use strict;
-use warnings;
+use warnings;
use Test::More;
use Test::Warn;
+use Test::Exception;
use lib qw(t/lib);
use DBICTest;
my $schema = DBICTest->init_schema();
-plan tests => 20;
-
my $art = $schema->resultset("Artist")->find(4);
ok(!defined($art), 'Find on primary id: artist not found');
my @cd = $schema->resultset("CD")->find(6);
$art = $artist_rs->find({ name => 'some other name' }, { key => 'primary' });
ok($art, 'Artist found by key in the resultset');
+# collapsing and non-collapsing are separate codepaths, thus the separate tests
+
+
$artist_rs = $schema->resultset("Artist");
-warning_is {
- $artist_rs->find({}, { key => 'primary' })
-} "DBIx::Class::ResultSet::find(): Query returned more than one row. SQL that returns multiple rows is DEPRECATED for ->find and ->single"
+
+warnings_exist {
+ $artist_rs->find({})
+} qr/\QQuery returned more than one row. SQL that returns multiple rows is DEPRECATED for ->find and ->single/
=> "Non-unique find generated a cursor inexhaustion warning";
+throws_ok {
+ $artist_rs->find({}, { key => 'primary' })
+} qr/Unable to satisfy requested constraint 'primary'/;
+
+for (1, 0) {
+ local $ENV{DBIC_NULLABLE_KEY_NOWARN};
+ warnings_like
+ sub {
+ $artist_rs->find({ artistid => undef }, { key => 'primary' })
+ },
+ $_ ? [
+ qr/undef values supplied for requested unique constraint.+almost certainly not what you wanted/,
+ ] : [],
+ 'One warning on NULL conditions for constraint'
+ ;
+}
+
+
$artist_rs = $schema->resultset("Artist")->search({}, { prefetch => 'cds' });
-warning_is {
+
+warnings_exist {
+ $artist_rs->find({})
+} qr/\QDBIx::Class::ResultSet::find(): Query returned more than one row/, "Non-unique find generated a cursor inexhaustion warning";
+
+throws_ok {
$artist_rs->find({}, { key => 'primary' })
-} "DBIx::Class::ResultSet::find(): Query returned more than one row", "Non-unique find generated a cursor inexhaustion warning";
+} qr/Unable to satisfy requested constraint 'primary'/;
+
+done_testing;