Published

2010-09-01

Using case-based reasoning for generating functional test procedures

Propuesta de utilización del razonamiento basado en casos para la recuperación de procedimientos de prueba funcionales

DOI:

https://doi.org/10.15446/ing.investig.v30n3.18183

Keywords:

case based reasoning, software engineering, software quality, functional testing, artificial intelligence (en)
razonamiento basado en casos, ingeniería de software, calidad de software, pruebas funcionales, inteligencia artificial (es)

Authors

  • Martha Dunia Delgado Dapena Insitituto Superior Politécnico “José Antonio Echevarria” (CUJAE)
  • Yucely López Trujillo Insitituto Superior Politécnico “José Antonio Echevarria” (CUJAE)
  • Indira Chávez Valiente Insitituto Superior Politécnico “José Antonio Echevarria”

This paper presents a proposal for storage structure and retrieval mechanisms used for implementing case-based reasoning (CBR) in generating functional test procedures in software projects. This proposal was based on software project functional requirements and sets out the proposed algorithms for considering the similarity between each pair of projects as well as those leading to adapting the solution found in the case base.

En este trabajo se presenta una propuesta de estructura de almacenamiento y los mecanismos de recuperación utilizados para aplicar el razonamiento basado en casos (RBC) en la generación de procedimientos de prueba funcionales en proyectos de software. Esta propuesta parte de los requisitos funcionales del proyecto de software y en ella se enuncian los algoritmos propuestos para considerar la semejanza entre cada par de proyectos, así como los que permiten adaptar la solución encontrada en la base de casos a las características de los nuevos proyectos.

Propuesta de utilización del razonamiento basado en casos para la recuperación de procedimientos de prueba funcionales

Using  case-based reasoning for generating functional test procedures

Martha Dunia Delgado Dapena1 , Yucely López Trujillo2 e Indira Chávez Valiente3

1 Ingeniera Informatica. M.Sc., en Informática Aplicada. Ph.D., en Ciencias Técnicas, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. Centro de estudios de ingeniería de sistemas (CEIS), Facultad de Ingenieria Informatica, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. marta@ceis.cujae.edu.cu

2 Ingeniera Informatica. M.Sc., en Informática Aplicada. Ph.D., en Ciencias Técnicas, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. Centro de estudios de ingeniería de sistemas (CEIS), Facultad de Ingenieria Informatica, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. ylopez@ceis.cujae.edu.cu

3 Ingeniera Informatica. M.Sc., en Informática Aplicada. Ph.D., en Ciencias Técnicas, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. Centro de estudios de ingeniería de sistemas (CEIS), Facultad de Ingenieria Informatica, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. ichavez@ceis.cujae.edu.cu


RESUMEN

En este trabajo se presenta una propuesta de estructura de almacenamiento y los mecanismos de recuperación utilizados para aplicar el razonamiento basado en casos (RBC) en la generación de procedimientos de prueba funcionales en proyectos de software. Esta propuesta parte de los requisitos funcionales del proyecto de software y en ella se enuncian los algoritmos propuestos para considerar la semejanza entre cada par de proyectos, así como los que permiten adaptar la solución encontrada en la base de casos a las características de los nuevos proyectos.

Palabras claves: razonamiento basado en casos, ingeniería de software, calidad de software, pruebas funcionales, inteligencia artificial.


ABSTRACT

This paper presents a proposal for storage structure and retrieval mechanisms used for implementing case-based reasoning (CBR) in generating functional test procedures in software projects. This proposal was based on software project t functional requirements and sets out the proposed algorithms for considering the similarity between each pair of projects as well as those leading to adapting the solution found in the case base.

Keywords: case based reasoning, software engineering, software quality, functional testing, artificial intelligence.


Recibido: junio 5 de 2009
Aceptado: noviembre 15 de 2010


Introducción

El tema de la calidad del software es de gran actualidad. Sin embargo, aunque las empresas dedican grandes recursos a la adopción o definición de estándares de calidad los resultados alcanzados no cubren las expectativas, ya que la productividad es baja, la cantidad de recursos a consumir es casi impredecible y el resultado casi nunca tiene la calidad y profesionalidad requerida. Desde las primeras etapas en el ciclo de vida de un software se pueden comenzar a planificar las pruebas a realizar (Everett, 2007; Pressman, 2005) incluso antes de llegar a la etapa de codificación, con esto se evita insertar errores en la aplicación que pueden volverse muy difíciles de encontrar en fases posteriores.

A pesar de constituir una buena práctica, muy pocos se acogen a esta idea y comienzan a pensar en las pruebas sólo después de tener el código. La mayoría de los equipos de desarrollo de software cuentan con tiempo limitado para la creación de pruebas minuciosas y bien planificadas, lo cual trae consigo que se ejecuten fundamentalmente pruebas funcionales y sin una planificación previa. Bajo estas condiciones puede pensarse en trabajar sobre la acumulación, en la computadora, de la experiencia que se obtiene en cada una de las pruebas, de forma tal que se disponga de un banco de casos para apoyar la fase de pruebas en nuevos proyectos, y en particular la generación de casos y procedimientos de prueba partiendo de otros que se han utilizado antes y que han permitido detectar defectos en proyectos previos.

Diferentes metodologías en desarrollo de software incluyen las pruebas, y algunas hacen más énfasis en ellas, como es el caso del desarrollo guiado por pruebas —en inglés Test-Driven Development— (Augustine, 2005) y otras lo ven como una fase del desarrollo que debe garantizar la calidad del producto final (Jacobson, 2004), pero todas las propuestas coinciden en que es un tema de suma importancia y debe planificarse desde las etapas tempranas de desarrollo del software. Varios trabajos refieren la importancia de estimar el esfuerzo asociado a las pruebas para decidir su automatización o ejecución en cada caso (Singh y Misra, 2008), así como la automatización de pruebas en entornos específicos (Xie y Memon, 2007; Masood, Bhatti, Ghafoor y Mathur, 2009; (KO y Myers, 2010). Existe un conjunto de propuestas que abordan directamente el tema de la reducción de casos de prueba (Heimdahl, 2004; Mogyorodi, 2008; Polo, 2005; Black, 2004; éstas utilizan algoritmos donde es vital disponer del tiempo necesario para la etapa de pruebas, siendo esto a veces imposible.

Han surgido nuevos procesos y metodologías para diseñar pruebas (Myers, 2004; Guvenc, 2006; Meyer, 2006; Gutiérrez, 2007; Dias; 2008; Naslavsky, 2008), pero en general ellas no permiten la reutilización de casos o procedimientos generados con anterioridad.

La propuesta que se presenta en este artículo toma en cuenta solamente las pruebas a los requisitos del software (funcionales o de caja negra), cuyo objetivo fundamental es validar si el comportamiento observado de él cumple o no con las especificaciones. Este trabajo forma parte de un proyecto más ambicioso a cargo de un grupo de investigadores y profesores del Centro de Estudios de Ingeniería de Sistemas (CEIS) perteneciente a la Facultad de Informática del Instituto Superior Politécnico José Antonio Echeverría (Cujae), cuyo objetivo fundamental es hacer propuestas para la planificación y reutilización de pruebas funcionales.

El proyecto abarca tres fases: una primera, en la que se traduce la especificación de requisitos del software, escrito en un lenguaje no formal, a un listado de requisitos funcionales reducido a un verbo y un sustantivo que caracterizan la funcionalidad en cuestión. En la segunda fase se llevan a cabo varios procesos que generan un conjunto de casos y procedimientos de prueba para un proyecto de software partiendo de pruebas funcionales desarrolladas a proyectos anteriores. Por último, una tercera fase, en la que se reduce el conjunto de casos y procedimientos de prueba propuestos de acuerdo a determinados criterios de prioridad y que serán considerados como la primera aproximación al plan de pruebas funcionales.

Este reporte está enfocado en la segunda fase del proyecto, relacionada con los algoritmos y mecanismos que permiten la generación de procedimientos de prueba funcionales en un proyecto de software.  

Para lograr una herramienta de apoyo a este tipo de decisión parece aconsejable utilizar técnicas de inteligencia artificial (IA). Si se considera que a los posibles expertos les resulta muy difícil establecer cadenas de reglas generalizables que permitan inferir los casos de prueba y procedimientos de prueba a utilizar en cualquier tipo de proyecto, y les es más fácil expresar su conocimiento en términos de casos ya ocurridos, parece aconsejable emplear el razonamiento basado en casos —RBC— (Althoff, 2001).

El RBC ha tenido aplicaciones en la ingeniería de software (Shepperd, 2003; Ganesan, 2000; García, 2001). En particular, en las pruebas de software se han utilizado varias técnicas de IA, de las que algunos ejemplos son el análisis de resultados utilizando una red neuronal y algoritmos de minería de datos presentados en Last (2006), la priorización de casos de prueba utilizando algoritmos genéticos y otras técnicas (Elbaum, 2004; Fraser, 2007).

Razonamiento basado en casos para reutilizar procedimientos de prueba en proyectos de software

Estructura de la base de casos

La información referente a los proyectos y los defectos detectados en las revisiones a éstos se almacenan en un repositorio presentado en Delgado (2006), que ha sido enriquecido con los conceptos de casos y procedimientos de prueba, así como los mecanismos de recuperación que permiten recuperar los casos de prueba (CP) y los procedimientos de prueba (PP), asociados con los proyectos almacenados en la base de casos y que son semejantes al nuevo proyecto en el que se trata de generar los CP. Es importante precisar que esta propuesta es para generación en etapas tempranas, donde la información de entrada es requisito del nuevo proyecto.

Ha sido necesario introducir la asociación entre el requisito del proyecto y una descripción de los diferentes escenarios a considerar en su prueba funcional (descripción de prueba funcional, DPF). Esta descripción contiene el orden de las acciones involucradas en el desarrollo de la funcionalidad y que incluyen todos los escenarios posibles que deben ser considerados en la prueba funcional del requisito. La estructura interna de esta entidad ha sido tomada de la definición realizada por Delgado (2006).

Adicionalmente, la DPF es relacionada con cada uno de los PP diseñados para ejecutar su prueba funcional y éstos a su vez están referenciados por cada uno de los CP en los que se utilizan.

La estructura definida para almacenar los PP se muestra en la Tabla 2. Los PP son identificados en la base de proyectos por la combinación del par <verbo> <sustantivo> que definen su nombre.

El sustantivo que nombra el PP constituye la referencia a un marco o frame dentro de una jerarquía de frames en la que se expresan las relaciones entre las entidades de un dominio particular y que son utilizadas en esta propuesta para la recuperación de PP entre proyectos similares. La estructura del frame que modela una entidad particular es la que se muestra en la Tabla 1.

Los CP en su sección de entradas hacen además referencia al paso del PP en el que el probador del proyecto debe introducir los valores de los atributos y entidades correspondientes. El almacenamiento separado de PP y CP garantiza que el mismo PP pueda ser utilizado en varios CP. Como puede observarse, ambas estructuras están ligadas a la lógica funcional propia del requisito que se quiere probar, donde se combinan el orden de acciones a ejecutar descritas en el PP y determinadas por el verbo, con los valores propios del CP determinados por el o los sustantivos que definen las entidades y atributos referenciados en el CP y que están directamente relacionados con la jerarquía de frames.

Ahora bien, para poder reutilizar la información sobre los pasos u orden de ejecución de las acciones que están en el PP en nuevos proyectos, ha sido necesario definir un conjunto de patrones de PP (Patrón_PP) basados en las definiciones de patrones de Delgado (2006).

Cada patrón representa el conjunto de pasos que debe seguir el probador durante la ejecución de la prueba, para acciones específicas como por ejemplo "registrar", independientemente de si se desea probar la funcionalidad "registrar estudiante" o la funcionalidad "registrar profesor". Con esta definición, cada PP se relaciona con uno o varios Patrón_PP, lo que permitirá reutilizar ese Patrón_PP en la generación de nuevos PP en proyectos con características similares a los almacenados en la base de proyectos.

Los Patrón_PP forman parte de una red semántica en la que existen tres tipos de relaciones: "es un", "incluye a" y "se extiende de". Estos tipos de relaciones están determinadas por las relación existente entre los verbos que identifican cada uno de los Patrón_PP. En la Tabla 4 se describe el significado semántico de estas relaciones, considerando A y B dos Patrón_PP pertenecientes a la red semántica.

Hay un cuarto tipo de relación entre los verbos que expresa su equivalencia con la relación "es equivalente a", por ejemplo, entre los verbos "registrar" y "crear". Este tipo de relación se considerará asociando un único Patrón_PP al conjunto de verbos equivalentes.

El Patrón_PP contiene ranuras que podrán ser instanciadas en el momento de la adaptación de los PP de un problema particular. En la Tabla 4 aparecen los tipos de ranuras que pueden aparecer en un Patrón_PP y donde pueden ubicarse los valores para su instanciación durante el proceso de adaptación de PP.

Determinación de la semejanza entre proyectos

Para poder ejecutar la fase de recuperación del sistema de RBC, es decir, recuperar los proyectos (casos), es necesario antes analizar cuáles son los rasgos que distinguen a cada proyecto de software. En este caso se considera como rasgo predictor a cada requisito del proyecto, tal como se presenta en la propuesta realizada para revisiones a proyectos de software, en Delgado (2006).

La función de semejanza entre proyectos es

f(wii(xi(O0),xi(OB)))=∑ni=lwiδi(xi(O0),Xi(OB))/∑ni=l wi  donde wi es el nivel de importancia o significación de cada requisito dentro del nuevo problema. Esto permite dar mayor importancia, dentro del proyecto que se desea revisar, a los requisitos que el analista o inspector consideren como los más significativos. El valor por defecto de wi es 1.

δi(xi(O0),xi(OB))=fr((wki(zi(xi(O0)),zi(xi(OB))))2k=l, es la función que evalúa la semejanza entre un par de requisitos y que es utilizada para combinar los valores de semejanza entre los verbos y los sustantivos para obtener el valor de semejanza entre dos requisitos.

fr((wkij(zk(yi),zk(yj)))2k=l)=∑k=l2wkij(zk(yi),zk(yj))

Para determinar la semejanza entre los sustantivos y los verbos se utilizó una red semántica en la cual se consideran dos tipos de relaciones: las relaciones jerárquicas ("es un", "es una instancia de") y las relaciones de equivalencia ("es equivalente a"). La función empleada en la determinación de la semejanza entre los verbos δij(z1(yi),z1(yj)) y entre los sustantivos δij(z2(yi),z2(yj)) es la presentada en Delgado (2006).


Los casos comparados con el nuevo problema se almacenarán en una lista lineal ordenada por valor descendente de la función f. Esta información será utilizada en la generación de la nueva solución.

Generación y adaptación de la nueva solución

Después de realizar la búsqueda se toma el caso o proyecto con valor mayor de f como potencial solución y se analiza si en este caso son cubiertos todos los requisitos que están presentes en el nuevo problema; de no ser así, se completa la solución potencial con los requisitos del segundo caso más parecido y así sucesivamente hasta completar los requisitos del nuevo problema o terminar de analizar el conjunto de casos recuperados.

Al asociar un requisito del nuevo proyecto xi(ON) con otro de un proyecto almacenado en la base de casos xj(ON) se puede asignar al requisito del nuevo problema el conjunto de CP y PP que es recuperado, pero antes es necesario valorar el nivel de semejanza entre ambos requisitos para valorar si pueden tomarse los CP y PP tal como aparecen en la base de casos, o es necesario hacer alguna adaptación. Si el valor de f es "1", pueden tomarse tal como están, porque es exactamente el mismo requisito, pero si no es el mismo se tienen dos casos que merecen un tratamiento diferenciado:

1. El valor de f está en [μ, 1), donde μ es un valor de umbral por encima del cual se pueden considerar semejantes un par de requisitos. El algoritmo 1 (Figuras 1 y 3) muestra cómo se realiza la adaptación en este caso. 2. El valor de f es "0"; no se encontró un requisito en la base de casos semejante al requisito del nuevo proyecto. El algoritmo 2 (Figura 2) muestra cómo se realiza la adaptación en este caso.

En el desarrollo de estos algoritmos se utilizan dos umbrales que permiten decidir cuándo un par de verbos y un par de sustantivos de requisitos pueden ser considerados semejantes, ellos son: μ1 y μ2 definidos para los verbos y sustantivos, respectivamente.

Los PP generados son utilizados para generar los CP correspondientes utilizando la información almacenada en la red de entidades y el conjunto de PPP que ya han sido generados. Los PP y CP obtenidos son puestos a consideración del usuario y éste puede hacer ajustes a la solución e incorporar nuevas consideraciones de acuerdo a la situación concreta que modela el proyecto, y esa nueva solución se almacenará en la base de ejemplos como un nuevo caso.

Conclusiones

Este trabajo hace una propuesta para la generación de procedimientos de pruebas funcionales, basada en el uso del razonamiento basado en casos para reutilizar información que haya sido generada con anterioridad. El aporte fundamental de la propuesta a juicio de sus autores está en el diseño de los algoritmos que permiten la recuperación y adaptación de procedimientos de prueba almacenados en la base de proyectos y que permite que se aproveche la experiencia anterior.

No obstante, la investigación no es una propuesta terminada, pues se trabaja en el desarrollo de las restantes fases del proyecto para llegar a ofrecer una solución que llegue hasta la priorización de qué casos de prueba ejecutar considerando restricciones de tiempo. En el momento en que se escribe este reporte se trabaja en la implementación de una herramienta que haga posible la experimentación en el ámbito docente como una primera prueba para comprobar los resultados que se pueden obtener con la propuesta.

Bibliografía

Althoff, K., Case-Based Reasoning. Handbook of Software Engineering and Knowledge Engineering., Kaiserslautern, Germany, Fraunhofer Institute for Experimental Software Engineering (IESE), 2001.

Augustine, S., Managing Agile Projects. Publicaciones Prentice Hall PTR, 2005.

Black, R., Pragmatic Software Testing-Becoming and Effective and Efficient Test Profesional., Publicaciones Wiley, 2007.

Delgado, M., Lorenzo, I., Carralero, J., Travieso, J., Rosete, A., Una propuesta de apoyo a las Revisiones de Proyectos de Software utilizando Razonamiento Basado en Casos., Revista Iberoamericana de Inteligencia Artificial, Vol. 10, No. 30, 2006, pp. 55-68.

Dias, A. C., Horta, G., Supporting the Selection of Model-based Testing., Approaches for Software Projects, AST '08: Proceedings of the 3rd international workshop on Automation of software test, ACM, mayo 2008.

Elbaum, S., Rothermel, G., Malishevsky, M., Selecting a Cost-Efective Test Case Prioritization Technique., Software Quality Journal, 2004 - Springer.

Everett, G. McLeod, R., Software Testing: Testing across the entire software development life cycle., John Wiley Edition, 2007.

Fraser, G., Wotawa, F., Test-Case Prioritization with Model-Checkers, 25th conference on IASTED International, 2007.

Ganesan, K., Khoshgoftaar, T., Allen, E., Case-Based Software Quality Prediction., International Journal of Software Engineering and Knowledge Engineering, Vol. 10, No. 2, 2000, pp. 139-152.

García, F., Corchado, J., Laguna, M., CBR Applied to Development with Reuse Based on mecanos., Proceedings of the 13th International Conference on Software Engineering and Knowledge Engineering, Buenos Aires, Argentina, 2001.

Gutiérrez, J., Generación automática de objetivos de prueba a partir de casos de uso mediante partición de categorías y variables operacionales., XVI Jornadas de Ingeniería del Software y Bases de Datos, JISBD07, España, 2007. 

Guvenc, M., Writing Testable and Code-able Requirements., Quality Software and Testing, Volumen 4, 2006.

Heimdahl M., George D., Test-Suite Reduction for Model Based Tests: Effects on Test Quality and Implications for Testing., 19th IEEE International Conference on Automated Software Engineering (ASE'04), 2004, pp. 176-185.

Jacobson, I., Booch, G., Rumbaugh, J., El Proceso Unificado de desarrollo de Software., Vol. 1, Editorial Félix Varela, 2004.

Ko, A., Myers, B., Extracting and Answering Why and Why Not Questions about Java Program Output., ACM Transactions on Software Engineering and Methodology, Vol. 20, No. 2, Article 4, August 2010.

Last, M., The Uncertainty Principle of Cross-Validation., 2006 IEEE International Conference on Granular Computing, 2006.

Masood, A.,  Bhatti, R., Ghafoor, A., Mathur, A., Scalable and Effective Test Generation for Role-Based Access Control Systems., IEEE Transactions on Software Engineering, Vol. 35, No. 5, September/October 2009.

Meyer, B., XP and TDD: Extreme Programing and Test-Driven Development., Chair of Software Engineering, Zurich, 2006.

Mogyorodi, E., Requirements-Based Testing: Ambiguity Reviews., Testing Experience: The Magazine for Professional Testers, 2008.

Myers, G. J., The Art of Software Testing., 2da Edición, Editorial John Wiley, 2004.

Naslavsky, L., Ziv, H., Richardson, D., Using Model Transformation to Support Model-BasedTest Coverage Measurement., AST '08: Proceedings of the 3rd international workshop on Automation of software test, ACM, mayo 2008.

Polo, M., Priorización de casos  de   prueba mediante mutación., Taller sobre Pruebas de Ingeniería del Software, PRIS 2007. Vol. 1, No. 4.

Pressman, R., Ingeniería del Software: un enfoque práctico., Vol. 1, Editorial Félix Varela, 5ta edición, 2005.

Shepperd, M., Case-based Reasoning and Software Engineering., Empirical Software Engineering Research Group, Universidad de Bournemouth, UK, 2003.

Singh, D., Misra, A. K., Software Test Effort Estimation, ACM SIGSOFT Software Engineering Notes, Vol. 33, No. 3, May 2008.

Xie, Q., Memon, A., Designing and Comparing Automated Test Oracles for GUI-Based Software Applications., ACM Transactions Software Engineering and Methodology, Vol. 16, No. 1, Article 4, Febrary 2007.

Using case-based reasoning for generating functional test procedures

Martha Dunia Delgado Dapena1 , Yucely López Trujillo2 e Indira Chávez Valiente3

1 Computer Engineering. M.Sc., in Applied Computing. Ph.D., in Technical Sciences, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. Centro de estudios de ingeniería de sistemas (CEIS), School of Computer Engineering, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. marta@ceis.cujae.edu.cu

2 Computer Engineering. M.Sc., in Applied Computing. Ph.D., in Technical Sciences, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. Centro de estudios de ingeniería de sistemas (CEIS), School of Computer Engineering, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. ylopez@ceis.cujae.edu.cu

3Computer Engineering. M.Sc., in Applied Computing. Ph.D., in Technical Sciences, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. Centro de estudios de ingeniería de sistemas (CEIS), School of Computer Engineering, Insitituto Superior Politécnico "José Antonio Echevarria" (CUJAE), La Habana, Cuba. ichavez@ceis.cujae.edu.cu


ABSTRACT

This paper presents a proposal for storage structure and retrieval mechanisms used for implementing case-based reasoning (CBR) in generating functional test procedures in software projects. This proposal was based on software project t functional requirements and sets out the proposed algorithms for considering the similarity between each pair of projects as well as those leading to adapting the solution found in the case base.

Keywords: case based reasoning, software engineering, software quality, functional testing, artificial intelligence.


Received: june 5th 2009

Accepted: november 15th 2010

Introduction

The issue of software quality receives a lot of attention nowadays. Although companies devote significant resources to adopting or defining quality standards, the results have not met expectations since productivity has been low, the actual amount of resources consumed has been almost unpredictable and has almost never resulted in the required quality and professionalism. The tests to be performed (Everett, 2007) (Pressman, 2005) can be planned from the earliest stages of software life-cycle, even before reaching the codification stage. This prevents errors being inserted into an application, which can become quite difficult to find in later stages.

Despite being good practice, few are benefiting from this idea and only begin to think about the tests after having the code. Most software development teams have limited time for creating detailed and well-planned testing, consequently leading to the execution of mainly functional tests without prior planning. In these circumstances, one can think of working on accumulating experience in the computer which has been obtained from each test. Doing so, a bank of cases can be created to support new projects´ testing phase and, in particular, generating test cases and procedures from others which have already been used and have led to identifying flaws in previous projects.

Software development methodologies include testing; some place more emphasis on this aspect, as in the case of test-driven development (Augustine, 2005). Other methodologies consider testing as a developmental stage that should ensure final product quality (Jacobson, 2004). Nonetheless, all proposals agree that it is an issue of paramount importance and should be planned during early stages of software development. Some studies have referred to the importance of estimating the effort associated with testing to determine automation or performance in each case (Singh and Misra 2008) and also test automation in specific environments (Xie and Memon 2007) (Masood Bhatti Ghafoor and Mathur 2009)(KO and Myers 2010). One set of proposals directly addresses the reduction of test cases (Heimdahl, 2004) (Mogyorodi, 2008) (Polo,2005) (Black, 2004); they use algorithms in which it is vital to have sufficient time for the testing stage, this being sometimes impossible.

New processes and methodologies for designing tests are available (Myers, 2004) (Guvenc, 2006) (Meyer, 2006) (Gutiérrez, 2007) (Dias, 2008) (Naslavsky, 2008) but they do not usually allow reuse of cases or previously-generated procedures.

The proposal presented in this paper only takes into account testing software requirements (functional or black box) whose main objective is to validate whether observed software behavior complies with its specifications. This work forms part of a larger project by a group of researchers and teachers from the Systems Engineering Study Center (CEIS), forming part of the Computer Science Faculty at the José Antonio Echeverría Higher Polytechnic Institute (CUJAE). Its main objective was to make proposals for planning functional tests and reusing them.

The project consisted of three phases. The first consisted of translating software requirements written in non-formal language to a list of functional requirements reduced to a verb and noun characterising the functionality in question. Several processes were carried out in the second phase generating a set of test cases and procedures for a software project based on functional tests from previous projects. A third phase reduced the set of cases and test procedures proposed in accordance with priority criteria and will be considered as a first approach to functional test planning.

This report focus on the project´s second phase related to algorithms and mechanisms generating functional test procedures in a software project.

Artificial intelligence (AI) techniques were used for achieving a tool for supporting this type of decision. Case-based reasoning (CBR)) (Althoff, 2001) was used, taking into consideration that potential experts find it very difficult to establish chains of generalized rules generating test cases and test procedures for use in any type of project, and it is easier to express knowledge in terms of cases.

CBR has had applications in software engineering (Shepperd, 2003) (Ganesan, 2000) (García, 2001). Several AI techniques have been used in software testing; some examples would be analysing results using a neural network and data-mining algorithms presented by Last (Last, 2006), prioritising test cases using genetic algorithms (Elbaum, 2004) (Fraser, 2007)

Case-based reasoning for reusing test procedures on software projects

Base case structure

Information regarding the projects and all defects detected were stored in a repository presented by Delgado (Delgado, 2006). This repository had been enriched with test cases, test procedures and recovery mechanisms. The latter allowed retrieval of test cases (TC) and test procedures (TP) associated with the projects stored in the case database which were similar to a new project for which one may want to generate a TC. It should be noted that this proposal consisted of generation during early stages where input informatio was required for a new project.

It has been necessary to associate project requirements and a description of different scenarios to be considered in the functional test (functional test description - FTD). The FTD contained the order of actions involved in developing functionality and included all possible scenarios to be considered in the requirement´s FDT. This entity´s internal structure has been taken from Delgado´s definition (2006).

The FTD was linked to each TP designed for performing functional testing and these, in turn, were referenced by each TC where they were used.

The structure defined for storing the TP is shown in Table 2. TP were identified in the project database by combining the pair (<VERB>, <NOUN>) defining its name.

The NOUN identifying the TP referred to a frame within a hierarchy of frames expressing relationships between entities in a particular domain and were used in this proposal for recovery of TP amongst similar projects. The frame structure modelling a particular entity is shown in Table 1.

At its input section, TC also referred to the TP step where the project tester had to enter values for corresponding attributes and entities. Separate storage of TP and TC ensured that the same TP could be used in various TC. As can be seen, both structures were linked to the functional logic of the requirement to be tested; they combined the order in which actions were executed, as described in the TP, with TC input values. TP were determined by the verb and the TC were determined by nouns corresponding to the entities and attributes referenced in the TC. These entities were directly related to frame hierarchy.

A set of TP patterns (Pattern_TP) based on the pattern definitions described by Delgado (2006) had to be defined to reuse information about the order of executing actions included in a new project´s TP.

Each pattern represented the set of steps to be followed by the tester during test execution. For example, for specific verb such as "to register", regardless of whether one wanted to test the functionality "register student" or "register teacher", the set of steps to be executed were the same. With this definition, each TP was linked to one or more Pattern_TP, allowing such Pattern_TP to be reused in generating TP in projects having similar characteristics to those stored in the project database.

Pattern_TP formed part of a semantic network in which there were three types of relationship: "is a", "includes to" and "extends from". These types of relationships were determined by the relationship between verbs identifying each Pattern_TP. Table 4 describes the semantic meaning of these relationships where A and B were type Pattern_TP and belonged to the semantic network.

A fourth kind of relationship named "is equivalent to",expressing equivalence, existed between the verbs. For example, the verbs "register" and "create" were equivalent. All equivalent verbs were associated with a single Pattern_TP in this kind of relationship.

The Pattern_TP contained slots that could be instantiated at the time of TP adaptation in a particular project. Table 4 shows the types of slots that could be presented in a Pattern_TP and where the

Determining similarity between projects

To run the CBR system recovery phase, i.e. project recovery (cases),it was first necessary to analyse which were each software project´s distinguishing features. In this case, each project requirement was considered as a trait predictor, as presented in Delgado(2006), in software project revisions.

The function of similarity between projects

f(wii(xi(O0),xi(OB)))=∑ni=lwiδi(xi(O0),Xi(OB))/∑ni=l wi   where wi was the level of importance or significance of each requirement within the new problem. This gave greater emphasis to the requirements analyst or inspector considering the most significant within the project to be reviewed.

δi(xi(O0),xi(OB))=fr((wki(zi(xi(O0)),zi(xi(OB))))2k=l ,          where

fr((wkij(zk(yi),zk(yj)))2k=l)=∑k=l2wkij(zk(yi),zk(yj)) , was the funtion evaluating similarity between a pair of requirements. This function was used to combine the similarity values between nouns and verbs and obtain the value of similarity between two requirements. A semantic network in which there were two main types of relationships, hierarchical relationships ("is a") and equivalence relations ("is equivalent to") was used for determining the similarity between nouns (and verbs). The function used for determining the similarity between verbs δij(z1(yi),z1(yj))  and between nouns δij(z2(yi),z2(yj))  was presented in Delgado (2006).

The cases compared with the new problem were stored in a linear list sorted by descending function value f . This information was used in generating a new solution.

Generating and adapting a new solution

After performing the search, the project having the highest similarity value f was used as a potential solution; it was checked that it covered all the requirements of a new project. In case not all requirements were covered, the potential solution was completed with the requirements of the second most similar case, and so on, until all the new project´s requirements were completed or all recovered cases were analysed.

When a requirement from the new project xi(ON)  was associated with another from a project stored in the case database xj(ON) , the set of TC and TP which have been recovered can be assigned to the new project requirement. However, the degree of similarity between the two requirements had to be assessed to decide whether they could take the TC and TP as they appeared in the case database or whether some adaptation were needed. If the value of f was "1" TC and TP could be taken as they were because it was exactly the same requirement, otherwise two cases would deserve special treatment:

1. Value of f was [μ, 1), where μ was a threshold value. If the value of f was greater than μ then the pair of requirements was similar. Algorithm 1 (Figure 1 y 3) shows how the adjustment was made in this case.

2. Value of f was "0". No requirement found in the case database similar to the requirement of a new project. Algorithm 2 (Figure 2)shows how the adjustment was made in this case.

Two thresholds values were used in developing these algorithms to decide when a pair of verbs and a few nouns could be considered similar. They were defined for verbs μ1  and μ2  for nouns.

The TP so generated were used for generating TC for using information stored in the network of entities and the set of patterns which had been generated. The TP and TC obtained were presented to the user. Doing so, adjustments could be made to the solution and new

considerations could be incorporated, according to a new project´s t specific situation. The new solution was stored in the case database as a new case.

Conclusions

This paper proposes generating functional test procedures based on the use of case-based reasoning for reusing previously generated information. The proposal´s fundamental contribution lies in designing algorithms leading to the recovery and adaptation of test procedures stored in the project database and allows past experience to be taken advantage of.

However, this research is not a complete proposal; further work is being carried out on developing the remaining phases of the project to provide a solution establishing the priority in which test cases must be run, considering time constraints. At the moment, efforts are directed towards implementing a tool for experimenting during teaching to generate a test bench for checking the results to be obtainned from the proposal.

References

Althoff, K., Case-Based Reasoning. Handbook of Software Engineering and Knowledge Engineering., Kaiserslautern, Germany, Fraunhofer Institute for Experimental Software Engineering (IESE), 2001.

Augustine, S., Managing Agile Projects. Publicaciones Prentice Hall PTR, 2005.

Black, R., Pragmatic Software Testing-Becoming and Effective and Efficient Test Profesional., Publicaciones Wiley, 2007.

Delgado, M., Lorenzo, I., Carralero, J., Travieso, J., Rosete, A., Una propuesta de apoyo a las Revisiones de Proyectos de Software utilizando Razonamiento Basado en Casos., Revista Iberoamericana de Inteligencia Artificial, Vol. 10, No. 30, 2006, pp. 55-68.

Dias, A. C., Horta, G., Supporting the Selection of Model-based Testing., Approaches for Software Projects, AST '08: Proceedings of the 3rd international workshop on Automation of software test, ACM, mayo 2008.

Elbaum, S., Rothermel, G., Malishevsky, M., Selecting a Cost-Efective Test Case Prioritization Technique., Software Quality Journal, 2004 - Springer.

Everett, G. McLeod, R., Software Testing: Testing across the entire software development life cycle., John Wiley Edition, 2007.

Fraser, G., Wotawa, F., Test-Case Prioritization with Model-Checkers, 25th conference on IASTED International, 2007.

Ganesan, K., Khoshgoftaar, T., Allen, E., Case-Based Software Quality Prediction., International Journal of Software Engineering and Knowledge Engineering, Vol. 10, No. 2, 2000, pp. 139-152.

García, F., Corchado, J., Laguna, M., CBR Applied to Development with Reuse Based on mecanos., Proceedings of the 13th International Conference on Software Engineering and Knowledge Engineering, Buenos Aires, Argentina, 2001.

Gutiérrez, J., Generación automática de objetivos de prueba a partir de casos de uso mediante partición de categorías y variables operacionales., XVI Jornadas de Ingeniería del Software y Bases de Datos, JISBD07, España, 2007. 

Guvenc, M., Writing Testable and Code-able Requirements., Quality Software and Testing, Volumen 4, 2006.

Heimdahl M., George D., Test-Suite Reduction for Model Based Tests: Effects on Test Quality and Implications for Testing., 19th IEEE International Conference on Automated Software Engineering (ASE'04), 2004, pp. 176-185.

Jacobson, I., Booch, G., Rumbaugh, J., El Proceso Unificado de desarrollo de Software., Vol. 1, Editorial Félix Varela, 2004.

Ko, A., Myers, B., Extracting and Answering Why and Why Not Questions about Java Program Output., ACM Transactions on Software Engineering and Methodology, Vol. 20, No. 2, Article 4, August 2010.

Last, M., The Uncertainty Principle of Cross-Validation., 2006 IEEE International Conference on Granular Computing, 2006.

Masood, A.,  Bhatti, R., Ghafoor, A., Mathur, A., Scalable and Effective Test Generation for Role-Based Access Control Systems., IEEE Transactions on Software Engineering, Vol. 35, No. 5, September/October 2009.

Meyer, B., XP and TDD: Extreme Programing and Test-Driven Development., Chair of Software Engineering, Zurich, 2006.

Mogyorodi, E., Requirements-Based Testing: Ambiguity Reviews., Testing Experience: The Magazine for Professional Testers, 2008.

Myers, G. J., The Art of Software Testing., 2da Edición, Editorial John Wiley, 2004.

Naslavsky, L., Ziv, H., Richardson, D., Using Model Transformation to Support Model-BasedTest Coverage Measurement., AST '08: Proceedings of the 3rd international workshop on Automation of software test, ACM, mayo 2008.

Polo, M., Priorización de casos  de   prueba mediante mutación., Taller sobre Pruebas de Ingeniería del Software, PRIS 2007. Vol. 1, No. 4.

Pressman, R., Ingeniería del Software: un enfoque práctico., Vol. 1, Editorial Félix Varela, 5ta edición, 2005.

Shepperd, M., Case-based Reasoning and Software Engineering., Empirical Software Engineering Research Group, Universidad de Bournemouth, UK, 2003.

Singh, D., Misra, A. K., Software Test Effort Estimation, ACM SIGSOFT Software Engineering Notes, Vol. 33, No. 3, May 2008.

Xie, Q., Memon, A., Designing and Comparing Automated Test Oracles for GUI-Based Software Applications., ACM Transactions Software Engineering and Methodology, Vol. 16, No. 1, Article 4, Febrary 2007.

References

Althoff, K., Case-Based Reasoning. Handbook of Software Engineering and Knowledge Engineering., Kaiserslautern, Germany, Fraunhofer Institute for Experimental Software Engineering (IESE), 2001. DOI: https://doi.org/10.1142/9789812389718_0023

Augustine, S., Managing Agile Projects. Publicaciones Prentice Hall PTR, 2005.

Black, R., Pragmatic Software Testing-Becoming and Effective and Efficient Test Profesional., Publicaciones Wiley, 2007.

Delgado, M., Lorenzo, I., Carralero, J., Travieso, J., Rosete, A., Una propuesta de apoyo a las Revisiones de Proyectos de Software utilizando Razonamiento Basado en Casos., Revista Iberoamericana de Inteligencia Artificial, Vol. 10, No. 30, 2006, pp. 55-68.

Dias, A. C., Horta, G., Supporting the Selection of Model-based Testing., Approaches for Software Projects, AST '08: Proceedings of the 3rd international workshop on Automation of software test, ACM, mayo 2008.

Elbaum, S., Rothermel, G., Malishevsky, M., Selecting a Cost-Efective Test Case Prioritization Technique., Software Quality Journal, 2004 - Springer. DOI: https://doi.org/10.1023/B:SQJO.0000034708.84524.22

Everett, G. McLeod, R., Software Testing: Testing across the entire software development life cycle., John Wiley Edition, 2007. DOI: https://doi.org/10.1002/9780470146354

Fraser, G., Wotawa, F., Test-Case Prioritization with Model-Checkers, 25th conference on IASTED International, 2007.

Ganesan, K., Khoshgoftaar, T., Allen, E., Case-Based Software Quality Prediction., International Journal of Software Engineering and Knowledge Engineering, Vol. 10, No. 2, 2000, pp. 139-152. DOI: https://doi.org/10.1142/S0218194000000092

García, F., Corchado, J., Laguna, M., CBR Applied to Development with Reuse Based on mecanos., Proceedings of the 13th International Conference on Software Engineering and Knowledge Engineering, Buenos Aires, Argentina, 2001.

Gutiérrez, J., Generación automática de objetivos de prueba a partir de casos de uso mediante partición de categorías y variables operacionales., XVI Jornadas de Ingeniería del Software y Bases de Datos, JISBD07, España, 2007.

Guvenc, M., Writing Testable and Code-able Requirements., Quality Software and Testing, Volumen 4, 2006.

Heimdahl M., George D., Test-Suite Reduction for Model Based Tests: Effects on Test Quality and Implications for Testing., 19th IEEE International Conference on Automated Software Engineering (ASE'04), 2004, pp. 176-185.

Jacobson, I., Booch, G., Rumbaugh, J., El Proceso Unificado de desarrollo de Software., Vol. 1, Editorial Félix Varela, 2004.

Ko, A., Myers, B., Extracting and Answering Why and Why Not Questions about Java Program Output., ACM Transactions on Software Engineering and Methodology, Vol. 20, No. 2, Article 4, August 2010. DOI: https://doi.org/10.1145/1824760.1824761

Last, M., The Uncertainty Principle of Cross-Validation., 2006 IEEE International Conference on Granular Computing, 2006.

Masood, A., Bhatti, R., Ghafoor, A., Mathur, A., Scalable and Effective Test Generation for Role-Based Access Control Systems., IEEE Transactions on Software Engineering, Vol. 35, No. 5, September/October 2009. DOI: https://doi.org/10.1109/TSE.2009.35

Meyer, B., XP and TDD: Extreme Programing and Test-Driven Development., Chair of Software Engineering, Zurich, 2006.

Mogyorodi, E., Requirements-Based Testing: Ambiguity Reviews., Testing Experience: The Magazine for Professional Testers, 2008.

Myers, G. J., The Art of Software Testing., 2da Edición, Editorial John Wiley, 2004.

Naslavsky, L., Ziv, H., Richardson, D., Using Model Transformation to Support Model-BasedTest Coverage Measurement., AST '08: Proceedings of the 3rd international workshop on Automation of software test, ACM, mayo 2008. DOI: https://doi.org/10.1145/1370042.1370044

Polo, M., Priorización de casos de prueba mediante mutación., Taller sobre Pruebas de Ingeniería del Software, PRIS 2007. Vol. 1, No. 4.

Pressman, R., Ingeniería del Software: un enfoque práctico., Vol. 1, Editorial Félix Varela, 5ta edición, 2005.

Shepperd, M., Case-based Reasoning and Software Engineering., Empirical Software Engineering Research Group, Universidad de Bournemouth, UK, 2003. DOI: https://doi.org/10.1007/978-3-662-05129-0_9

Singh, D., Misra, A. K., Software Test Effort Estimation, ACM SIGSOFT Software Engineering Notes, Vol. 33, No. 3, May 2008. DOI: https://doi.org/10.1145/1360602.1361211

Xie, Q., Memon, A., Designing and Comparing Automated Test Oracles for GUI-Based Software Applications., ACM Transactions Software Engineering and Methodology, Vol. 16, No. 1, Article 4, February 2007. DOI: https://doi.org/10.1145/1189748.1189752

How to Cite

APA

Delgado Dapena, M. D., López Trujillo, Y. and Chávez Valiente, I. (2010). Using case-based reasoning for generating functional test procedures. Ingeniería e Investigación, 30(3), 116–123. https://doi.org/10.15446/ing.investig.v30n3.18183

ACM

[1]
Delgado Dapena, M.D., López Trujillo, Y. and Chávez Valiente, I. 2010. Using case-based reasoning for generating functional test procedures. Ingeniería e Investigación. 30, 3 (Sep. 2010), 116–123. DOI:https://doi.org/10.15446/ing.investig.v30n3.18183.

ACS

(1)
Delgado Dapena, M. D.; López Trujillo, Y.; Chávez Valiente, I. Using case-based reasoning for generating functional test procedures. Ing. Inv. 2010, 30, 116-123.

ABNT

DELGADO DAPENA, M. D.; LÓPEZ TRUJILLO, Y.; CHÁVEZ VALIENTE, I. Using case-based reasoning for generating functional test procedures. Ingeniería e Investigación, [S. l.], v. 30, n. 3, p. 116–123, 2010. DOI: 10.15446/ing.investig.v30n3.18183. Disponível em: https://revistas.unal.edu.co/index.php/ingeinv/article/view/18183. Acesso em: 4 apr. 2025.

Chicago

Delgado Dapena, Martha Dunia, Yucely López Trujillo, and Indira Chávez Valiente. 2010. “Using case-based reasoning for generating functional test procedures”. Ingeniería E Investigación 30 (3):116-23. https://doi.org/10.15446/ing.investig.v30n3.18183.

Harvard

Delgado Dapena, M. D., López Trujillo, Y. and Chávez Valiente, I. (2010) “Using case-based reasoning for generating functional test procedures”, Ingeniería e Investigación, 30(3), pp. 116–123. doi: 10.15446/ing.investig.v30n3.18183.

IEEE

[1]
M. D. Delgado Dapena, Y. López Trujillo, and I. Chávez Valiente, “Using case-based reasoning for generating functional test procedures”, Ing. Inv., vol. 30, no. 3, pp. 116–123, Sep. 2010.

MLA

Delgado Dapena, M. D., Y. López Trujillo, and I. Chávez Valiente. “Using case-based reasoning for generating functional test procedures”. Ingeniería e Investigación, vol. 30, no. 3, Sept. 2010, pp. 116-23, doi:10.15446/ing.investig.v30n3.18183.

Turabian

Delgado Dapena, Martha Dunia, Yucely López Trujillo, and Indira Chávez Valiente. “Using case-based reasoning for generating functional test procedures”. Ingeniería e Investigación 30, no. 3 (September 1, 2010): 116–123. Accessed April 4, 2025. https://revistas.unal.edu.co/index.php/ingeinv/article/view/18183.

Vancouver

1.
Delgado Dapena MD, López Trujillo Y, Chávez Valiente I. Using case-based reasoning for generating functional test procedures. Ing. Inv. [Internet]. 2010 Sep. 1 [cited 2025 Apr. 4];30(3):116-23. Available from: https://revistas.unal.edu.co/index.php/ingeinv/article/view/18183

Download Citation

CrossRef Cited-by

CrossRef citations0

Dimensions

PlumX

Article abstract page views

424

Downloads