The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use DBIx::Class::Fixtures;
use Test::More tests => 9;

use lib qw(t/lib);
use DBICTest;
use Path::Class;
use Data::Dumper; 
use File::Spec;
use Test::TempDir::Tiny;
use IO::All;

my $tempdir = tempdir;

ok my $config_dir = io->catfile(qw't var configs')->name;
ok my $schema = DBICTest->init_schema(db_dir => $tempdir), 'got schema';
ok my $fixtures = DBIx::Class::Fixtures->new({config_dir => $config_dir}),
  'object created with correct config dir';
  

my $ret = $fixtures->dump_config_sets({
  configs => [qw[ date.json rules.json ]],
  schema => $schema,
  directory_template => sub {
      my ($fixture, $params, $set) = @_;
      File::Spec->catdir($tempdir,'multi', $set);
  },
});

ok -e io->catfile($tempdir, qw'multi date.json artist')->name,
  'artist directory created';

my $dir = dir(io->catfile($tempdir, qw'multi date.json artist')->name);
my @children = $dir->children;
is(scalar(@children), 1, 'right number of fixtures created');

my $fix_file = $children[0];
my $HASH1; eval($fix_file->slurp());
is(ref $HASH1, 'HASH', 'fixture evals into hash');

is_deeply([sort $schema->source('Artist')->columns], [sort keys %{$HASH1}], 'fixture has correct keys');

my $artist = $schema->resultset('Artist')->find($HASH1->{artistid});
is_deeply({$artist->get_columns}, $HASH1, 'dumped fixture is equivalent to artist row');

$schema->resultset('Artist')->delete; # so we can create the row again on the next line
 ok($schema->resultset('Artist')->create($HASH1), 'new dbic row created from fixture');