NAME
Test::Tiny -- Write simple tests, simply.
SYNOPSIS
use Test::Tiny tests => NUMBER;
ok(TEST [, MESSAGE]); # pass if TEST is true, and print MESSAGE
show(TEST); # pass if eval(TEST) is true, print TEST
SKIP: {
skip(MESSAGE, N);
# skip this code, including N tests
}
BAIL_OUT([MESSAGE]); # give up, printing MESSAGE.
DESCRIPTION
I thought Test::Simple was simple, but then I realized it relies on Test::Builder to implement the one function it exports. Test::Tiny does more with less:
ok(TEST [, MESSAGE])
Print "ok N - MESSAGE"
if TEST
is true, and "not ok N - MESSAGE"
otherwise. The MESSAGE
is optional.
show(EXPRESSION)
show
is like ok
, but uses eval(EXPRESSION)
as the TEST
, and uses EXPRESSION
as the MESSAGE
. This is useful when your test is self-explanatory:
ok sqrt(4) == 2, 'sqrt(4) is 2'; # redundant
show 'sqrt(4) == 2'; # non-redundant
skip(MESSAGE, NUMBER)
Skip NUMBER
tests with reason MESSAGE
:
SKIP: {
skip "message", $number;
# tests go here.
}
BAIL_OUT(REASON)
Stop testing for REASON
.
AUTHOR
Sean O'Rourke <seano@cpan.org>
.
Bug reports welcome, patches even more welcome.
Test::Tiny doesn't try to be 100% compatible with Test::Simple, but should stay clean, clear, and under 5% of Test::Simple's lines (from Simple.pm, Builder.pm, and files in @INC/Builder). Current counts are:
Test::Tiny 48 SLOC, 129 lines
Test::Simple 1345 SLOC, 3612 lines
COPYRIGHT
Copyright (C) 2010, Sean O'Rourke. This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.