3 use DBIx::Class::Fixtures;
4 use Test::More tests => 47;
10 # set up and populate schema
11 ok(my $schema = DBICTest->init_schema(), 'got schema');
12 my $config_dir = 't/var/configs';
15 ok(my $fixtures = DBIx::Class::Fixtures->new({ config_dir => $config_dir, debug => 0 }), 'object created with correct config dir');
17 foreach my $set ('simple', 'quantity', 'fetch', 'rules') {
18 no warnings 'redefine';
19 DBICTest->clear_schema($schema);
20 DBICTest->populate_schema($schema);
21 ok($fixtures->dump({ config => "$set.json", schema => $schema, directory => 't/var/fixtures' }), "$set dump executed okay");
22 $fixtures->populate({ ddl => 't/lib/sqlite.sql', connection_details => ['dbi:SQLite:t/var/DBIxClass.db', '', ''], directory => 't/var/fixtures' });
24 my $fixture_dir = dir('t/var/fixtures');
25 foreach my $class ($schema->sources) {
26 my $source_dir = dir($fixture_dir, lc($class));
27 is($schema->resultset($class)->count, (-e $source_dir) ? scalar($source_dir->children) : 0, "correct number of $set " . lc($class) . 's ' . $schema->resultset($class)->count);
28 next unless (-e $source_dir);
30 my $rs = $schema->resultset($class);
31 foreach my $row ($rs->all) {
32 my $file = file($source_dir, $row->id . '.fix');
33 my $HASH1; eval($file->slurp());
34 is_deeply($HASH1, {$row->get_columns}, "$set " . lc($class) . " row " . $row->id . " imported okay")