Suggest different variables to use if we want to tunnel both v4 and v6
[mirror/dsa-puppet.git] / 3rdparty / modules / stdlib / spec / acceptance / parseyaml_spec.rb
old mode 100755 (executable)
new mode 100644 (file)
index 5819837..4cdf36d
@@ -1,35 +1,52 @@
-#! /usr/bin/env ruby -S rspec
 require 'spec_helper_acceptance'
 
-describe 'parseyaml function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
+describe 'parseyaml function' do
   describe 'success' do
-    it 'parses valid yaml' do
-      pp = <<-EOS
+    pp1 = <<-DOC
       $a = "---\nhunter: washere\ntests: passing\n"
       $o = parseyaml($a)
       $tests = $o['tests']
       notice(inline_template('tests are <%= @tests.inspect %>'))
-      EOS
-
-      apply_manifest(pp, :catch_failures => true) do |r|
-        expect(r.stdout).to match(/tests are "passing"/)
+    DOC
+    it 'parses valid yaml' do
+      apply_manifest(pp1, :catch_failures => true) do |r|
+        expect(r.stdout).to match(%r{tests are "passing"})
       end
     end
   end
+
   describe 'failure' do
-    it 'raises error on incorrect yaml' do
-      pp = <<-EOS
+    pp2 = <<-DOC
       $a = "---\nhunter: washere\ntests: passing\n:"
-      $o = parseyaml($a)
+      $o = parseyaml($a, {'tests' => 'using the default value'})
       $tests = $o['tests']
       notice(inline_template('tests are <%= @tests.inspect %>'))
-      EOS
+    DOC
+    it 'returns the default value on incorrect yaml' do
+      apply_manifest(pp2, :catch_failures => true) do |r|
+        expect(r.stdout).to match(%r{tests are "using the default value"})
+      end
+    end
 
-      apply_manifest(pp, :expect_failures => true) do |r|
-        expect(r.stderr).to match(/(syntax error|did not find expected key)/)
+    pp3 = <<-DOC
+      $a = "---\nhunter: washere\ntests: passing\n:"
+      $o = parseyaml($a)
+      $tests = $o['tests']
+      notice(inline_template('tests are <%= @tests.inspect %>'))
+    DOC
+    it 'raises error on incorrect yaml' do
+      apply_manifest(pp3, :expect_failures => true) do |r|
+        expect(r.stderr).to match(%r{(syntax error|did not find expected key)})
       end
     end
 
-    it 'raises error on incorrect number of arguments'
+    pp4 = <<-DOC
+      $o = parseyaml()
+    DOC
+    it 'raises error on incorrect number of arguments' do
+      apply_manifest(pp4, :expect_failures => true) do |r|
+        expect(r.stderr).to match(%r{wrong number of arguments}i)
+      end
+    end
   end
 end