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

BEGIN {
	eval "use DBD::SQLite";
	plan $@ ? (skip_all => 'needs DBD::SQLite for testing') : (tests => 42);
}

INIT {
	use lib 't/testlib';
	use Film;
	use NewFilm;
	Film->CONSTRUCT;
	NewFilm->CONSTRUCT;
}

Film->retrieve_all->delete_all;
NewFilm->retrieve_all->delete_all;

my @film  = (
	Film->create({ Title => 'Film 1' }),
	Film->create({ Title => 'Film 2' }),
	Film->create({ Title => 'Film 3' }),
	Film->create({ Title => 'Film 4' }),
	Film->create({ Title => 'Film 5' }),
	Film->create({ Title => 'Film 6' }),
);
my @newfilm  = (
	NewFilm->create({ Title => 'Film 1' }),
	NewFilm->create({ Title => 'Film 2' }),
	NewFilm->create({ Title => 'Film 3' }),
	NewFilm->create({ Title => 'Film 4' }),
	NewFilm->create({ Title => 'Film 5' }),
	NewFilm->create({ Title => 'Film 6' }),
);

{
	my $it1 = NewFilm->retrieve_all;
	isa_ok $it1, "Class::DBI::Plugin::Iterator";

	my $it2 = NewFilm->retrieve_all;
	isa_ok $it2, "Class::DBI::Plugin::Iterator";

	while (my $from1 = $it1->next) {
		my $from2 = $it2->next;
		is $from1->id, $from2->id, "Both iterators get $from1";
	}
}

{
	my $it1 = Film->retrieve_all;
	isa_ok $it1, "Class::DBI::Iterator";

	my $it2 = NewFilm->retrieve_all;
	isa_ok $it2, "Class::DBI::Plugin::Iterator";

	while (my $from1 = $it1->next) {
		my $from2 = $it2->next;
		is $from1->id, $from2->id, "Both iterators get $from1";
	}
}

{
	my $it = NewFilm->retrieve_all;
	is $it->first->title, "Film 1", "Film 1 first";
	is $it->next->title, "Film 2", "Film 2 next";
	is $it->first->title, "Film 1", "First goes back to 1";
	is $it->next->title, "Film 2", "With 2 still next";
	$it->reset;
	is $it->next->title, "Film 1", "Reset brings us to film 1 again";
	is $it->next->title, "Film 2", "And 2 is still next";
}


{
	my $it = NewFilm->retrieve_all;
	my @slice = $it->slice(2,4);
	is @slice, 3, "correct slice size (array)";
	is $slice[0]->title, "Film 3", "Film 3 first";
	is $slice[2]->title, "Film 5", "Film 5 last";
}

{
	my $it = NewFilm->retrieve_all;
	my $slice = $it->slice(2,4);
	isa_ok $slice, "Class::DBI::Iterator", "slice as iterator";
	is $slice->count, 3,"correct slice size (array)";
	is $slice->first->title, "Film 3", "Film 3 first";
	is $slice->next->title, "Film 4", "Film 4 next";
	is $slice->first->title, "Film 3", "First goes back to 3";
	is $slice->next->title, "Film 4", "With 4 still next";
	$slice->reset;
	is $slice->next->title, "Film 3", "Reset brings us to film 3 again";
	is $slice->next->title, "Film 4", "And 4 is still next";

	# check if the original iterator still works
	is $it->count, 6, "back to the original iterator, is of right size";
	is $it->first->title, "Film 1", "Film 1 first";
	is $it->next->title, "Film 2", "Film 2 next";
	is $it->first->title, "Film 1", "First goes back to 1";
	is $it->next->title, "Film 2", "With 2 still next";
	is $it->next->title, "Film 3", "Film 3 is still in original Iterator";
	$it->reset;
	is $it->next->title, "Film 1", "Reset brings us to film 1 again";
	is $it->next->title, "Film 2", "And 2 is still next";
}

{
	my $it = NewFilm->search( Title => 'no match' );
	is $it->count, 0, "correct slice size (array)";
}