⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 test.pm

📁 视频监控网络部分的协议ddns,的模块的实现代码,请大家大胆指正.
💻 PM
字号:
package TAP::Parser::Result::Test;use strict;use vars qw($VERSION @ISA);use TAP::Parser::Result;@ISA = 'TAP::Parser::Result';use vars qw($VERSION);=head1 NAMETAP::Parser::Result::Test - Test result token.=head1 VERSIONVersion 3.07=cut$VERSION = '3.07';=head1 DESCRIPTIONThis is a subclass of L<TAP::Parser::Result>.  A token of this class will bereturned if a test line is encountered. 1..1 ok 1 - woo hooo!=head1 OVERRIDDEN METHODSThis class is the workhorse of the L<TAP::Parser> system.  Most TAP lines willbe test lines and if C<< $result->is_test >>, then you have a bunch of methodsat your disposal.=head2 Instance Methods=cut##############################################################################=head3 C<ok>  my $ok = $result->ok;Returns the literal text of the C<ok> or C<not ok> status.=cutsub ok { shift->{ok} }##############################################################################=head3 C<number>  my $test_number = $result->number;Returns the number of the test, even if the original TAP output did not supplythat number.=cutsub number { shift->{test_num} }sub _number {    my ( $self, $number ) = @_;    $self->{test_num} = $number;}##############################################################################=head3 C<description>  my $description = $result->description;Returns the description of the test, if any.  This is the portion after thetest number but before the directive.=cutsub description { shift->{description} }##############################################################################=head3 C<directive>  my $directive = $result->directive;Returns either C<TODO> or C<SKIP> if either directive was present for a testline.=cutsub directive { shift->{directive} }##############################################################################=head3 C<explanation>  my $explanation = $result->explanation;If a test had either a C<TODO> or C<SKIP> directive, this method will returnthe accompanying explantion, if present.  not ok 17 - 'Pigs can fly' # TODO not enough acidFor the above line, the explanation is I<not enough acid>.=cutsub explanation { shift->{explanation} }##############################################################################=head3 C<is_ok>  if ( $result->is_ok ) { ... }Returns a boolean value indicating whether or not the test passed.  Rememberthat for TODO tests, the test always passes.If the test is unplanned, this method will always return false.  SeeC<is_unplanned>.=cutsub is_ok {    my $self = shift;    return if $self->is_unplanned;    # TODO directives reverse the sense of a test.    return $self->has_todo ? 1 : $self->ok !~ /not/;}##############################################################################=head3 C<is_actual_ok>  if ( $result->is_actual_ok ) { ... }Returns a boolean value indicating whether or not the test passed, regardlessof its TODO status.=cutsub is_actual_ok {    my $self = shift;    return $self->{ok} !~ /not/;}##############################################################################=head3 C<actual_passed>Deprecated.  Please use C<is_actual_ok> instead.=cutsub actual_passed {    warn 'actual_passed() is deprecated.  Please use "is_actual_ok()"';    goto &is_actual_ok;}##############################################################################=head3 C<todo_passed>  if ( $test->todo_passed ) {     # test unexpectedly succeeded  }If this is a TODO test and an 'ok' line, this method returns true.Otherwise, it will always return false (regardless of passing status onnon-todo tests).This is used to track which tests unexpectedly succeeded.=cutsub todo_passed {    my $self = shift;    return $self->has_todo && $self->is_actual_ok;}##############################################################################=head3 C<todo_failed>  # deprecated in favor of 'todo_passed'.  This method was horribly misnamed.This was a badly misnamed method.  It indicates which TODO tests unexpectedlysucceeded.  Will now issue a warning and call C<todo_passed>.=cutsub todo_failed {    warn 'todo_failed() is deprecated.  Please use "todo_passed()"';    goto &todo_passed;}##############################################################################=head3 C<has_skip>  if ( $result->has_skip ) { ... }Returns a boolean value indicating whether or not this test has a SKIPdirective.=head3 C<has_todo>  if ( $result->has_todo ) { ... }Returns a boolean value indicating whether or not this test has a TODOdirective.=head3 C<as_string>  print $result->as_string;This method prints the test as a string.  It will probably be similar, butnot necessarily identical, to the original test line.  Directives arecapitalized, some whitespace may be trimmed and a test number will be added ifit was not present in the original line.  If you need the original text of thetest line, use the C<raw> method.=cutsub as_string {    my $self   = shift;    my $string = $self->ok . " " . $self->number;    if ( my $description = $self->description ) {        $string .= " $description";    }    if ( my $directive = $self->directive ) {        my $explanation = $self->explanation;        $string .= " # $directive $explanation";    }    return $string;}##############################################################################=head3 C<is_unplanned>  if ( $test->is_unplanned ) { ... }  $test->is_unplanned(1);If a test number is greater than the number of planned tests, this method willreturn true.  Unplanned tests will I<always> return false for C<is_ok>,regardless of whether or not the test C<has_todo>.Note that if tests have a trailing plan, it is not possible to set thisproperty for unplanned tests as we do not know it's unplanned until the planis reached:  print <<'END';  ok 1  ok 2  1..1  END=cutsub is_unplanned {    my $self = shift;    return ( $self->{unplanned} || '' ) unless @_;    $self->{unplanned} = !!shift;    return $self;}1;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -