do not upgrade non-Moose schemas to use_moose=1 (RT#60558)
[catagits/Catalyst-Model-DBIC-Schema.git] / t / 05testapp.t
CommitLineData
5d11d759 1use strict;
2use Test::More;
3use FindBin;
4use File::Spec;
5use File::Find;
6
7plan skip_all => 'Enable this optional test with $ENV{C_M_DBIC_SCHEMA_TESTAPP}'
8 unless $ENV{C_M_DBIC_SCHEMA_TESTAPP};
9
12ee1738 10# XXX this test needs a re-write to fully test the current set of capabilities...
11
5d11d759 12my $test_params = [
13 [ 'TestSchema', 'DBIC::Schema', '' ],
ce9e19dc 14 [ 'TestSchemaDSN', 'DBIC::Schema', qw/fakedsn fakeuser fakepass/, '{ AutoCommit => 1 }' ],
15 [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', 'moniker_map={ roles => "ROLE" }', 'constraint=^users\z', 'dbi:SQLite:testdb.db' ],
16 [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', 'moniker_map={ roles => "ROLE" }', 'constraint=^users\z', 'dbi:SQLite:testdb.db', '', '', 'on_connect_do=["select 1", "select 2"]', 'quote_char="' ],
17 [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', 'moniker_map={ roles => "ROLE" }', 'dbi:SQLite:testdb.db', 'on_connect_do=["select 1", "select 2"]', 'quote_char="' ],
18 [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', 'inflect_singular=sub { $_[0] =~ /\A(.+?)(_id)?\z/; $1 }', q{moniker_map=sub { return join('', map ucfirst, split(/[\W_]+/, lc $_[0])); }}, 'dbi:SQLite:testdb.db' ],
5d11d759 19];
20
5d11d759 21my $test_dir = $FindBin::Bin;
22my $blib_dir = File::Spec->catdir ($test_dir, '..', 'blib', 'lib');
23my $cat_dir = File::Spec->catdir ($test_dir, 'TestApp');
24my $catlib_dir = File::Spec->catdir ($cat_dir, 'lib');
a75b6e58 25my $schema_dir = File::Spec->catdir ($catlib_dir, 'TestSchemaDSN');
5d11d759 26my $creator = File::Spec->catfile($cat_dir, 'script', 'testapp_create.pl');
27my $model_dir = File::Spec->catdir ($catlib_dir, 'TestApp', 'Model');
a75b6e58 28my $db = File::Spec->catdir ($cat_dir, 'testdb.db');
5d11d759 29
30chdir($test_dir);
31system("catalyst.pl TestApp");
32chdir($cat_dir);
33
a75b6e58 34# create test db
35open my $sql, '|-', 'sqlite3', $db or die $!;
36print $sql <<'EOF';
37CREATE TABLE users (
38 id INTEGER PRIMARY KEY,
39 username TEXT,
40 password TEXT,
41 email_address TEXT,
42 first_name TEXT,
43 last_name TEXT,
44 active INTEGER
45);
46CREATE TABLE roles (
47 id INTEGER PRIMARY KEY,
48 role TEXT
49);
50EOF
51close $sql;
52
5d11d759 53foreach my $tparam (@$test_params) {
ce9e19dc 54 my ($model, $helper, @args) = @$tparam;
55
6b6abf77 56 cleanup_schema();
ce9e19dc 57
58 system($^X, "-I$blib_dir", $creator, 'model', $model, $helper, $model, @args);
59
5d11d759 60 my $model_path = File::Spec->catfile($model_dir, $model . '.pm');
61 ok( -f $model_path, "$model_path is a file" );
62 my $compile_rv = system("$^X -I$blib_dir -I$catlib_dir -c $model_path");
63 ok($compile_rv == 0, "perl -c $model_path");
a75b6e58 64
ce9e19dc 65 if (grep /create=static/, @args) {
6b6abf77 66 my @result_files = result_files();
ce9e19dc 67
68 if (grep /constraint/, @args) {
6b6abf77 69 is scalar @result_files, 1, 'constraint works';
a75b6e58 70 } else {
6b6abf77 71 is scalar @result_files, 2, 'correct number of tables';
a75b6e58 72 }
6b6abf77 73
74 for my $file (@result_files) {
75 my $code = code_for($file);
76
77 like $code, qr/use Moose;\n/, 'use_moose enabled';
78 like $code, qr/__PACKAGE__->meta->make_immutable;\n/, 'use_moose enabled';
79 }
80 }
81}
82
83# Test that use_moose=1 is not applied to existing non-moose schemas (RT#60558)
84{
85 cleanup_schema();
86
87 system($^X, "-I$blib_dir", $creator, 'model',
88 'TestSchemaDSN', 'DBIC::Schema', 'TestSchemaDSN',
89 'create=static', 'use_moose=0', 'dbi:SQLite:testdb.db'
90 );
91
92 my @result_files = result_files();
93
94 for my $file (@result_files) {
95 my $code = code_for($file);
96
97 unlike $code, qr/use Moose;\n/, 'non use_moose=1 schema';
98 unlike $code, qr/__PACKAGE__->meta->make_immutable;\n/, 'non use_moose=1 schema';
99 }
100
101 system($^X, "-I$blib_dir", $creator, 'model',
102 'TestSchemaDSN', 'DBIC::Schema', 'TestSchemaDSN',
103 'create=static', 'dbi:SQLite:testdb.db'
104 );
105
106 for my $file (@result_files) {
107 my $code = code_for($file);
108
109 unlike $code, qr/use Moose;\n/,
110 'non use_moose=1 schema not upgraded to use_moose=1';
111 unlike $code, qr/__PACKAGE__->meta->make_immutable;\n/,
112 'non use_moose=1 schema not upgraded to use_moose=1';
a75b6e58 113 }
5d11d759 114}
115
ce9e19dc 116done_testing;
5d11d759 117
118sub rm_rf {
119 my $name = $File::Find::name;
120 if(-d $name) { rmdir $name or die "Cannot rmdir $name: $!" }
121 else { unlink $name or die "Cannot unlink $name: $!" }
122}
ce9e19dc 123
6b6abf77 124sub cleanup_schema {
125 return unless -d $schema_dir;
126 finddepth(\&rm_rf, $schema_dir);
127 unlink "${schema_dir}.pm";
128}
129
130sub code_for {
131 my $file = shift;
132
133 open my $fh, '<', $file;
134 my $code = do { local $/; <$fh> };
135 close $fh;
136
137 return $code;
138}
139
140sub result_files {
141 my $glob = File::Spec->catfile($schema_dir, 'Result', '*');
142
143 return glob($glob);
144}
145
ce9e19dc 146END {
87145c6c 147 if ($ENV{C_M_DBIC_SCHEMA_TESTAPP}) {
148 chdir($test_dir);
149 finddepth(\&rm_rf, $cat_dir);
150 }
ce9e19dc 151}
6b6abf77 152
153# vim:sts=3 sw=3 et tw=80: