Added two tests and marked one todo_skip
Rob Kinyon [Mon, 3 Aug 2009 03:49:59 +0000 (03:49 +0000)]
t/count/prefetch.t

index 1103c56..f0b4e06 100644 (file)
@@ -8,7 +8,7 @@ use DBICTest;
 use DBIC::SqlMakerTest;
 use DBIC::DebugObj;
 
-plan tests => 9;
+plan tests => 17;
 
 my $schema = DBICTest->init_schema();
 
@@ -37,8 +37,35 @@ my $schema = DBICTest->init_schema();
   );
 }
 
+# Added test by mo per http://scsys.co.uk:8001/31870
+TODO: {
+  todo_skip "This breaks stuff", 3;
+  my $rs = $schema->resultset("Artist")->search(undef, {distinct => 1})
+            ->search_related('cds')->search_related('genre',
+                { 'genre.name' => 'foo' },
+                { prefetch => q(cds) },
+            );
+  is ($rs->all, 5, 'Correct number of objects');
+
+
+  my ($sql, @bind);
+  $schema->storage->debugobj(DBIC::DebugObj->new(\$sql, \@bind));
+  $schema->storage->debug(1);
+
+
+  is ($rs->count, 5, 'Correct count');
+
+  is_same_sql_bind (
+    $sql,
+    \@bind,
+    'SELECT COUNT( * ) FROM (SELECT cds.cdid FROM artist me JOIN cd cds ON cds.artist = me.artistid LEFT JOIN track tracks ON tracks.cd = cds.cdid JOIN artist artist ON artist.artistid = cds.artist WHERE tracks.position = ? OR tracks.position = ? GROUP BY cds.cdid) count_subq',
+    [ qw/'1' '2'/ ],
+  );
+}
+
 # collapsing prefetch with distinct
-{
+TODO: {
+  todo_skip "This is busted", 3;
   my $rs = $schema->resultset("Artist")->search(undef, {distinct => 1})
             ->search_related('cds')->search_related('genre',
                 { 'genre.name' => 'foo' },
@@ -86,3 +113,44 @@ my $schema = DBICTest->init_schema();
     [ qw/'1' '2'/ ],
   );
 }
+
+# Added test by mo per http://scsys.co.uk:8001/31873
+TODO: {
+    todo_skip "This breaks stuff", 5;
+    my $rs = $schema->resultset("Artwork")->search(undef, {distinct => 1})
+              ->search_related('artwork_to_artist')->search_related('artist',
+                 undef,
+                  { prefetch => q(cds) },
+              );
+    is($rs->all, 0, 'failure without WHERE');
+
+    $rs = $schema->resultset("Artwork")->search(undef, {distinct => 1})
+              ->search_related('artwork_to_artist')->search_related('artist',
+                 { 'cds.title' => 'foo' }, # this line has changed
+                  { prefetch => q(cds) },
+              );
+    is($rs->all, 0, 'success with WHERE');
+    
+    # different case
+    
+    $rs = $schema->resultset("Artist")->search(undef)#, {distinct => 1})
+                ->search_related('cds')->search_related('genre',
+                    { 'genre.name' => 'foo' },
+                    { prefetch => q(cds) },
+                 );
+    is($rs->all, 0, 'success without distinct');
+    
+    $rs = $schema->resultset("Artist")->search(undef, {distinct => 1})
+                ->search_related('cds')->search_related('genre',
+                    { 'genre.name' => 'foo' },
+                    #{ prefetch => q(cds) },
+                 );
+    is($rs->all, 0, 'success without prefetch');
+
+    $rs = $schema->resultset("Artist")->search(undef, {distinct => 1})
+                ->search_related('cds')->search_related('genre',
+                    { 'genre.name' => 'foo' },
+                    { prefetch => q(cds) },
+                 );
+    is($rs->all, 0, 'failure with distinct');
+}