1 package Test2::Event::Ok;
5 our $VERSION = '1.302169';
8 BEGIN { require Test2::Event; our @ISA = qw(Test2::Event) }
9 use Test2::Util::HashBase qw{
10 pass effective_pass name todo
16 # Do not store objects here, only true or false
17 $self->{+PASS} = $self->{+PASS} ? 1 : 0;
18 $self->{+EFFECTIVE_PASS} = $self->{+PASS} || (defined($self->{+TODO}) ? 1 : 0);
22 no warnings 'redefine';
26 $self->{+TODO} = $todo;
27 $self->{+EFFECTIVE_PASS} = defined($todo) ? 1 : $self->{+PASS};
31 sub increments_count { 1 };
33 sub causes_fail { !$_[0]->{+EFFECTIVE_PASS} }
38 my $name = $self->{+NAME} || "Nameless Assertion";
40 my $todo = $self->{+TODO};
42 $name .= " (TODO: $todo)";
44 elsif (defined $todo) {
53 return unless defined($self->{+TODO}) || ($self->{+EFFECTIVE_PASS} && !$self->{+PASS});
56 details => $self->{+TODO},
63 my $out = $self->common_facet_data;
66 no_debug => 1, # Legacy behavior
67 pass => $self->{+PASS},
68 details => $self->{+NAME},
71 if (my @exra_amnesty = $self->extra_amnesty) {
72 unshift @{$out->{amnesty}} => @exra_amnesty;
88 Test2::Event::Ok - Ok event type
92 Ok events are generated whenever you run a test that produces a result.
93 Examples are C<ok()>, and C<is()>.
97 use Test2::API qw/context/;
101 my $event = $ctx->ok($bool, $name, \@diag);
106 my $event = $ctx->send_event(
118 The original true/false value of whatever was passed into the event (but
119 reduced down to 1 or 0).
121 =item $name = $e->name
125 =item $b = $e->effective_pass
127 This is the true/false value of the test after TODO and similar modifiers are
134 The source code repository for Test2 can be found at
135 F<http://github.com/Test-More/test-more/>.
141 =item Chad Granum E<lt>exodist@cpan.orgE<gt>
149 =item Chad Granum E<lt>exodist@cpan.orgE<gt>
155 Copyright 2019 Chad Granum E<lt>exodist@cpan.orgE<gt>.
157 This program is free software; you can redistribute it and/or
158 modify it under the same terms as Perl itself.
160 See F<http://dev.perl.org/licenses/>