8 use DBIx::Class::DeploymentHandler;
9 use DBIx::Class::DeploymentHandler::ExplicitVersions;
10 my $db = 'dbi:SQLite:db.db';
11 my @connection = ($db, '', '', { ignore_version => 1 });
12 my $sql_dir = 't/sql';
14 unlink 'db.db' if -e 'db.db';
16 unlink $_ for glob('t/sql/*');
22 my $s = DBICVersion::Schema->connect(@connection);
24 my $handler = DBIx::Class::DeploymentHandler->new({
25 upgrade_directory => $sql_dir,
27 databases => 'SQLite',
28 sqltargs => { add_drop_table => 0 },
31 my $version = $s->schema_version();
32 $handler->create_install_ddl();
36 my $versions = [map "$_.0", 0..100];
39 my $vh = DBIx::Class::DeploymentHandler::ExplicitVersions->new({
41 ordered_versions => $versions,
45 ok $vh, 'VersionHandler gets instantiated';
47 ok( !$vh->next_version_set, 'next version set returns undef if we are at the version requested' );
51 my $vh = DBIx::Class::DeploymentHandler::ExplicitVersions->new({
53 ordered_versions => $versions,
57 ok $vh, 'VersionHandler gets instantiated';
58 ok( eq_array($vh->next_version_set, [qw( 1.0 2.0 )]), 'first version pair works' );
59 ok( eq_array($vh->next_version_set, [qw( 2.0 3.0 )]), 'second version pair works' );
60 ok( eq_array($vh->next_version_set, [qw( 3.0 4.0 )]), 'third version pair works' );
61 ok( eq_array($vh->next_version_set, [qw( 4.0 5.0 )]), 'fourth version pair works' );
62 ok( !$vh->next_version_set, 'no more versions after final pair' );
63 ok( !$vh->next_version_set, 'still no more versions after final pair' );
67 my $vh = DBIx::Class::DeploymentHandler::ExplicitVersions->new({
69 ordered_versions => $versions,
72 } 'cannot request a version before the current version';
77 vim: ts=2 sw=2 expandtab