The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#!/usr/bin/perl

use strict;
use warnings;

use Test::More;

our $schema;

BEGIN {
    plan skip_all => $@ unless eval {
        require DBIx::Class;
        require DBI;
        require DBD::SQLite;
        require Test::TempDir;
        Test::TempDir->import('temp_root');
        1;
    }
}

BEGIN {
    plan skip_all => $@ unless eval {
        {
            package Schema::Foo;
            use base qw(DBIx::Class);

            __PACKAGE__->load_components(qw(Core));

            __PACKAGE__->table("foo");

            __PACKAGE__->add_columns(qw(id name));

            __PACKAGE__->set_primary_key("id");

            package Schema;
            use base qw(DBIx::Class::Schema);

            __PACKAGE__->load_classes(qw(Foo));

            1;
        }

        my $file = temp_root()->file("db");
        $schema = Schema->connect("dbi:SQLite:dbname=$file", undef, undef, { RaiseError => 1 } );
        $schema->storage->dbh->do("create table foo ( id integer primary key, name varchar )");
    };

    plan 'no_plan';
}

use ok 'Data::Stream::Bulk::DBIC';

{
    my $d = Data::Stream::Bulk::DBIC->new( resultset => $schema->resultset("Foo") );

    ok( !$d->is_done, "not done" );

    is_deeply( [ $d->items ], [], "no items" );

    ok( $d->is_done, "now done" );
}

{
    $schema->resultset("Foo")->populate([
        { name => "hello" },
        { name => "goodbye" },
    ]);

    my $d = Data::Stream::Bulk::DBIC->new( resultset => $schema->resultset("Foo") );

    ok( !$d->is_done, "not done" );
    is_deeply( [ map { $_->name } $d->items ], [ "hello" ], "one item" );
    ok( !$d->is_done, "not done" );
    is_deeply( [ map { $_->name } $d->items ], [ "goodbye" ], "one item" );
    ok( !$d->is_done, "not done" );
    is_deeply( [ $d->items ], [], "no items" );

    ok( $d->is_done, "now done" );
}