upgrade not update
[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    #ok(-e 't/sql/DBICVersion-Schema-schema-2.0-SQLite.sql', 'DDL for 2.0 got created successfully');
63    #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');
64    dies_ok {
65       $s->resultset('Foo')->create({
66          bar => 'frew',
67          baz => 'frew',
68       })
69    } 'schema not deployed';
70    #$handler->install('1.0');
71    dies_ok {
72       $s->resultset('Foo')->create({
73          bar => 'frew',
74          baz => 'frew',
75       })
76    } 'schema not uppgrayyed';
77    $handler->upgrade;
78    lives_ok {
79       $s->resultset('Foo')->create({
80          bar => 'frew',
81          baz => 'frew',
82       })
83    } 'schema is deployed';
84 }
85
86 VERSION3: {
87    use_ok 'DBICVersion_v3';
88    my $s = DBICVersion::Schema->connect(@connection);
89    ok($s, 'DBICVersion::Schema 3.0 instantiates correctly');
90    my $handler = DBIx::Class::DeploymentHandler->new({
91       upgrade_directory => $sql_dir,
92       schema => $s,
93       databases => 'SQLite',
94    });
95
96    ok($handler, 'DBIx::Class::DeploymentHandler w/3.0 instantiates correctly');
97
98    $version = $s->schema_version();
99    $handler->prepare_install;
100    $handler->prepare_upgrade( '1.0', $version );
101    $handler->prepare_upgrade( '2.0', $version );
102    #ok(-e 't/sql/DBICVersion-Schema-schema-3.0-SQLite.sql', 'DDL for 3.0 got created successfully');
103    #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');
104    #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');
105    dies_ok {
106       $s->resultset('Foo')->create({
107             bar => 'frew',
108             baz => 'frew',
109             biff => 'frew',
110          })
111    } 'schema not deployed';
112    $handler->upgrade;
113    lives_ok {
114       $s->resultset('Foo')->create({
115          bar => 'frew',
116          baz => 'frew',
117          biff => 'frew',
118       })
119    } 'schema is deployed';
120 }
121
122 done_testing;
123 __END__
124
125 vim: ts=2 sw=2 expandtab