basic compat fixes for SQLT2
[dbsrgits/DBIx-Class-DeploymentHandler.git] / t / version_handlers / db_schema_versions.t
CommitLineData
24794769 1#!perl
2
3use Test::More;
4use Test::Exception;
5
6use lib 't/lib';
02d58ac0 7use DBICDHTest;
24794769 8use DBICTest;
9use DBIx::Class::DeploymentHandler;
c703d15d 10use DBIx::Class::DeploymentHandler::VersionHandler::ExplicitVersions;
24794769 11my $db = 'dbi:SQLite:db.db';
12my @connection = ($db, '', '', { ignore_version => 1 });
13my $sql_dir = 't/sql';
14
02d58ac0 15DBICDHTest::ready;
24794769 16
17use DBICVersion_v1;
18my $s = DBICVersion::Schema->connect(@connection);
19
20my $handler = DBIx::Class::DeploymentHandler->new({
21 upgrade_directory => $sql_dir,
22 schema => $s,
23 databases => 'SQLite',
24 sqltargs => { add_drop_table => 0 },
25});
fb105cfa 26my $v_storage = $handler->version_storage;
24794769 27my $version = $s->schema_version();
a912450b 28$handler->prepare_install();
24794769 29
30$handler->install;
31{
c703d15d 32 my $vh = DBIx::Class::DeploymentHandler::VersionHandler::DatabaseToSchemaVersions->new({
24794769 33 schema => $s,
34 ordered_versions => $versions,
35 to_version => '5.0',
fb105cfa 36 version_storage => $v_storage,
24794769 37 });
38
39 ok( $vh, 'VersionHandler gets instantiated' );
40 ok( eq_array( $vh->next_version_set, [qw( 1.0 5.0 )] ), 'db version and to_version get correctly put into version set');
41 ok( !$vh->next_version_set, 'next_version_set only works once');
42 ok( !$vh->next_version_set, 'seriously.');
43}
44
45{
c703d15d 46 my $vh = DBIx::Class::DeploymentHandler::VersionHandler::DatabaseToSchemaVersions->new({
24794769 47 schema => $s,
48 ordered_versions => $versions,
fb105cfa 49 version_storage => $v_storage,
24794769 50 });
51
52 ok( $vh, 'VersionHandler gets instantiated' );
53 ok( !$vh->next_version_set, 'VersionHandler is null when schema_version and db_verison are the same' );
54}
55
56{
c703d15d 57 my $vh = DBIx::Class::DeploymentHandler::VersionHandler::DatabaseToSchemaVersions->new({
24794769 58 schema => $s,
59 ordered_versions => $versions,
fb105cfa 60 version_storage => $v_storage,
24794769 61 });
62
63 ok( $vh, 'VersionHandler gets instantiated' );
64 ok( !$vh->next_version_set, 'VersionHandler is null when schema_version and db_verison are the same' );
65}
66
67{
68 $DBICVersion::Schema::VERSION = '10.0';
69
c703d15d 70 my $vh = DBIx::Class::DeploymentHandler::VersionHandler::DatabaseToSchemaVersions->new({
24794769 71 schema => $s,
72 ordered_versions => $versions,
fb105cfa 73 version_storage => $v_storage,
24794769 74 });
75
76 ok( $vh, 'VersionHandler gets instantiated' );
77 ok( eq_array( $vh->next_version_set, [qw( 1.0 10.0 )] ), 'db version and schema version get correctly put into version set');
78 ok( !$vh->next_version_set, 'VersionHandler is null on next try' );
79}
80
81done_testing;
82__END__
83
84vim: ts=2 sw=2 expandtab