improve diagnostics in yaml test
[p5sagit/Config-Any.git] / t / 53-perl.t
index 4914075..4e59ae7 100644 (file)
@@ -1,11 +1,60 @@
-use Test::More tests => 2;
+use strict;
+use warnings;
 
+use Test::More tests => 12;
+use Config::Any;
 use Config::Any::Perl;
 
-my $config = eval { Config::Any::Perl->load( 't/conf/conf.pl' ) };
+{
+    my $file   = 't/conf/conf.pl';
+    my $config = Config::Any::Perl->load( $file );
 
-SKIP: {
-    skip "Couldn't Load Perl plugin", 2 if $@;
     ok( $config );
     is( $config->{ name }, 'TestApp' );
+
+    my $config_load2 = Config::Any::Perl->load( $file );
+    is_deeply( $config_load2, $config, 'multiple loads of the same file' );
+}
+
+# test invalid config
+{
+    my $file = 't/invalid/conf.pl';
+    my $config;
+    my $loaded = eval {
+        $config = Config::Any::Perl->load( $file );
+        1;
+    };
+
+    ok !$loaded, 'config load failed';
+    is $config, undef, 'config load failed';
+    like $@, qr/syntax error/, 'error thrown';
+}
+
+# parse error generated on invalid config
+{
+    my $file = 't/invalid/conf.pl';
+    my $config;
+    my $loaded = eval {
+        $config = Config::Any::Perl->load( $file );
+        Config::Any->load_files( { files => [$file], use_ext => 1} );
+        1;
+    };
+
+    ok !$loaded, 'config load failed';
+    is $config, undef, 'config load failed';
+    like $@, qr/syntax error/, 'error thrown';
+}
+
+# test missing config
+{
+    my $file = 't/invalid/missing.pl';
+    my $config;
+    my $loaded = eval {
+        $config = Config::Any::Perl->load( $file );
+        1;
+    };
+
+    ok !$loaded, 'config load failed';
+    is $config, undef, 'config load failed';
+    isnt $@, '', 'error thrown';
 }