13-waiter.t 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. use strict;
  2. use warnings;
  3. use Selenium::Waiter;
  4. use FindBin;
  5. use lib $FindBin::Bin . '/lib';
  6. use Test::More;
  7. my $res;
  8. subtest 'basic' => sub {
  9. my @warning;
  10. local $SIG{__WARN__} = sub { push( @warning, $_[0] ) };
  11. $res = wait_until { 1 };
  12. is $res, 1, 'right return value';
  13. $res = wait_until { 0 } timeout => 1;
  14. is $res, '', 'right return value';
  15. is( scalar @warning, 0, 'no warnings' );
  16. };
  17. subtest 'exception' => sub {
  18. my @warning;
  19. local $SIG{__WARN__} = sub { push( @warning, $_[0] ) };
  20. $res = wait_until { die 'case1' } debug => 0, timeout => 1;
  21. is $res, '', 'right return value';
  22. is( scalar @warning, 1, 'right number of warnings' );
  23. like( $warning[0], qr{^case1}, 'right warning' );
  24. @warning = ();
  25. eval {
  26. $res = wait_until { die 'case2' } die => 1, timeout => 1;
  27. };
  28. like $@, qr{case2}, 'right error';
  29. is $res, '', 'right return value';
  30. is( scalar @warning, 0, 'right number of warnings' );
  31. @warning = ();
  32. $res = wait_until { 0 } debug => 1, timeout => 1;
  33. is $res, '', 'right return value';
  34. is( scalar @warning, 1, 'right number of warnings' );
  35. like( $warning[0], qr{timeout}i, 'timeout is reported' );
  36. };
  37. done_testing;