File Coverage

blib/lib/Test2/Workflow/Task.pm
Criterion Covered Total %
statement 74 84 88.1
branch 23 38 60.5
condition 14 35 40.0
subroutine 17 18 94.4
pod 0 5 0.0
total 128 180 71.1


line stmt bran cond sub pod time code
1             package Test2::Workflow::Task;
2 48     48   89437 use strict;
  48         60  
  48         944  
3 48     48   129 use warnings;
  48         38  
  48         838  
4              
5 48     48   145 use Test2::API();
  48         39  
  48         494  
6 48     48   150 use Test2::Event::Exception();
  48         44  
  48         686  
7              
8 48     48   141 use List::Util qw/min max/;
  48         43  
  48         2505  
9 48     48   166 use Scalar::Util qw/blessed/;
  48         46  
  48         1845  
10 48     48   157 use Carp qw/croak/;
  48         39  
  48         2000  
11             our @CARP_NOT = qw/Test2::Util::HashBase/;
12              
13 48     48   156 use base 'Test2::Workflow::BlockBase';
  48         44  
  48         16009  
14 48     48   233 use Test2::Util::HashBase qw/name flat async iso todo skip scaffold events is_root/;
  48         47  
  48         215  
15              
16             for my $attr (FLAT, ISO, ASYNC, TODO, SKIP, SCAFFOLD) {
17             my $old = __PACKAGE__->can("set_$attr");
18             my $new = sub {
19 90     90   81 my $self = shift;
        60      
20 90         126 my $out = $self->$old(@_);
21 90         234 $self->verify_scaffold;
22 90         117 return $out;
23             };
24              
25 48     48   10985 no strict 'refs';
  48         76  
  48         1166  
26 48     48   250 no warnings 'redefine';
  48         38  
  48         23949  
27             *{"set_$attr"} = $new;
28             }
29              
30             sub init {
31 1300     1300 0 4341 my $self = shift;
32              
33 1300   100     4327 $self->{+EVENTS} ||= [];
34              
35             {
36 1300         961 local $Carp::CarpLevel = $Carp::CarpLevel + 1;
  1300         1266  
37 1300         2668 $self->SUPER::init();
38             }
39              
40             $self->throw("the 'name' attribute is required")
41 1300 50       1691 unless $self->{+NAME};
42              
43             $self->throw("the 'flat' attribute cannot be combined with 'iso' or 'async'")
44 1300 50 33     2054 if $self->{+FLAT} && ($self->{+ISO} || $self->{+ASYNC});
      66        
45              
46 1300         2526 $self->set_subname($self->package . "::<$self->{+NAME}>");
47              
48 1300         3867 $self->verify_scaffold;
49             }
50              
51             sub clone {
52 419     419 0 384 my $self = shift;
53 419         2145 return bless {%$self}, blessed($self);
54             }
55              
56             sub verify_scaffold {
57 1390     1390 0 1100 my $self = shift;
58              
59 1390 100       3226 return unless $self->{+SCAFFOLD};
60              
61             croak "The 'flat' attribute must be true for scaffolding"
62 216 50 33     400 if defined($self->{+FLAT}) && !$self->{+FLAT};
63              
64 216         192 $self->{+FLAT} = 1;
65              
66 216         338 for my $attr (ISO, ASYNC, TODO, SKIP) {
67             croak "The '$attr' attribute cannot be used on scaffolding"
68 864 50       1381 if $self->{$attr};
69             }
70             }
71              
72             sub exception {
73 0     0 0 0 my $self = shift;
74 0         0 my ($err) = @_;
75              
76 0         0 my $trace = $self->trace;
77              
78 0         0 Test2::API::test2_stack->top->send(
79             Test2::Event::Exception->new(
80             trace => $trace,
81             error => $err,
82             )
83             );
84             }
85              
86             sub filter {
87 663     663 0 423 my $self = shift;
88 663         442 my ($filter) = @_;
89              
90 663 50       709 return unless $filter;
91 663 50       741 return if $self->{+IS_ROOT};
92 663 100       774 return if $self->{+SCAFFOLD};
93              
94 601 100       749 if (my $name = $filter->{name}) {
95 398         257 my $ok = 0;
96 398 50       513 unless(ref($name)) {
97 398   66     887 $ok ||= $self->{+NAME} eq $name;
98 398   66     821 $ok ||= $self->subname eq $name;
99             }
100 398 50       796 if (ref($name) eq 'Regexp') {
    50          
101 0   0     0 $ok ||= $self->{+NAME} =~ $name;
102 0   0     0 $ok ||= $self->subname =~ $name;
103             }
104             elsif ($name =~ m{^/}) {
105 0 0       0 my $pattern = eval "qr$name" or die "'$name' does not appear to be a valid pattern";
106 0   0     0 $ok ||= $self->{+NAME} =~ $pattern;
107 0   0     0 $ok ||= $self->subname =~ $pattern;
108             }
109              
110 398 100       1167 return {skip => "Does not match name filter '$name'"}
111             unless $ok;
112             }
113              
114 250 50       278 if (my $file = $filter->{file}) {
115 0 0       0 return {skip => "Does not match file filter '$file'"}
116             unless $self->file eq $file;
117             }
118              
119 250 100       317 if (my $line = $filter->{line}) {
120 203         295 my $lines = $self->lines;
121              
122 203 50 33     540 return {skip => "Does not match line filter '$line' (no lines)"}
123             unless $lines && @$lines;
124              
125 203         231 my $min = min(@$lines);
126 203         198 my $max = max(@$lines);
127              
128 203 100 100     895 return {skip => "Does not match line filter '$min <= $line <= $max'"}
129             unless $min <= $line && $max >= $line;
130             }
131              
132 78         115 return;
133             }
134              
135             1;
136              
137             __END__