ref: be27d7ef34e73a0289e786456c8aa60aec55e646
dir: /doc/api/libtestr/index.txt/
{
title: libtestr
description: Myrddin Test Library
}
Libtestr
---------
pkg testr =
type ctx
type spec = struct
name : byte[:]
fn : (ctx : ctx# -> void)
;;
const run : (specs : spec[:] -> void)
const ok : (ctx : ctx# -> void)
const fail : (ctx : ctx#, msg : byte[:] -> void)
;;
Overview
--------
The testr library provides a simple library for running
unit tests. It outputs subtest results in a format that mbld
will be able to understand, log, and report on.
Types
-----
type ctx
The context for the current test. Used to record the state
of the set of tests currently running.
type spec = struct
name : byte[:]
fn : (ctx : ctx# -> void)
;;
The specification for a single test. Contains the name
of the test being run, and the code used to execute it.
Mutex.
Functions: Mutexes
------------------
const run : (specs : spec[:] -> void)
Runs a sequence of tests, recording the state of the test
and outputting an appropriate log for mtest to consume.
const ok : (ctx : ctx# -> void)
Records a test success. It does not leave the current
scope.
const fail : (ctx : ctx#, msg : byte[:] -> void)
Records a test failure. It does not leave the current
scope.