|
|
@@ -0,0 +1,49 @@
|
|
|
+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;
|