File: 104view.t

package info (click to toggle)
libdbix-class-perl 0.082843-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 5,320 kB
  • sloc: perl: 27,215; sql: 322; sh: 29; makefile: 16
file content (72 lines) | stat: -rw-r--r-- 1,955 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
use strict;
use warnings;

use Test::More;
use lib qw(t/lib);
use DBICTest;

my $schema = DBICTest->init_schema();

## Real view
my $cds_rs_2000 = $schema->resultset('CD')->search( { year => 2000 });
my $year2kcds_rs = $schema->resultset('Year2000CDs');

is($cds_rs_2000->count, $year2kcds_rs->count, 'View Year2000CDs sees all CDs in year 2000');


## Virtual view
my $cds_rs_1999 = $schema->resultset('CD')->search( { year => 1999 });
my $year1999cds_rs = $schema->resultset('Year1999CDs');

is($cds_rs_1999->count, $year1999cds_rs->count, 'View Year1999CDs sees all CDs in year 1999');


# Test if relationships work correctly
is_deeply (
  [
    $schema->resultset('Year1999CDs')->search (
      {},
      {
        result_class => 'DBIx::Class::ResultClass::HashRefInflator',
        prefetch => ['artist', { tracks => [qw/cd year1999cd year2000cd/] } ],
        order_by => 'tracks.trackid',
      },
    )->all
  ],
  [
    $schema->resultset('CD')->search (
      { 'me.year' => '1999'},
      {
        result_class => 'DBIx::Class::ResultClass::HashRefInflator',
        prefetch => ['artist', { tracks => [qw/cd year1999cd year2000cd/] } ],
        columns => [qw/cdid single_track title/],   # to match the columns retrieved by the virtview
        order_by => 'tracks.trackid',
      },
    )->all
  ],
  'Prefetch over virtual view gives expected result',
);

is_deeply (
  [
    $schema->resultset('Year2000CDs')->search (
      {},
      {
        result_class => 'DBIx::Class::ResultClass::HashRefInflator',
        prefetch => ['artist', { tracks => [qw/cd year1999cd year2000cd/] } ],
      },
    )->all
  ],
  [
    $schema->resultset('CD')->search (
      { 'me.year' => '2000'},
      {
        result_class => 'DBIx::Class::ResultClass::HashRefInflator',
        prefetch => ['artist', { tracks => [qw/cd year1999cd year2000cd/] } ],
      },
    )->all
  ],
  'Prefetch over regular view gives expected result',
);

done_testing;