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