Protect DBIC as best we can from the failure mode in 7cb35852
[dbsrgits/DBIx-Class.git] / t / 61findnot.t
1 use strict;
2 use warnings;
3
4 use Test::More;
5 use Test::Warn;
6 use Test::Exception;
7 use lib qw(t/lib);
8 use DBICTest;
9
10 my $schema = DBICTest->init_schema();
11
12 my $art = $schema->resultset("Artist")->find(4);
13 ok(!defined($art), 'Find on primary id: artist not found');
14 my @cd = $schema->resultset("CD")->find(6);
15 cmp_ok(@cd, '==', 1, 'Return something even in array context');
16 ok(@cd && !defined($cd[0]), 'Array contains an undef as only element');
17
18 $art = $schema->resultset("Artist")->find({artistid => '4'});
19 ok(!defined($art), 'Find on unique constraint: artist not found');
20 @cd = $schema->resultset("CD")->find({artist => '2', title => 'Lada-Di Lada-Da'});
21 cmp_ok(@cd, '==', 1, 'Return something even in array context');
22 ok(@cd && !defined($cd[0]), 'Array contains an undef as only element');
23
24 $art = $schema->resultset("Artist")->search({name => 'The Jesus And Mary Chain'});
25 isa_ok($art, 'DBIx::Class::ResultSet', 'get a DBIx::Class::ResultSet object');
26 my $next = $art->next;
27 ok(!defined($next), 'Nothing next in ResultSet');
28 my $cd = $schema->resultset("CD")->search({title => 'Rubbersoul'});
29 @cd = $cd->next;
30 cmp_ok(@cd, '==', 1, 'Return something even in array context');
31 ok(@cd && !defined($cd[0]), 'Array contains an undef as only element');
32
33 $art = $schema->resultset("Artist")->single({name => 'Bikini Bottom Boys'});
34 ok(!defined($art), 'Find on primary id: artist not found');
35 @cd = $schema->resultset("CD")->single({title => 'The Singles 1962-2006'});
36 cmp_ok(@cd, '==', 1, 'Return something even in array context');
37 ok(@cd && !defined($cd[0]), 'Array contains an undef as only element');
38
39 $art = $schema->resultset("Artist")->search({name => 'Random Girl Band'});
40 isa_ok($art, 'DBIx::Class::ResultSet', 'get a DBIx::Class::ResultSet object');
41 $next = $art->single;
42 ok(!defined($next), 'Nothing next in ResultSet');
43 $cd = $schema->resultset("CD")->search({title => 'Call of the West'});
44 @cd = $cd->single;
45 cmp_ok(@cd, '==', 1, 'Return something even in array context');
46 ok(@cd && !defined($cd[0]), 'Array contains an undef as only element');
47
48 $cd = $schema->resultset("CD")->first;
49 my $artist_rs = $schema->resultset("Artist")->search({ artistid => $cd->artist->artistid });
50 for my $key ('', 'primary') {
51   my $art = $artist_rs->find({ name => 'some other name' }, { $key ? (key => $key) : () });
52   is($art->artistid, $cd->get_column('artist'), "Artist found through @{[ $key ? 'explicit' : 'implicit' ]} key locked in the resultset");
53 }
54
55 # collapsing and non-collapsing are separate codepaths, thus the separate tests
56 my $ea_count = 0;
57 $schema->exception_action(sub {
58   $ea_count++;
59   die @_;
60 });
61
62 $artist_rs = $schema->resultset("Artist");
63
64 warnings_exist {
65   $artist_rs->find({})
66 } qr/\QQuery returned more than one row.  SQL that returns multiple rows is DEPRECATED for ->find and ->single/
67     =>  "Non-unique find generated a cursor inexhaustion warning";
68
69 throws_ok {
70   $artist_rs->find({}, { key => 'primary' })
71 } qr/Unable to satisfy requested constraint 'primary'/;
72
73 for (1, 0) {
74   local $ENV{DBIC_NULLABLE_KEY_NOWARN};
75   warnings_like
76     sub {
77       $artist_rs->find({ artistid => undef }, { key => 'primary' })
78     },
79     $_ ? [
80       qr/undef values supplied for requested unique constraint.+almost certainly not what you wanted/,
81     ] : [],
82     'One warning on NULL conditions for constraint'
83   ;
84 }
85
86 is( $ea_count, 1, "exception action invoked the expected amount of times (just the exception)" );
87
88 $schema->exception_action(undef);
89
90
91 $artist_rs = $schema->resultset("Artist")->search({}, { prefetch => 'cds' });
92
93 warnings_exist {
94   $artist_rs->find({})
95 } qr/\QDBIx::Class::ResultSet::find(): Query returned more than one row/, "Non-unique find generated a cursor inexhaustion warning";
96
97 throws_ok {
98   $artist_rs->find({}, { key => 'primary' })
99 } qr/Unable to satisfy requested constraint 'primary'/;
100
101 done_testing;