Another revamp of the selector resolution - now supporting unbalanced select/as
[dbsrgits/DBIx-Class.git] / t / search / select_chains.t
CommitLineData
3a55f069 1use strict;
2use warnings;
3
4use Test::More;
3a55f069 5
6use lib qw(t/lib);
7use DBIC::SqlMakerTest;
8use DBICTest;
9
10
11my $schema = DBICTest->init_schema();
12
13my @chain = (
14 {
15 columns => [ 'cdid' ],
37aafa2e 16 '+columns' => [ { title_lc => { lower => 'title', -as => 'lctitle' } } ],
442363e5 17 '+select' => [ 'genreid' ],
18 '+as' => [ 'genreid' ],
37aafa2e 19 } => 'SELECT me.cdid, LOWER( title ) AS lctitle, me.genreid FROM cd me',
3a55f069 20
21 {
37aafa2e 22 '+columns' => [ { max_year => { max => 'me.year', -as => 'last_y' }}, ],
3a55f069 23 '+select' => [ { count => 'me.cdid' }, ],
24 '+as' => [ 'cnt' ],
00336453 25 } => 'SELECT me.cdid, LOWER( title ) AS lctitle, me.genreid, MAX( me.year ) AS last_y, COUNT( me.cdid ) FROM cd me',
3a55f069 26
27 {
28 select => [ { min => 'me.cdid' }, ],
29 as => [ 'min_id' ],
30 } => 'SELECT MIN( me.cdid ) FROM cd me',
31
32 {
37aafa2e 33 '+columns' => [ { cnt => { count => 'cdid', -as => 'cnt' } } ],
34 } => 'SELECT MIN( me.cdid ), COUNT ( cdid ) AS cnt FROM cd me',
3a55f069 35
36 {
37aafa2e 37 columns => [ { foo => { coalesce => [qw/a b c/], -as => 'firstfound' } } ],
38 } => 'SELECT COALESCE( a, b, c ) AS firstfound FROM cd me',
39
40 {
41 '+columns' => [ 'me.year' ],
42 '+select' => [ { max => 'me.year', -as => 'last_y' } ],
43 '+as' => [ 'ly' ],
44 } => 'SELECT COALESCE( a, b, c ) AS firstfound, me.year, MAX( me.year ) AS last_y FROM cd me',
45
46 {
47 '+select' => [ { count => 'me.cdid', -as => 'cnt' } ],
48 '+as' => [ 'cnt' ],
49 } => 'SELECT COALESCE( a, b, c ) AS firstfound, me.year, MAX( me.year ) AS last_y, COUNT( me.cdid ) AS cnt FROM cd me',
50
51 # adding existing stuff should not alter selector
52 {
53 '+select' => [ 'me.year' ],
54 '+as' => [ 'year' ],
55 } => 'SELECT COALESCE( a, b, c ) AS firstfound, me.year, MAX( me.year ) AS last_y, COUNT( me.cdid ) AS cnt FROM cd me',
56
57 {
58 '+columns' => [ 'me.year' ],
59 } => 'SELECT COALESCE( a, b, c ) AS firstfound, me.year, MAX( me.year ) AS last_y, COUNT( me.cdid ) AS cnt FROM cd me',
60
61 {
62 '+columns' => 'me.year',
63 } => 'SELECT COALESCE( a, b, c ) AS firstfound, me.year, MAX( me.year ) AS last_y, COUNT( me.cdid ) AS cnt FROM cd me',
64
3a55f069 65);
66
67my $rs = $schema->resultset('CD');
68
69my $testno = 1;
70while (@chain) {
71 my $attrs = shift @chain;
72 my $sql = shift @chain;
73
74 $rs = $rs->search ({}, $attrs);
75
76 is_same_sql_bind (
77 $rs->as_query,
14af4aa0 78 "($sql)",
3a55f069 79 [],
80 "Test $testno of SELECT assembly ok",
81 );
82
83 $testno++;
84}
85
37aafa2e 86# Make sure we don't lose bits even with weird selector specs
87$rs = $schema->resultset('CD')->search ({}, {
88 'columns' => [ 'me.title' ],
89})->search ({}, {
90 '+select' => \'me.year AS foo',
91})->search ({}, {
92 '+select' => [ \'me.artistid AS bar' ],
93})->search ({}, {
94 '+select' => { count => 'artistid', -as => 'baz' },
95});
96
97is_same_sql_bind (
98 $rs->as_query,
99 '( SELECT
100 me.title,
00336453 101 COUNT( artistid ) AS baz,
37aafa2e 102 me.year AS foo,
00336453 103 me.artistid AS bar
37aafa2e 104 FROM cd me
105 )',
106 [],
107 'Correct chaining before attr resolution'
108);
109
b773093f 110done_testing;