insert ddl into database; fix tests to ingore that
[dbsrgits/DBIx-Class-DeploymentHandler.git] / t / 02-instantiation.t
1 #!perl
2
3 use Test::More;
4 use Test::Exception;
5 use File::Path 'remove_tree';
6
7 use lib 't/lib';
8 use DBICDHTest;
9 use DBICTest;
10 use DBIx::Class::DeploymentHandler;
11 my $db = 'dbi:SQLite:db.db';
12 my @connection = ($db, '', '', { ignore_version => 1 });
13 my $sql_dir = 't/sql';
14
15 DBICDHTest::ready;
16
17 VERSION1: {
18    use_ok 'DBICVersion_v1';
19    my $s = DBICVersion::Schema->connect(@connection);
20    ok($s, 'DBICVersion::Schema 1.0 instantiates correctly');
21    my $handler = DBIx::Class::DeploymentHandler->new({
22       upgrade_directory => $sql_dir,
23       schema => $s,
24       databases => 'SQLite',
25     sqltargs => { add_drop_table => 0 },
26    });
27
28    ok($handler, 'DBIx::Class::DeploymentHandler w/1.0 instantiates correctly');
29
30    my $version = $s->schema_version();
31    $handler->prepare_install();
32    #ok(-e 't/sql/DBICVersion-Schema-schema-1.0-SQLite.sql', 'DDL for 1.0 got created successfully');
33
34    dies_ok {
35       $s->resultset('Foo')->create({
36          bar => 'frew',
37       })
38    } 'schema not deployed';
39    $handler->install;
40    lives_ok {
41       $s->resultset('Foo')->create({
42          bar => 'frew',
43       })
44    } 'schema is deployed';
45 }
46
47 VERSION2: {
48    use_ok 'DBICVersion_v2';
49    my $s = DBICVersion::Schema->connect(@connection);
50    ok($s, 'DBICVersion::Schema 2.0 instantiates correctly');
51    my $handler = DBIx::Class::DeploymentHandler->new({
52       upgrade_directory => $sql_dir,
53       schema => $s,
54       databases => 'SQLite',
55    });
56
57    ok($handler, 'DBIx::Class::DeploymentHandler w/2.0 instantiates correctly');
58
59    $version = $s->schema_version();
60    $handler->prepare_install();
61    $handler->prepare_upgrade('1.0', $version);
62    $handler->prepare_upgrade($version, '1.0');
63    #ok(-e 't/sql/DBICVersion-Schema-schema-2.0-SQLite.sql', 'DDL for 2.0 got created successfully');
64    #ok(-e 't/sql/DBICVersion-Schema-diff-1.0-2.0-SQLite.sql', 'DDL for migration from 1.0 to 2.0 got created successfully');
65    dies_ok {
66       $s->resultset('Foo')->create({
67          bar => 'frew',
68          baz => 'frew',
69       })
70    } 'schema not deployed';
71    #$handler->install('1.0');
72    dies_ok {
73       $s->resultset('Foo')->create({
74          bar => 'frew',
75          baz => 'frew',
76       })
77    } 'schema not uppgrayyed';
78    $handler->upgrade;
79    lives_ok {
80       $s->resultset('Foo')->create({
81          bar => 'frew',
82          baz => 'frew',
83       })
84    } 'schema is deployed';
85 }
86
87 VERSION3: {
88    use_ok 'DBICVersion_v3';
89    my $s = DBICVersion::Schema->connect(@connection);
90    ok($s, 'DBICVersion::Schema 3.0 instantiates correctly');
91    my $handler = DBIx::Class::DeploymentHandler->new({
92       upgrade_directory => $sql_dir,
93       schema => $s,
94       databases => 'SQLite',
95    });
96
97    ok($handler, 'DBIx::Class::DeploymentHandler w/3.0 instantiates correctly');
98
99    $version = $s->schema_version();
100    $handler->prepare_install;
101    $handler->prepare_upgrade( '1.0', $version );
102    $handler->prepare_upgrade( '2.0', $version );
103    #ok(-e 't/sql/DBICVersion-Schema-schema-3.0-SQLite.sql', 'DDL for 3.0 got created successfully');
104    #ok(-e 't/sql/DBICVersion-Schema-diff-1.0-3.0-SQLite.sql', 'DDL for migration from 1.0 to 3.0 got created successfully');
105    #ok(-e 't/sql/DBICVersion-Schema-diff-2.0-3.0-SQLite.sql', 'DDL for migration from 2.0 to 3.0 got created successfully');
106    dies_ok {
107       $s->resultset('Foo')->create({
108             bar => 'frew',
109             baz => 'frew',
110             biff => 'frew',
111          })
112    } 'schema not deployed';
113    $handler->upgrade;
114    lives_ok {
115       $s->resultset('Foo')->create({
116          bar => 'frew',
117          baz => 'frew',
118          biff => 'frew',
119       })
120    } 'schema is deployed';
121 }
122
123 done_testing;
124 __END__
125
126 vim: ts=2 sw=2 expandtab