12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- use strict;
- use warnings;
- use Selenium::Waiter;
- use FindBin;
- use lib $FindBin::Bin . '/lib';
- use Test::More;
- my $res;
- subtest 'basic' => sub {
- my @warning;
- local $SIG{__WARN__} = sub { push( @warning, $_[0] ) };
- $res = wait_until { 1 };
- is $res, 1, 'right return value';
- $res = wait_until { 0 } timeout => 1;
- is $res, '', 'right return value';
- is( scalar @warning, 0, 'no warnings' );
- };
- subtest 'exception' => sub {
- my @warning;
- local $SIG{__WARN__} = sub { push( @warning, $_[0] ) };
- $res = wait_until { die 'case1' } debug => 0, timeout => 1;
- is $res, '', 'right return value';
- is( scalar @warning, 1, 'right number of warnings' );
- like( $warning[0], qr{^case1}, 'right warning' );
- @warning = ();
- eval {
- $res = wait_until { die 'case2' } die => 1, timeout => 1;
- };
- like $@, qr{case2}, 'right error';
- is $res, '', 'right return value';
- is( scalar @warning, 0, 'right number of warnings' );
- @warning = ();
- $res = wait_until { 0 } debug => 1, timeout => 1;
- is $res, '', 'right return value';
- is( scalar @warning, 1, 'right number of warnings' );
- like( $warning[0], qr{timeout}i, 'timeout is reported' );
- };
- done_testing;
|