1 research outputs found

    Testing and test-driven development of conceptual schemas

    Get PDF
    The traditional focus for Information Systems (IS) quality assurance relies on the evaluation of its implementation. However, the quality of an IS can be largely determined in the first stages of its development. Several studies reveal that more than half the errors that occur during systems development are requirements errors. A requirements error is defined as a mismatch between requirements specification and stakeholders驴 needs and expectations. Conceptual modeling is an essential activity in requirements engineering aimed at developing the conceptual schema of an IS. The conceptual schema is the general knowledge that an IS needs to know in order to perform its functions. A conceptual schema specification has semantic quality when it is valid and complete. Validity means that the schema is correct (the knowledge it defines is true for the domain) and relevant (the knowledge it defines is necessary for the system). Completeness means that the conceptual schema includes all relevant knowledge. The validation of a conceptual schema pursues the detection of requirements errors in order to improve its semantic quality. Conceptual schema validation is still a critical challenge in requirements engineering. In this work we contribute to this challenge, taking into account that, since conceptual schemas of IS can be specified in executable artifacts, they can be tested. In this context, the main contributions of this Thesis are (1) an approach to test conceptual schemas of information systems, and (2) a novel method for the incremental development of conceptual schemas supported by continuous test-driven validation. As far as we know, this is the first work that proposes and implements an environment for automated testing of UML/OCL conceptual schemas, and the first work that explores the use of test-driven approaches in conceptual modeling. The testing of conceptual schemas may be an important and practical means for their validation. It allows checking correctness and completeness according to stakeholders驴 needs and expectations. Moreover, in conjunction with the automatic check of basic test adequacy criteria, we can also analyze the relevance of the elements defined in the schema. The testing environment we propose requires a specialized language for writing tests of conceptual schemas. We defined the Conceptual Schema Testing Language (CSTL), which may be used to specify automated tests of executable schemas specified in UML/OCL. We also describe a prototype implementation of a test processor that makes feasible the approach in practice. The conceptual schema testing approach supports test-last validation of conceptual schemas, but it also makes sense to test incomplete conceptual schemas while they are developed. This fact lays the groundwork of Test-Driven Conceptual Modeling (TDCM), which is our second main contribution. TDCM is a novel conceptual modeling method based on the main principles of Test-Driven Development (TDD), an extreme programming method in which a software system is developed in short iterations driven by tests. We have applied the method in several case studies, in the context of Design Research, which is the general research framework we adopted. Finally, we also describe an integration approach of TDCM into a broad set of software development methodologies, including the Unified Process development methodology, MDD-based approaches, storytest-driven agile methods and goal and scenario-oriented requirements engineering methods.Els enfocaments per assegurar la qualitat deis sistemes d'informaci贸 s'han basal tradicional m en! en l'avaluaci贸 de la seva implementaci贸. No obstan! aix6, la qualitat d'un sis tema d'informaci贸 pot ser ampliament determinada en les primeres fases del seu desenvolupament. Diversos estudis indiquen que m茅s de la meitat deis errors de software s贸n errors de requisits . Un error de requisit es defineix com una desalineaci贸 entre l'especificaci贸 deis requisits i les necessitats i expectatives de les parts im plicades (stakeholders ). La modelitzaci贸 conceptual 茅s una activitat essencial en l'enginyeria de requisits , l'objectiu de la qual 茅s desenvolupar !'esquema conceptual d'un sistema d'informaci贸. L'esquema conceptual 茅s el coneixement general que un sistema d'informaci贸 requereix per tal de desenvolupar les seves funcions . Un esquema conceptual t茅 qualitat semantica quan 茅s va lid i complet. La valides a implica que !'esquema sigui correcte (el coneixement definit 茅s cert peral domini) i rellevant (el coneixement definit 茅s necessari peral sistema). La completes a significa que !'esquema conceptual inclou tot el coneixement rellevant. La validaci贸 de !'esquema conceptual t茅 coma objectiu la detecci贸 d'errors de requisits per tal de millorar la qualitat semantica. La validaci贸 d'esquemes conceptuals 茅s un repte cr铆tic en l'enginyeria de requisits . Aquesta te si contribueix a aquest repte i es basa en el fet que els es quemes conceptuals de sistemes d'informaci贸 poden ser especificats en artefactes executables i, per tant, poden ser provats. Les principals contribucions de la te si s贸n (1) un enfocament pera les pro ves d'esquemes conceptuals de sistemes d'informaci贸, i (2) una metodolog铆a innovadora pel desenvolupament incremental d'esquemes conceptuals assistit per una validaci贸 continuada basada en proves . Les pro ves d'esquemes conceptuals poden ser una im portant i practica t茅cnica pera la se va validaci贸, jaque permeten provar la correctesa i la completesa d'acord ambles necessitats i expectatives de les parts interessades. En conjunci贸 amb la comprovaci贸 d'un conjunt basic de criteris d'adequaci贸 de les proves, tamb茅 podem analitzar la rellevancia deis elements definits a !'esquema. L'entorn de test proposat inclou un llenguatge especialitzat per escriure proves automatitzades d'esquemes conceptuals, anomenat Conceptual Schema Testing Language (CSTL). Tamb茅 hem descrit i implementa! a un prototip de processador de tes tos que fa possible l'aplicaci贸 de l'enfocament proposat a la practica. D'acord amb l'estat de l'art en validaci贸 d'esquemes conceptuals , aquest 茅s el primer treball que proposa i implementa un entorn pel testing automatitzat d'esquemes conceptuals definits en UML!OCL. L'enfocament de proves d'esquemes conceptuals permet dura terme la validaci贸 d'esquemes existents , pero tamb茅 t茅 sentit provar es quemes conceptuals incomplets m entre estant sent desenvolupats. Aquest fet 茅s la base de la metodolog铆a Test-Driven Conceptual Modeling (TDCM), que 茅s la segona contribuci贸 principal. El TDCM 茅s una metodolog铆a de modelitzaci贸 conceptual basada en principis basics del Test-Driven Development (TDD), un m茅tode de programaci贸 en el qual un sistema software 茅s desenvolupat en petites iteracions guiades per proves. Tamb茅 hem aplicat el m茅tode en diversos casos d'estudi en el context de la metodolog铆a de recerca Design Science Research. Finalment, hem proposat enfocaments d'integraci贸 del TDCM en diverses metodologies de desenvolupament de software
    corecore