1 use DBIx::Class::Fixtures;
2 use Test::More tests => 9;
9 use Test::TempDir::Tiny;
12 my $tempdir = tempdir;
14 ok my $config_dir = io->catfile(qw't var configs')->name;
15 ok my $schema = DBICTest->init_schema(db_dir => $tempdir), 'got schema';
16 ok my $fixtures = DBIx::Class::Fixtures->new({config_dir => $config_dir}),
17 'object created with correct config dir';
20 my $ret = $fixtures->dump_config_sets({
21 configs => [qw[ date.json rules.json ]],
23 directory_template => sub {
24 my ($fixture, $params, $set) = @_;
25 File::Spec->catdir($tempdir,'multi', $set);
29 ok -e io->catfile($tempdir, qw'multi date.json artist')->name,
30 'artist directory created';
32 my $dir = dir(io->catfile($tempdir, qw'multi date.json artist')->name);
33 my @children = $dir->children;
34 is(scalar(@children), 1, 'right number of fixtures created');
36 my $fix_file = $children[0];
37 my $HASH1; eval($fix_file->slurp());
38 is(ref $HASH1, 'HASH', 'fixture evals into hash');
40 is_deeply([sort $schema->source('Artist')->columns], [sort keys %{$HASH1}], 'fixture has correct keys');
42 my $artist = $schema->resultset('Artist')->find($HASH1->{artistid});
43 is_deeply({$artist->get_columns}, $HASH1, 'dumped fixture is equivalent to artist row');
45 $schema->resultset('Artist')->delete; # so we can create the row again on the next line
46 ok($schema->resultset('Artist')->create($HASH1), 'new dbic row created from fixture');