The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;
use warnings;
use FindBin qw/$Bin/;
use Path::Class;
use SQL::DB;
use SQL::DBx::Deploy;
use Test::Database;
use Test::More;
use Test::SQL::DB;

foreach my $handle ( Test::Database->handles(qw/SQLite Pg/) ) {
    diag "Running with " . $handle->dbd;

    my $db = SQL::DB->connect( $handle->connection_info );
    $db->_clean_database();

    my $dir1  = dir($Bin)->subdir('deploy');
    my $dir2  = dir($Bin)->subdir('deploy2');
    my $file1 = $dir1->file('1.sql');
    my $file2 = $dir2->file('1.sql');
    my $ret;
    my $prev_id;

    $prev_id = $db->last_deploy_id;
    is $prev_id, 0, 'Nothing deployed yet: ' . $prev_id;

    $ret = $db->deploy_file($file1);
    is $ret, 2, 'deployed to ' . $ret;

    $prev_id = $db->last_deploy_id;
    is $prev_id, 2, 'last id check';

    $ret = $db->deploy_file($file1);
    is $ret, 2, 'still deployed to ' . $ret;

    $prev_id = $db->last_deploy_id;
    is $prev_id, 2, 'still last id check';

    $ret = $db->deploy_dir($dir1);
    is $ret, 3, 'upgraded to ' . $ret;

    $db->_clean_database();

    $prev_id = $db->last_deploy_id;
    is $prev_id, 0, 'Nothing deployed yet: ' . $prev_id;

    $ret = $db->deploy_dir($dir1);
    is $ret, 3, 'deployed to ' . $ret;

    $prev_id = $db->last_deploy_id;
    is $prev_id, 3, 'last id check';

    $ret = $db->deploy_dir($dir1);
    is $ret, 3, 'still deployed to ' . $ret;

    $prev_id = $db->last_deploy_id;
    is $prev_id, 3, 'still last id check';

    $ret = $db->deploy_dir($dir2);
    is $ret, 5, 'upgraded to ' . $ret;

    my $table_info = $db->deployed_table_info;

    isa_ok( $table_info, 'HASH' );
    is_deeply(
        [ sort keys %$table_info ],
        [qw/_deploy actors film_actors films/],
        'deployed_table_info'
    );
}

done_testing;