tests: init_schema now accepts a db_dir parameter
[dbsrgits/DBIx-Class-Fixtures.git] / t / 17-dump_all_config_sets.t
CommitLineData
5cc47846 1use DBIx::Class::Fixtures;
281f2645 2use Test::More tests => 9;
5cc47846 3
4use lib qw(t/lib);
5use DBICTest;
6use Path::Class;
7use Data::Dumper;
8use File::Spec;
66d02e24 9use IO::All;
5cc47846 10
66d02e24 11ok my $config_dir = io->catfile(qw't var configs')->name;
5cc47846 12ok my $schema = DBICTest->init_schema(), 'got schema';
13ok my $fixtures = DBIx::Class::Fixtures->new({config_dir => $config_dir}),
14 'object created with correct config dir';
15
281f2645 16
17my $ret = $fixtures->dump_config_sets({
66d02e24 18 configs => [qw[ date.json rules.json ]],
281f2645 19 schema => $schema,
20 directory_template => sub {
21 my ($fixture, $params, $set) = @_;
22 File::Spec->catdir('t','var','fixtures','multi', $set);
23 },
24});
25
66d02e24 26ok -e io->catfile(qw't var fixtures multi date.json artist')->name,
281f2645 27 'artist directory created';
28
66d02e24 29my $dir = dir(io->catfile(qw't var fixtures multi date.json artist')->name);
281f2645 30my @children = $dir->children;
31is(scalar(@children), 1, 'right number of fixtures created');
32
33my $fix_file = $children[0];
34my $HASH1; eval($fix_file->slurp());
35is(ref $HASH1, 'HASH', 'fixture evals into hash');
36
37is_deeply([sort $schema->source('Artist')->columns], [sort keys %{$HASH1}], 'fixture has correct keys');
38
39my $artist = $schema->resultset('Artist')->find($HASH1->{artistid});
40is_deeply({$artist->get_columns}, $HASH1, 'dumped fixture is equivalent to artist row');
41
42$schema->resultset('Artist')->delete; # so we can create the row again on the next line
43 ok($schema->resultset('Artist')->create($HASH1), 'new dbic row created from fixture');
44
5cc47846 45
46