Testing Data Consistency of Data-Intensive Applications Using QuickCheck
Journal article, 2011

Many software systems are data-intensive and use a data management systems for data storage, such as Relational Database Management Systems (RDBMS). RDBMSs are used to store information in a structured manner, and to define several types of constraints on the data, to maintain basic consistency. The RDBMSs are mature, well tested, software products that one can trust to reliably store data and keep it consistent within the defined constraints. There are, however, scenarios in which passing the responsibility of consistency enforcement to the RDBMS is not convenient, or simply not possible. In such cases, the alternative is to have that responsibility at the business logic level of the system. Hence, from the point of view of testing data-intensive applications, one of the most relevant aspects is to ensure correctness of the business logic in terms of data consistency. In this article, we show how QuickCheck, a tool for random testing against specifications, can be used to test the business logic of an application to increase confidence on data integrity. We build an abstract model of the data containing the minimum information necessary to create meaningful test cases, while keeping its state substantially smaller than the data in the complete database. From the abstract model we automatically generate and execute test cases which check that data constraints are preserved.

Software Testing

QuickCheck

Author

Laura M. Castro

University of A Coruña

Thomas Arts

Chalmers, Computer Science and Engineering (Chalmers), Software Engineering (Chalmers)

Electronic Notes in Theoretical Computer Science

1571-0661 (ISSN)

Vol. 271 41-62

Areas of Advance

Information and Communication Technology

Subject Categories (SSIF 2011)

Software Engineering

DOI

10.1016/j.entcs.2011.02.010

More information

Latest update

8/6/2020 9