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;