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