switch tests to Test::TempDir::Tiny to enable parallelization
[dbsrgits/DBIx-Class-Fixtures.git] / t / 13-populate-two-dbs.t
1 #!perl
2
3 use DBIx::Class::Fixtures;
4 use Test::More tests => 7;
5 use lib qw(t/lib);
6 use DBICTest;
7 use Path::Class;
8 use Data::Dumper;
9 use DBICTest::Schema2;
10 use Devel::Confess;
11 use Test::TempDir::Tiny;
12 use IO::All;
13
14 my $tempdir = tempdir;
15
16 # set up and populate normal schema
17 ok(my $schema = DBICTest->init_schema(db_dir => $tempdir), 'got schema');
18 my $config_dir = io->catfile(qw't var configs')->name;
19 my $dbix_class_different = io->catfile($tempdir, qw[ DBIxClassDifferent.db ])->name;
20 my @different_connection_details = (
21     "dbi:SQLite:$dbix_class_different",
22     '', 
23     ''
24 )
25 ;
26 my $schema2 = DBICTest::Schema2->compose_namespace('DBICTest2')
27                                ->connect(@different_connection_details);
28
29 ok $schema2;
30
31 unlink($dbix_class_different) if (-e $dbix_class_different );
32
33 DBICTest->deploy_schema($schema2, io->catfile(qw't lib sqlite_different.sql')->name);
34
35 # do dump
36 ok(my $fixtures = DBIx::Class::Fixtures->new({ 
37       config_dir => $config_dir, 
38       debug => 0
39    }), 
40    'object created with correct config dir');
41
42 ok($fixtures->dump({ 
43       config => "simple.json", 
44       schema => $schema,
45       directory => $tempdir 
46     }), 
47     "simple dump executed okay");
48
49 ok($fixtures->populate({ 
50       ddl => io->catfile(qw[t lib sqlite_different.sql])->name,
51       connection_details => [@different_connection_details], 
52       directory => $tempdir
53     }),
54     'mysql populate okay');
55
56 ok($fixtures->populate({ 
57       ddl => io->catfile(qw[ t lib sqlite.sql ])->name,
58       connection_details => ['dbi:SQLite:'.io->catfile($tempdir, qw[ DBIxClass.db ])->name, '', ''],
59       directory => $tempdir
60     }), 
61     'sqlite populate okay');
62
63 $schema = DBICTest->init_schema(db_dir => $tempdir,no_deploy => 1);
64 is($schema->resultset('Artist')->count, 1, 'artist imported to sqlite okay');