Sanify group_by handling in complex prefetch rewrites
[dbsrgits/DBIx-Class.git] / t / inflate / core.t
CommitLineData
70350518 1use strict;
2use warnings;
3
4use Test::More;
5use lib qw(t/lib);
6use DBICTest;
7
a47e1233 8my $schema = DBICTest->init_schema();
0567538f 9
10eval { require DateTime };
11plan skip_all => "Need DateTime for inflation tests" if $@;
12
c6e0ee83 13plan tests => 22;
0567538f 14
c6e0ee83 15$schema->class('CD') ->inflate_column( 'year',
0567538f 16 { inflate => sub { DateTime->new( year => shift ) },
17 deflate => sub { shift->year } }
18);
19
20# inflation test
f9db5527 21my $cd = $schema->resultset("CD")->find(3);
0567538f 22
23is( ref($cd->year), 'DateTime', 'year is a DateTime, ok' );
24
89279e9d 25is( $cd->year->year, 1997, 'inflated year ok' );
26
0567538f 27is( $cd->year->month, 1, 'inflated month ok' );
28
e81a6241 29eval { $cd->year(\'year +1'); };
30ok(!$@, 'updated year using a scalarref');
31$cd->update();
32$cd->discard_changes();
33
34is( ref($cd->year), 'DateTime', 'year is still a DateTime, ok' );
35
36is( $cd->year->year, 1998, 'updated year, bypassing inflation' );
37
38is( $cd->year->month, 1, 'month is still 1' );
39
40# get_inflated_column test
41
42is( ref($cd->get_inflated_column('year')), 'DateTime', 'get_inflated_column produces a DateTime');
43
0567538f 44# deflate test
45my $now = DateTime->now;
46$cd->year( $now );
47$cd->update;
48
ad5d0ee9 49$cd = $schema->resultset("CD")->find(3);
0567538f 50is( $cd->year->year, $now->year, 'deflate ok' );
51
e81a6241 52# set_inflated_column test
53eval { $cd->set_inflated_column('year', $now) };
54ok(!$@, 'set_inflated_column with DateTime object');
55$cd->update;
56
ad5d0ee9 57$cd = $schema->resultset("CD")->find(3);
e81a6241 58is( $cd->year->year, $now->year, 'deflate ok' );
59
ad5d0ee9 60$cd = $schema->resultset("CD")->find(3);
61my $before_year = $cd->year->year;
e81a6241 62eval { $cd->set_inflated_column('year', \'year + 1') };
e81a6241 63ok(!$@, 'set_inflated_column to "year + 1"');
64$cd->update;
e81a6241 65
c6e0ee83 66TODO: {
67 local $TODO = 'this was left in without a TODO - should it work?';
68
69 eval {
70 $cd->store_inflated_column('year', \'year + 1');
71 is_deeply( $cd->year, \'year + 1', 'deflate ok' );
72 };
73 ok(!$@, 'store_inflated_column to "year + 1"');
74}
75
ad5d0ee9 76$cd = $schema->resultset("CD")->find(3);
77is( $cd->year->year, $before_year+1, 'deflate ok' );
e81a6241 78
79# store_inflated_column test
ad5d0ee9 80$cd = $schema->resultset("CD")->find(3);
e81a6241 81eval { $cd->store_inflated_column('year', $now) };
82ok(!$@, 'store_inflated_column with DateTime object');
83$cd->update;
84
85is( $cd->year->year, $now->year, 'deflate ok' );
86
ad5d0ee9 87# update tests
88$cd = $schema->resultset("CD")->find(3);
89eval { $cd->update({'year' => $now}) };
90ok(!$@, 'update using DateTime object ok');
91is($cd->year->year, $now->year, 'deflate ok');
92
93$cd = $schema->resultset("CD")->find(3);
94$before_year = $cd->year->year;
95eval { $cd->update({'year' => \'year + 1'}) };
96ok(!$@, 'update using scalarref ok');
97
98$cd = $schema->resultset("CD")->find(3);
99is($cd->year->year, $before_year + 1, 'deflate ok');
100
101# discard_changes test
102$cd = $schema->resultset("CD")->find(3);
103# inflate the year
104$before_year = $cd->year->year;
105$cd->update({ year => \'year + 1'});
106$cd->discard_changes;
107
108is($cd->year->year, $before_year + 1, 'discard_changes clears the inflated value');
07d4fb20 109
110my $copy = $cd->copy({ year => $now, title => "zemoose" });
111
112isnt( $copy->year->year, $before_year, "copy" );
ad5d0ee9 113