2 char quote_char support and s/roles/traits/
[catagits/Catalyst-Model-DBIC-Schema.git] / t / 08helper.t
1 use strict;
2 use warnings;
3
4 use FindBin '$Bin';
5 use lib "$Bin/lib";
6
7 use Test::More tests => 40;
8 use Test::Exception;
9 use Catalyst::Helper::Model::DBIC::Schema;
10 use Catalyst::Helper;
11 use Storable 'dclone';
12
13 my $helper      = Catalyst::Helper->new;
14 $helper->{base} = $Bin;
15 my $static      = 'create=static';
16 my $dynamic     = 'create=dynamic';
17 my $sqlite      = 'dbi:SQLite:myapp.db';
18 my $pg          = 'dbi:Pg:dbname=foo';
19 my $on_connect_do = 'on_connect_do=["select 1", "select 2"]';
20 my $quote_char  = 'quote_char="';
21 my $name_sep    = 'name_sep=.';
22 my $i;
23
24 $i = instance(schema_class => 'ASchemaClass');
25 is $i->old_schema, 1, '->load_classes detected correctly';
26
27 $i = instance(args => ['traits=Caching']);
28 is_deeply $i->traits, ['Caching'], 'one trait';
29 is $i->helper->{traits}, "['Caching']", 'one trait as string';
30
31 $i = instance(args => ['traits=Caching,Replicated']);
32 is_deeply $i->traits, ['Caching', 'Replicated'], 'two traits';
33 is $i->helper->{traits}, "['Caching','Replicated']", 'two traits as string';
34
35 $i = instance(args => [$static]);
36 is $i->create, 'static', 'create=static';
37
38 $i = instance(args => [$static,
39     q{moniker_map={ authors => "AUTHORS", books => "BOOKS" }}]
40 );
41 is_deeply $i->loader_args->{moniker_map},
42     { authors => 'AUTHORS', books => 'BOOKS' },
43     'loader hash arg';
44 is $i->helper->{loader_args}{moniker_map},
45     q{{authors => "AUTHORS",books => "BOOKS"}},
46     'loader hash arg as string';
47
48 $i = instance(args => [$static, q{foo=["bar","baz"]}]);
49 is_deeply $i->loader_args->{foo}, ['bar', 'baz'], 'loader array arg';
50 is $i->helper->{loader_args}{foo},
51     q{["bar","baz"]},
52     'loader array arg as string';
53
54 $i = instance(args => [$static, q{components=TimeStamp}]);
55 is_deeply $i->components, ['InflateColumn::DateTime', 'TimeStamp'],
56     'extra component';
57 is $i->helper->{loader_args}{components},
58     q{["InflateColumn::DateTime","TimeStamp"]},
59     'components as string';
60
61 $i = instance(
62     schema_class => 'ASchemaClass',
63     args => [$static, q{components=TimeStamp}]
64 );
65 is_deeply $i->components, ['TimeStamp'],
66     'extra component with ->load_classes';
67
68 $i = instance(args => [$static, q{components=TimeStamp,Foo}]);
69 is_deeply $i->components, ['InflateColumn::DateTime', 'TimeStamp', 'Foo'],
70     'two extra components';
71
72 $i = instance(args => [$static, q{constraint=^(foo|bar)$}]);
73 is $i->loader_args->{constraint}, qr/^(foo|bar)$/,
74     'constraint loader arg';
75 is $i->helper->{loader_args}{constraint},
76     q{qr/(?-xism:^(foo|bar)$)/},
77     'constraint loader arg as string';
78
79 $i = instance(args => [$static, q{exclude=^(foo|bar)$}]);
80 is $i->loader_args->{exclude}, qr/^(foo|bar)$/,
81     'exclude loader arg';
82
83 $i = instance(args => [$static, q{db_schema=foo;bar::baz/quux}]);
84 is $i->loader_args->{db_schema}, q{foo;bar::baz/quux},
85     'simple value loader arg';
86
87 $i = instance(args => [
88     $static, 'components=TimeStamp', $sqlite, $on_connect_do,
89     $quote_char, $name_sep
90 ]);
91
92 is_deeply $i->components, ['InflateColumn::DateTime', 'TimeStamp'],
93     'extra component';
94
95 is $i->connect_info->{dsn}, $sqlite, 'connect_info dsn';
96 is $i->connect_info->{user}, '', 'sqlite omitted user';
97 is $i->connect_info->{password}, '', 'sqlite omitted password';
98
99 is_deeply $i->connect_info->{on_connect_do},
100     ['select 1', 'select 2'], 'connect_info data struct';
101
102 is $i->helper->{connect_info}{on_connect_do},
103     q{["select 1", "select 2"]}, 'connect_info data struct as string';
104
105 is $i->connect_info->{quote_char}, '"', 'connect_info quote_char';
106
107 is $i->helper->{connect_info}{quote_char}, 'q{"}',
108     'connect_info quote_char as string';
109
110 is $i->connect_info->{name_sep}, '.', 'connect_info name_sep';
111
112 is $i->helper->{connect_info}{name_sep}, 'q{.}',
113     'connect_info name_sep as string';
114
115 $i = instance(args => [
116     $static, 'components=TimeStamp', $sqlite, '', $on_connect_do,
117     $quote_char, $name_sep
118 ]);
119
120 is $i->connect_info->{dsn}, $sqlite, 'connect_info dsn';
121 is $i->connect_info->{user}, '', 'sqlite user';
122 is $i->connect_info->{password}, '', 'sqlite omitted password';
123
124 $i = instance(args => [
125     $static, 'components=TimeStamp', $pg, 'user', 'pass', $on_connect_do,
126     $quote_char, $name_sep
127 ]);
128
129 is $i->connect_info->{dsn}, $pg, 'connect_info dsn';
130 is $i->connect_info->{user}, 'user', 'user';
131 is $i->connect_info->{password}, 'pass', 'password';
132
133 $i = instance(args => [
134     $static, $pg, 'user', 'pass', 'quote_char=[]', $name_sep
135 ]);
136
137 is_deeply $i->connect_info->{quote_char}, ['[', ']'],
138     '2 character quote_char';
139 is $i->helper->{connect_info}{quote_char}, '["[","]"]',
140     '2 character quote_char as string';
141
142 $i = instance(args => [
143     $static, 'components=TimeStamp', $sqlite, $on_connect_do,
144     $quote_char, $name_sep, '{ auto_savepoint => 1, AutoCommit => 0 }'
145 ]);
146
147 is $i->connect_info->{auto_savepoint}, 1, 'connect_info arg from extra hash';
148 is $i->connect_info->{AutoCommit}, 0, 'connect_info arg from extra hash';
149 is $i->helper->{connect_info}{auto_savepoint}, 'q{1}',
150     'connect_info arg from extra hash as string';
151 is $i->helper->{connect_info}{AutoCommit}, 'q{0}',
152     'connect_info arg from extra hash as string';
153
154 sub instance {
155     Catalyst::Helper::Model::DBIC::Schema->new(
156         schema_class => 'AnotherSchemaClass',
157         helper => dclone($helper),
158         args => ['create=static'],
159         @_
160     )
161 }