package pfff
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
md5=818ceb6724ebcff9f179bcd6aa566bbb
    
    
  sha512=e64da49c06fbc341ca01fbee4e541d9ab90aa374c1d08152207f9cc130afd779f3e538a7dcc183dd6e2919e235a324acd89583e47c4725c02a5de57e5abec326
    
    
  doc/commons/OUnit/index.html
Module OUnit
The OUnit library can be used to implement unittests
To uses this library link with ocamlc oUnit.cmo or ocamlopt oUnit.cmx
Assertions
Assertions are the basic building blocks of unittests.
Signals a failure. This will raise an exception with the specified string.
Signals a failure when bool is false. The string identifies the failure.
Signals a failure when the string is non-empty. The string identifies the failure.
val assert_equal : 
  ?cmp:('a -> 'a -> bool) ->
  ?printer:('a -> string) ->
  ?msg:string ->
  'a ->
  'a ->
  unitCompares two values, when they are not equal a failure is signaled. The cmp parameter can be used to pass a different compare function. This parameter defaults to ( = ). The optional printer can be used to convert the value to string, so a nice error message can be formatted. When msg is also set it can be used to identify the failure.
Asserts if the expected exception was raised. When msg is set it can be used to identify the failure
Skipping tests
In certain condition test can be written but there is no point running it, because they are not significant (missing OS features for example). In this case this is not a failure nor a success. Following function allow you to escape test, just as assertion but without the same error status.
A test skipped is counted as success. A test todo is counted as failure.
skip cond msg If cond is true, skip the test for the reason explain in msg. * For example skip_if (Sys.os_type = "Win32") "Test a doesn't run on windows".
Compare Functions
Compare floats up to a given relative error.
Bracket
A bracket is a functional implementation of the commonly used setUp and tearDown feature in unittests. It can be used like this:
"MyTestCase" >:: (bracket test_set_up test_fun test_tear_down)
Constructing Tests
The type of tests
Some shorthands which allows easy test construction.
Examples:
- "test1" >: TestCase((fun _ -> ()))=>- TestLabel("test2", TestCase((fun _ -> ())))
- "test2" >:: (fun _ -> ())=>- TestLabel("test2", TestCase((fun _ -> ())))
- "test-suite" >::: ["test2" >:: (fun _ -> ());]=>- TestLabel("test-suite", TestSuite([TestLabel("test2", TestCase((fun _ -> ())))]))
test_decorate g tst Apply g to test function contains in tst tree.
test_filter paths tst Filter test based on their path string representation.
Retrieve Information from Tests
val test_case_count : test -> intReturns the number of available test cases
type path = node listThe path to the test (in reverse order).
val string_of_node : node -> stringMake a string from a node
val string_of_path : path -> stringMake a string from a path. The path will be reversed before it is tranlated into a string
Performing Tests
Events which occur during a test run
val perform_test : (test_event -> 'a) -> test -> test_result listPerform the test, allows you to build your own test runner
val run_test_tt : ?verbose:bool -> test -> test_result listA simple text based test runner. It prints out information during the test.
val run_test_tt_main : test -> test_result listMain version of the text based test runner. It reads the supplied command line arguments to set the verbose level and limit the number of test to run