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 find with paging' => sub {

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

    it 'get_page' => sub {
        Person->new(name => $_)->create for 1 .. 20;

        my $table = _build_table();

        my @persons = $table->find(page => 1);
        is(@persons, 10);
    };

    it 'get_page_with_correct_results' => sub {
        Person->new(name => $_)->create for 1 .. 20;

        my $table = _build_table();

        my @persons = $table->find(page => 2);
        is($persons[0]->get_column('name'),  11);
        is($persons[-1]->get_column('name'), 20);
    };

    it 'default_to_the_first_page_on_invalid_data' => sub {
        Person->new(name => $_)->create for 1 .. 20;

        my $table = _build_table();

        my @persons = $table->find(page => 'abc');
        is($persons[0]->get_column('name'),  1);
        is($persons[-1]->get_column('name'), 10);
    };

};

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

runtests unless caller;