Test::Block(3pm) | User Contributed Perl Documentation | Test::Block(3pm) |
Test::Block - DEPRECIATED: Specify fine granularity test plans
use Test::More 'no_plan'; use Test::Block qw($Plan); { # This block should run exactly two tests local $Plan = 2; pass 'first test'; # oops. forgot second test }; SKIP: { local $Plan = 3; pass('first test in second block'); skip "skip remaining tests" => $Plan; }; ok( Test::Block->all_in_block, 'all test run in blocks' ); is( Test::Block->block_count, 2, 'two blocks ran' ); # This produces... ok 1 - first test not ok 2 - block expected 2 test(s) and ran 1 # Failed test (foo.pl at line 6) ok 3 - first test in second block ok 4 # skip skip remaining tests ok 5 # skip skip remaining tests ok 6 - all test run in blocks ok 7 - two blocks ran 1..7 # Looks like you failed 1 tests of 7.
NOTE: This module was written before subtests existed in TAP and Test::More. These days subtests will probably be a better option for you.
This module allows you to specify the number of expected tests at a finer level of granularity than an entire test script. It is built with Test::Builder and plays happily with Test::More and friends.
If you are not already familiar with Test::More now would be the time to go take a look.
Test::Block supplies a special variable $Plan that you can localize to specify the number of tests in a block like this:
use Test::More 'no_plan'; use Test::Block qw($Plan); { local $Plan = 2; pass('first test'); pass('second test'); };
If a block doesn't run the number of tests specified in $Plan then Test::Block will automatically produce a failing test. For example:
{ local $Plan = 2; pass('first test'); # oops - forgot second test };
will output
ok 1 - first test not ok 2 - block 1 expected 2 test(s) and ran 1
During the execution of a block $Plan will contain the number of remaining tests that are expected to run so:
{ local $Plan = 2; diag "$Plan tests to run"; pass('first test'); diag "$Plan tests to run"; pass('second test'); diag "$Plan tests to run"; };
will produce
# 2 tests to run ok 1 - first test # 1 tests to run ok 2 - second test # 0 tests to run
This can make skip blocks easier to write and maintain, for example:
SKIP: { local $Plan = 5; pass('first test'); pass('second test'); skip "debug tests" => $Plan unless DEBUG > 0; pass('third test'); pass('fourth test'); skip "high level debug tests" => $Plan unless DEBUG > 2; pass('fifth test'); };
To make debugging easier you can give your blocks an optional name like this:
{ local $Plan = { example => 2 }; pass('first test'); # oops - forgot second test };
which would output
ok 1 - first test not ok 2 - block example expected 2 test(s) and ran 1
The $Plan is implemented using a tied variable that stores and retrieves Test::Block objects. If you want to avoid the tied interface you can use Test::Block objects directly.
# create a block expecting 4 tests my $block = Test::Block->plan(4); # create a named block with two tests my $block = Test::Block->plan('test name' => 2);
You create Test::Block objects with the "plan" method. When the object is destroyed it outputs a failing test if the expected number of tests have not run.
Test::Block objects overload "" and "0+" to return the result of the remaining method.
Test::Block->builder->skip('skip a test');
See Test::Builder for more information.
is( Test::Block->block_count, 5, 'five blocks run' );
at the end of your test script.
ok( Test::Block->all_in_block, 'all tests run in blocks' );
None known at the time of writing.
If you find any please let me know by e-mail, or report the problem with <http://rt.cpan.org/>.
If you think this module should do something that it doesn't (or does something that it shouldn't) please let me know.
You can see my current to do list at <http://adrianh.tadalist.com/lists/public/15423>, with an RSS feed of changes at <http://adrianh.tadalist.com/lists/feed_public/15423>.
Thanks to chromatic and Michael G Schwern for the excellent Test::Builder, without which this module wouldn't be possible.
Thanks to Michael G Schwern and Tony Bowden for the mails on perl-qa@perl.org that sparked the idea for this module. Thanks to Fergal Daly for suggesting named blocks. Thanks to Michael G Schwern for suggesting $Plan. Thanks to Nadim Khemir for feedback and Andreas Koenig for spotting bugs.
Adrian Howard <adrianh@quietstars.com>
If you can spare the time, please drop me a line if you find this module useful.
Copyright 2003-2006 Adrian Howard, All Rights Reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
2016-05-29 | perl v5.22.2 |