package qcheck-core
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
md5=3eba3b3b47ccfa48afd1ce7dbdd463f7
    
    
  sha512=6f4749df32629b2a64034f7a8d07079b8d3d628cc402c52bbdbd7e287ca20adf8e8133f91d79e75d8402100715a1138d62904b2d9c1d1595602d5206e0862305
    
    
  doc/qcheck-core.runner/QCheck_base_runner/index.html
Module QCheck_base_runnerSource
Runners for Tests
Once you have built tests using QCheck.Test.make or QCheck2.Test.make, you need to run them. This module contains several runners, which are designed to run every test and report the result.
By default, you can use run_tests in a test program as follows:
  let testsuite = [
    Test.make ...;
    Test.make ...;
  ]
  let () =
    let errcode = QCheck_base_runner.run_tests ~verbose:true testsuite in
    exit errcodewhich will run the tests, and exit the program. The error code will be 0 if all tests pass, 1 otherwise.
run_tests_main can be used as a shortcut for that, also featuring command-line parsing (using Arg) to activate verbose mode and others.
State
Access the current random state
Is the default mode verbose or quiet?
Is the default mode to run long tests or nor?
Change the random_state by creating a new one, initialized with the given seed.
Change the value of verbose ()
Change the value of long_tests ()
Console message printing
In verbose mode, by default QCheck_base_runner prints frequent sub-second messages suitable for an interactive console test run. This behaviour can be changed by the environment variable QCHECK_MSG_INTERVAL. Intervals are given in seconds and can also be decimal numbers. For example, setting
   QCHECK_MSG_INTERVAL=7.5will only print a console message every 7.5 seconds. This feature can be useful in a CI context, where updates are printed on consecutive lines and one may want to avoid overflowing the CI log files with too many lines.
Note: The start and finishing message for each test is printed eagerly in verbose mode regardless of the specified message interval.
Get the minimum time (in seconds) to wait between printing messages.
Set the minimum time (in seconds) between messages.
Event handlers
type counter = private {- start : float;
- expected : int;
- mutable gen : int;
- mutable passed : int;
- mutable failed : int;
- mutable errored : int;
}The type of counter used to keep tracks of the events received for a given test cell.
A type to represent polymorphic-enough handlers for test cells.
type handler_gen =
  colors:bool ->
  debug_shrink:out_channel option ->
  debug_shrink_list:string list ->
  size:int ->
  out:out_channel ->
  verbose:bool ->
  counter ->
  handlerAn alias type to a generator of handlers for test cells.
The default handler used.
val debug_shrinking_choices : 
  colors:bool ->
  out:out_channel ->
  name:string ->
  'a QCheck2.Test.cell ->
  step:int ->
  'a ->
  unitThe function used by the default handler to debug shrinking choices. This can be useful to outside users trying to reproduce some of the base-runner behavior.
Run a Suite of Tests and Get Results
val run_tests : 
  ?handler:handler_gen ->
  ?colors:bool ->
  ?verbose:bool ->
  ?long:bool ->
  ?debug_shrink:out_channel option ->
  ?debug_shrink_list:string list ->
  ?out:out_channel ->
  ?rand:Random.State.t ->
  QCheck2.Test.t list ->
  intRun a suite of tests, and print its results. This is an heritage from the "qcheck" library.
Can be used as the main function of a test file. Exits with a non-0 code if the tests fail. It refers to run_tests for actually running tests after CLI options have been parsed.
The available options are:
- "--verbose" (or "-v") for activating verbose tests
- "--seed <n>" (or "-s <n>") for repeating a previous run by setting the random seed
- "--long" for running the long versions of the tests
Below is an example of the output of the run_tests and run_tests_main function:
random seed: 438308050 generated error; fail; pass / total - time -- test name [✓] (1000) 0 ; 0 ; 1000 / 1000 -- 0.5s -- list_rev_is_involutive [✗] ( 1) 0 ; 1 ; 0 / 10 -- 0.0s -- should_fail_sort_id [✗] ( 1) 1 ; 0 ; 0 / 10 -- 0.0s -- should_error_raise_exn [✓] (1000) 0 ; 0 ; 1000 / 1000 -- 0.0s -- collect_results --- Failure -------------------------------------------------------------------- Test should_fail_sort_id failed (11 shrink steps): [1; 0] === Error ====================================================================== Test should_error_raise_exn errored on (62 shrink steps): 0 exception QCheck_runner_test.Error Raised at file "example/QCheck_runner_test.ml", line 20, characters 20-25 Called from file "src/QCheck.ml", line 839, characters 13-33 +++ Collect ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Collect results for test collect_results: 4: 207 cases (20.7%) 3: 190 cases (19.0%) 2: 219 cases (21.9%) 1: 196 cases (19.6%) 0: 188 cases (18.8%) ================================================================================ failure (1 tests failed, 1 tests errored, ran 4 tests)