The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use Test::Spec;
use Test::Fatal;

use lib 't/lib';

use TestDBH;
use TestEnv;
use ObjectDB::Table;
use Person;

describe 'table delete' => sub {

    before each => sub {
        TestEnv->prepare_table('person');
    };

    it 'delete_objects ' => sub {
        Person->new(name => ' vti ')->create;

        my $table = _build_table();
        $table->delete;

        is($table->count, 0);
    };

    it 'delete_objects_with_query' => sub {
        Person->new(name => 'vti')->create;
        Person->new(name => 'foo')->create;

        my $table = _build_table();
        $table->delete(where => [name => 'foo']);

        is($table->count, 1);
    };

    it 'return_number_of_deleted_rows' => sub {
        Person->new(name => 'vti')->create;
        Person->new(name => 'foo')->create;

        my $table = _build_table();
        is $table->delete, 2;
    };

};

sub _build_table {
    ObjectDB::Table->new(class => 'Person', dbh => TestDBH->dbh, @_);
}

runtests unless caller;