The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use t::Utils;
use Mock::Basic;
use Test::More;

my $dbh = t::Utils->setup_dbh;
my $db = Mock::Basic->new({dbh => $dbh});
$db->setup_test_db;

subtest 'delete/update rows arrayref' => sub {
    $db->insert('mock_basic',{
        id   => 1,
        name => 'perl',
    });
    $db->insert('mock_basic',{
        id   => 2,
        name => 'perl',
    });

    is +$db->count('mock_basic', 'id'), 2;

    my $update_count = $db->update('mock_basic',{name => 'oCaml'}, {id => [1, 2]});
    is $update_count, 2;

    my $deleted_count = $db->delete('mock_basic',{id => [1, 2]});
    is $deleted_count, 2;
    is +$db->count('mock_basic', 'id'), 0;

    done_testing;
};

subtest 'delete/update rows using IN operator' => sub {
    $db->insert('mock_basic',{
        id   => 1,
        name => 'perl',
    });
    $db->insert('mock_basic',{
        id   => 2,
        name => 'perl',
    });

    is +$db->count('mock_basic', 'id'), 2;

    my $update_count = $db->update('mock_basic',{name => 'oCaml'}, {id => +{ in => [1, 2]}});
    is $update_count, 2;

    my $deleted_count = $db->delete('mock_basic',{ id => { in => [1, 2] }});
    is $deleted_count, 2;
    is +$db->count('mock_basic', 'id'), 0;
    done_testing;
};

subtest 'delete/update rows using LIKE operator' => sub {
    $db->insert('mock_basic',{
        id   => 1,
        name => 'perl',
    });
    $db->insert('mock_basic',{
        id   => 2,
        name => 'perl',
    });

    is +$db->count('mock_basic', 'id'), 2;

    my $update_count = $db->update('mock_basic',{name => 'oCaml'}, {name => +{ like => 'perl'}});
    is $update_count, 2;

    my $deleted_count = $db->delete('mock_basic',{ name => { like => 'oCaml' }});
    is $deleted_count, 2;
    is +$db->count('mock_basic', 'id'), 0;
    done_testing;
};

subtest 'delete/update rows XXX' => sub {
    $db->insert('mock_basic',{
        id   => 1,
        name => 'perl',
    });

    is +$db->count('mock_basic', 'id'), 1;

    my $update_count = $db->update('mock_basic',{name => 'oCaml'}, {id => 1});
    is $update_count, 1;

    my $deleted_count = $db->delete('mock_basic',{id => 1});
    is $deleted_count, 1;
    is +$db->count('mock_basic', 'id'), 0;
    done_testing;
};

done_testing;