QuickCheck is a random testing library designed for the purely functional programming language Haskell. Its main features include a descriptive yet embedded domain-specific testing language, a variety of test generators including a generator for functions, and a set of operations for monitoring generated inputs. QuickCheck is limited to ad-hoc testing, compared to more systematic testing methods such as full coverage testing. However, experiences showed that well-factored functions and properties make the QuickCheck approach as effective as systematic testing while maintaining its conciseness. QuickCheck and its variants are now available in dozens of programming languages.
We present a version of QuickCheck for the Fortress programming language in this paper. Fortress is an object-oriented language with extensive support for functional programming, with the strong emphasis on high-performance computing, parallelism by default, and growability of the language. While the main features of QuickCheck are straight-forward to implement, we are extending them to support unique features of Fortress and to support seamless integration to Fortress. We observed that the prevalent uses of implicit parallelism in Fortress call for testing parallel language constructs especially those using side effects. Also, because Fortress provides both subtype polymorphism and parametric polymorphism unlike Haskell, testing both polymorphic properties becomes interesting. We propose FortressCheck to test implicit parallelism and to test parametric polymorphism via reflection, by generating first-class type objects and using QuickCheck's own implication checking as a safety mechanism.
[1]
Koushik Sen,et al.
DART: directed automated random testing
,
2005,
PLDI '05.
[2]
Michael D. Ernst,et al.
Feedback-Directed Random Test Generation
,
2007,
29th International Conference on Software Engineering (ICSE'07).
[3]
Victor Luchangco,et al.
The Fortress Language Specification Version 1.0
,
2007
.
[4]
Koen Claessen,et al.
Finding race conditions in Erlang with QuickCheck and PULSE
,
2009,
ICFP.
[5]
Eric E. Allen,et al.
Growing a Syntax
,
2008
.
[6]
Koen Claessen,et al.
QuickCheck: a lightweight tool for random testing of Haskell programs
,
2000,
ICFP.
[7]
Koushik Sen,et al.
CUTE: a concolic unit testing engine for C
,
2005,
ESEC/FSE-13.
[8]
Yannis Smaragdakis,et al.
JCrasher: an automatic robustness tester for Java
,
2004,
Softw. Pract. Exp..