improve diagnostics in yaml test
[p5sagit/Config-Any.git] / t / 55-yaml.t
index 3c95831..907d576 100644 (file)
@@ -1,14 +1,26 @@
 use strict;
 use warnings;
+no warnings 'once';
 
 use Test::More;
+use Config::Any;
 use Config::Any::YAML;
+use Data::Dumper;
 
-if ( !Config::Any::YAML->is_supported ) {
+sub _dump {
+  local $Data::Dumper::Terse = 1;
+  local $Data::Dumper::Sortkeys = 1;
+  local $Data::Dumper::Indent = 1;
+  my $out = Data::Dumper::Dumper(@_);
+  $out =~ s/\s*\z//;
+  $out eq 'undef' ? undef : $out;
+}
+
+if ( !Config::Any::YAML->is_supported && !$ENV{RELEASE_TESTING} ) {
     plan skip_all => 'YAML format not supported';
 }
 else {
-    plan tests => 2;
+    plan tests => 6;
 }
 
 {
@@ -16,3 +28,22 @@ else {
     ok( $config );
     is( $config->{ name }, 'TestApp' );
 }
+
+# test invalid config
+{
+    my $file = 't/invalid/conf.yml';
+    my $config = eval { Config::Any::YAML->load( $file ) };
+
+
+    is _dump($config), undef, 'config load failed';
+    isnt $@, '', 'error thrown';
+}
+
+# parse error generated on invalid config
+{
+    my $file = 't/invalid/conf.yml';
+    my $config = eval { Config::Any->load_files( { files => [$file], use_ext => 1} ) };
+
+    is _dump($config), undef, 'config load failed';
+    isnt $@, '', 'error thrown';
+}