Squashed an extraneous warning in 82cascade_copy.t and fixed up 26dumper.t
[dbsrgits/DBIx-Class.git] / t / 67pager.t
CommitLineData
70350518 1use strict;
2use warnings;
3
4use Test::More;
5use lib qw(t/lib);
6use DBICTest;
7
8my $schema = DBICTest::init_schema();
0567538f 9
10plan tests => 12;
11
12# first page
f9db5527 13my $it = $schema->resultset("CD")->search(
0567538f 14 {},
15 { order_by => 'title',
16 rows => 3,
17 page => 1 }
18);
19
20is( $it->pager->entries_on_this_page, 3, "entries_on_this_page ok" );
21
22is( $it->pager->next_page, 2, "next_page ok" );
23
24is( $it->count, 3, "count on paged rs ok" );
25
26is( $it->next->title, "Caterwaulin' Blues", "iterator->next ok" );
27
28$it->next;
29$it->next;
30
31is( $it->next, undef, "next past end of page ok" );
32
33# second page, testing with array
f9db5527 34my @page2 = $schema->resultset("CD")->search(
0567538f 35 {},
36 { order_by => 'title',
37 rows => 3,
38 page => 2 }
39);
40
41is( $page2[0]->title, "Generic Manufactured Singles", "second page first title ok" );
42
43# page a standard resultset
f9db5527 44$it = $schema->resultset("CD")->search(
0567538f 45 {},
46 { order_by => 'title',
47 rows => 3 }
48);
49my $page = $it->page(2);
50
51is( $page->count, 2, "standard resultset paged rs count ok" );
52
53is( $page->next->title, "Generic Manufactured Singles", "second page of standard resultset ok" );
54
55# test software-based limit paging
f9db5527 56$it = $schema->resultset("CD")->search(
0567538f 57 {},
58 { order_by => 'title',
59 rows => 3,
60 page => 2,
61 software_limit => 1 }
62);
63is( $it->pager->entries_on_this_page, 2, "software entries_on_this_page ok" );
64
65is( $it->pager->previous_page, 1, "software previous_page ok" );
66
67is( $it->count, 2, "software count on paged rs ok" );
68
69is( $it->next->title, "Generic Manufactured Singles", "software iterator->next ok" );
70