NAME
Method::Workflow::SPEC - RSPEC keywords + workflow
DESCRIPTION
This module is an implementation of RSPEC on top of Method::Workflow. This provides the basic keywords to create an RSPEC workflow.
EARLY VERSION WARNING
This is an early version, better tests are needed. Most documented features should work fine though.
SYNOPSYS
From the acceptance test:
#!/usr/bin/perl
use strict;
use warnings;
use Test::More;
use Method::Workflow::SPEC;
#################
# Define the workflow
start_class_workflow;
our @RUN_ORDER;
describe aa {
push @RUN_ORDER => "Describe";
before_all cc { push @RUN_ORDER => "Before All" }
before_each bb { push @RUN_ORDER => "Before Each" }
it dd {
push @RUN_ORDER => "It";
}
after_each ff { push @RUN_ORDER => "After Each" }
after_all ee { push @RUN_ORDER => "After All" }
describe aa {
push @RUN_ORDER => "Describe Nested";
before_all cc { push @RUN_ORDER => "Before All Nested" }
before_each bb { push @RUN_ORDER => "Before Each Nested" }
it dd {
push @RUN_ORDER => "It Nested";
}
after_each ff { push @RUN_ORDER => "After Each Nested" }
after_all ee { push @RUN_ORDER => "After All Nested" }
}
}
end_class_workflow;
##################
# Run the workflow
run_workflow;
##################
# Verify the results
is_deeply(
\@RUN_ORDER,
[
# Generators
"Describe",
"Describe Nested",
# Root before all
"Before All",
# It and each
"Before Each",
"It",
"After Each",
# Nested
"Before All Nested",
"Before Each",
"Before Each Nested",
"It Nested",
"After Each Nested",
"After Each",
"After All Nested",
# Root after all
"After All",
],
"Order is correct"
);
done_testing;
KEYWORDS
All keywords take a name and codeblock. Name is not currently optional, this may change.
- describe NAME { ... }
-
Create a root SPEC workflow element. These are run first to generate the tasks that will be run. These may be nested.
- it NAME { ... }
-
Create a task node, these are the blocks that should produce results or accomplish work. These may not be nested, but there can be multiple within the same describe block.
- before_each NAME { ... }
-
Create a setup block that should be run once for each 'it' block prior to the run of that 'it' block.
- after_each NAME { ... }
-
Create a setup block that should be run once before any 'it' block is run.
- before_all NAME { ... }
-
Create a teardown block that should be run once for each 'it' block after the run of that 'it' block.
- after_all NAME { ... }
-
Create a teardown block that should be run once before any 'it' block is run.
USE IN TESTING
Works as expected, use Test::More. Checks can be placed in any block.
ENCAPSULATING ERRORS
Use the 'error_handler' keyword (see Method::Workflow::Base the exports section) to create a handler that lets your tests continue if an exception is thrown from any block.
#!/usr/bin/perl
use strict;
use warnings;
use Test::More;
use Method::Workflow::SPEC;
start_class_workflow;
my @errors;
error_handler( sub { @errors = @_ });
describe aa { it xxx { die "Error!" }}
describe bb { ok( 1, "I still run!" )}
end_class_workflow;
run_workflow;
my ( $item, $root, $error ) = @errors;
like( $error, qr/Error! at/, "Workflow element error caught" );
done_testing;
ORDERING TESTS
You can specify an order at the class level and/or the block level. The ordering will carry-down to nested elements until a new order is specified.
There are 3 orderng options:
- ordered
-
The default, run in the order they were defined.
- sorted
-
Sorts tasks by name, task name will be the name of the 'it' block unless tests are grouped togethr by at some level by a before/after all, or ordering change. When grouped the group will be a single task named after the describe block that defined the grouping.
- random
-
Shuffles the items for a random run order.
CLASS LEVEL
Specify the ordering at use time:
use Method::Workflow::SPEC ':random';
use Method::Workflow::SPEC ':ordered';
use Method::Workflow::SPEC ':sorted';
ELEMENT LEVEL
Specify in the parameters list '( ... )':
describe random_describe ( random => 1 ) { ... }
describe sorted_describe ( sorted => 1 ) { ... }
describe ordered_describe ( ordered => 1 ) { ... }
FENNEC PROJECT
This module is part of the Fennec project. See Fennec for more details. Fennec is a project to develop an extendable and powerful testing framework. Together the tools that make up the Fennec framework provide a potent testing environment.
The tools provided by Fennec are also useful on their own. Sometimes a tool created for Fennec is useful outside the greator framework. Such tools are turned into their own projects. This is one such project.
- Fennec - The core framework
-
The primary Fennec project that ties them all together.
AUTHORS
Chad Granum exodist7@gmail.com
COPYRIGHT
Copyright (C) 2010 Chad Granum
Method-Workflow-SPEC is free software; Standard perl licence.
Method-Workflow-SPEC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the license for more details.