X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=t%2Fzero.t;h=ee51f2b9b4e4f2127ede1198063cfa287c139def;hb=34ac983862368c022af1ffe37fe80de1abdec2a8;hp=8e6426b978648577ad1c0bb62ff62ee895a211bf;hpb=8f87af0520c5dbcedbfe74dd6ef6e7826f200263;p=term-progressbar.git diff --git a/t/zero.t b/t/zero.t index 8e6426b..ee51f2b 100644 --- a/t/zero.t +++ b/t/zero.t @@ -1,6 +1,7 @@ # (X)Emacs mode: -*- cperl -*- use strict; +use warnings; =head1 Unit Test Package for Term::ProgressBar @@ -8,14 +9,10 @@ This package tests the zero-progress handling of progress bar. =cut -use Data::Dumper qw( Dumper ); -use FindBin qw( $Bin ); use Test::More tests => 9; +use Test::Exception; -use Capture::Tiny qw(capture); - -use lib $Bin; -use test qw( evcheck ); +use Capture::Tiny qw(capture_stderr); use_ok 'Term::ProgressBar'; @@ -37,18 +34,14 @@ Update it it from 1 to 10. { my $p; - my $name; -my ($out, $err) = capture { - $name = 'doing nothing'; - ok (evcheck(sub { $p = Term::ProgressBar->new($name, 0); }, - 'V1 mode ( 1)' ), - 'V1 mode ( 1)'); - ok (evcheck(sub { $p->update($_) for 1..10 },'V1 mode ( 2)'), - 'V1 mode ( 2)'); -}; -print $out; - my @lines = grep $_ ne '', split /\r/, $err; - print Dumper \@lines + my $name = 'doing nothing'; + my $err = capture_stderr { + lives_ok { $p = Term::ProgressBar->new($name, 0); } 'V1 mode ( 1)'; + lives_ok { $p->update($_) for 1..10 } 'V1 mode ( 2)'; + }; + + my @lines = grep { $_ ne ''} split /\r/, $err; + diag explain @lines if $ENV{TEST_DEBUG}; like $lines[-1], qr/^$name:/, 'V1 mode ( 3)'; like $lines[-1], qr/\(nothing to do\)/, 'V1 mode ( 4)'; @@ -71,20 +64,16 @@ Update it it from 1 to 10. { my $p; my $name = 'zero'; -my ($out, $err) = capture { - ok (evcheck(sub { $p = Term::ProgressBar->new({ count => 0, - name => $name }); }, - 'V2 mode ( 1)' ), - 'V2 mode ( 1)'); - ok (evcheck(sub { $p->update($_) for 1..10 },'V2 mode ( 2)'), - 'V2 mode ( 2)'); -}; -print $out; - my @lines = grep $_ ne '', split /\r/, $err; - print Dumper \@lines + my $err = capture_stderr { + lives_ok { $p = Term::ProgressBar->new({ count => 0, name => $name }); } 'V2 mode ( 1)'; + lives_ok { $p->update($_) for 1..10 } 'V2 mode ( 2)'; + }; + + my @lines = grep {$_ ne ''} split /\r/, $err; + diag explain @lines if $ENV{TEST_DEBUG}; - like $lines[-1], qr/^$name:/, 'V2 mode ( 3)'; - like $lines[-1], qr/\(nothing to do\)/, 'V2 mode ( 4)'; + like $lines[-1], qr/^$name:/, 'V2 mode ( 3)'; + like $lines[-1], qr/\(nothing to do\)/, 'V2 mode ( 4)'; } # ----------------------------------------------------------------------------