Shrinking and showing functions (Functional pearl)
Paper in proceeding, 2012

Although quantification over functions in QuickCheck properties has been supported from the beginning, displaying and shrinking them as counter examples has not. The reason is that in general, functions are infinite objects, which means that there is no sensible show function for them, and shrinking an infinite object within a finite number of steps seems impossible. This paper presents a general technique with which functions as counter examples can be shrunk to finite objects, which can then be displayed to the user. The approach turns out to be practically usable, which is shown by a number of examples. The two main limitations are that higher-order functions cannot be dealt with, and it is hard to deal with terms that contain functions as subterms.

quickcheck

testing

counter example

Author

Koen Lindström Claessen

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

SIGPLAN Notices (ACM Special Interest Group on Programming Languages)

07308566 (ISSN)

Vol. 47 12 73-80
978-145031574-6 (ISBN)

Subject Categories (SSIF 2011)

Computer and Information Science

DOI

10.1145/2430532.2364516

ISBN

978-145031574-6

More information

Created

10/8/2017