test for inline config people/jnap/excludes_from_dump
John Napiorkowski [Sun, 20 Feb 2011 23:04:30 +0000 (18:04 -0500)]
t/02-dump-basic.t

index cf2b7c9..62a156e 100644 (file)
@@ -1,7 +1,7 @@
 #!perl
 
 use DBIx::Class::Fixtures;
-use Test::More tests => 9;
+use Test::More tests => 17;
 use lib qw(t/lib);
 use DBICTest;
 use Path::Class;
@@ -12,25 +12,67 @@ ok(my $schema = DBICTest->init_schema(), 'got schema');
 
 my $config_dir = 't/var/configs';
 
-# do dump
-ok(my $fixtures = DBIx::Class::Fixtures->new({ config_dir => $config_dir, debug => 0 }), 'object created with correct config dir');
-ok($fixtures->dump({ config => 'simple.json', schema => $schema, directory => 't/var/fixtures' }), 'simple dump executed okay');
+{
+    # do dump
+    ok(my $fixtures = DBIx::Class::Fixtures->new({ config_dir => $config_dir, debug => 0 }), 'object created with correct config dir');
+    ok($fixtures->dump({ config => 'simple.json', schema => $schema, directory => 't/var/fixtures' }), 'simple dump executed okay');
 
-# check dump is okay
-my $dir = dir('t/var/fixtures/artist');
-ok(-e 't/var/fixtures/artist', 'artist directory created');
+    # check dump is okay
+    my $dir = dir('t/var/fixtures/artist');
+    ok(-e 't/var/fixtures/artist', 'artist directory created');
 
-my @children = $dir->children;
-is(scalar(@children), 1, 'right number of fixtures created');
+    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');
+    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');
+    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');
+    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');
+    $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');
+}
+
+{
+    # do dump with hashref config
+    ok(my $fixtures = DBIx::Class::Fixtures->new({ config_dir => $config_dir, debug => 0 }), 'object created with correct config dir');
+    ok($fixtures->dump({
+        config => {
+            "might_have" => {
+                "fetch" => 0
+            },
+            "has_many" => {
+                "fetch" => 0
+            },
+            "sets" => [{
+                "class" => "Artist",
+                "quantity" => 1
+            }]
+        },
+        schema => $schema, 
+        directory => 't/var/fixtures',
+    }), 'simple dump executed okay');
+
+    # check dump is okay
+    my $dir = dir('t/var/fixtures/artist');
+    ok(-e 't/var/fixtures/artist', 'artist directory created');
+
+    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');
+}