On this page:
4.1 Checking documentation completeness
check-docs
4.2 Logging Test Results
test-log!
test-log
test-log-enabled?

4 Testing Utilities

4.1 Checking documentation completeness

 (require rackunit/docs-complete) package: racket-index

procedure

(check-docs lib [#:skip skip])  any

  lib : module-path?
  skip : 
(or/c regexp?
      symbol?
      (listof (or/c regexp? symbol?))
      (-> symbol? any)
      #f)
 = #f
Checks to see if the module path named by lib (e.g. 'racket/list) has documented all of its exports and prints an error message to (current-error-port) if not.

If skip is a regexp, then exporting matching that regexp are ignored. If it is a symbol, then that export is ignored. If it is a list of symbols and regexps, then any exporting matching any of the symbols or regexps are ignored. If it is a function, the function is treated as a predicate and passed each export of the module. If skip is #f, no exports are skipped.

Changed in version 1.10 of package racket-index: Changed lib to accept any module path.

4.2 Logging Test Results

 (require rackunit/log) package: testing-util-lib

Rackunit provides a general purpose library for tracking test results and displaying a summary message.

procedure

(test-log! result)  void?

  result : any/c
Adds a test result to the running log. If result is false, then the test is considered a failure.

procedure

(test-log [#:display? display? 
  #:exit? exit?]) 
  
(cons/c exact-nonnegative-integer?
        exact-nonnegative-integer?)
  display? : any/c = #f
  exit? : any/c = #f
Processes the running test log. The first integer is the failed tests, the second is the total tests. If display? is true, then a message is displayed. If there were failures, the message is printed on (current-error-port). If exit? is true, then if there were failures, calls (exit 1).

Changed in version 1.11 of package testing-util-lib: Allow any value for the display? and exit? arguments, not just booleans.

parameter

(test-log-enabled?)  boolean?

(test-log-enabled? enabled?)  void?
  enabled? : any/c
 = #t
When set to #f, test-log! is a no-op. This is useful to dynamically disable certain tests whose failures are expected and shouldn’t be counted in the test log, such as when testing a custom check’s failure behavior.

Added in version 1.1 of package testing-util-lib.
Changed in version 1.11: Allow any value for the parameter and coerce it to a boolean.