summaryrefslogtreecommitdiff
path: root/spec/classes
diff options
context:
space:
mode:
authorDavid Schmitt <david.schmitt@puppet.com>2016-08-14 13:50:22 +0100
committerGitHub <noreply@github.com>2016-08-14 13:50:22 +0100
commit1d9d2c02d6669d4a6219140ae7ff3648a30c89cf (patch)
tree709bcf434658a291ce9a87e3bc4639992141725b /spec/classes
parentf9c74fb04ecb9daccfa8b35b854ffd0601187a16 (diff)
parentadf922c28441bc95f5cbac1f0951256c080b3298 (diff)
Merge pull request #630 from HelenCampbell/validateLegacy
(MODULES-3540) Addition of validate legacy function
Diffstat (limited to 'spec/classes')
-rw-r--r--spec/classes/validate_legacy_spec.rb39
1 files changed, 39 insertions, 0 deletions
diff --git a/spec/classes/validate_legacy_spec.rb b/spec/classes/validate_legacy_spec.rb
new file mode 100644
index 0000000..ded6890
--- /dev/null
+++ b/spec/classes/validate_legacy_spec.rb
@@ -0,0 +1,39 @@
+require 'spec_helper'
+
+if Puppet.version.to_f >= 4.0
+ # validate_legacy requires a proper scope to run, so we have to trigger a true compilation here,
+ # instead of being able to leverage the function test group.
+ describe 'test::validate_legacy', type: :class do
+
+ describe 'validate_legacy passes assertion of type but not previous validation' do
+ let(:params) {{ type: "Optional[Integer]", prev_validation: "validate_re", value: 5, previous_arg1: ["^\\d+$", ""] }}
+ it {
+ Puppet.expects(:warn).with(includes('Accepting previously invalid value for target_type'))
+ is_expected.to compile
+ }
+ end
+
+ describe 'validate_legacy passes assertion of type and previous validation' do
+ let(:params) {{ type: "Optional[String]", prev_validation: "validate_re", value: "5", previous_arg1: ["."] }}
+ it { is_expected.to compile }
+ end
+
+ describe 'validate_legacy fails assertion of type and passes previous validation' do
+ let(:params) {{ type: "Optional[Integer]", prev_validation: "validate_re", value: "5", previous_arg1: ["."] }}
+ it {
+ Puppet.expects(:warn).with(includes('expected'))
+ is_expected.to compile
+ }
+ end
+
+ describe 'validate_legacy fails assertion and fails previous validation' do
+ let(:params) {{ type: "Optional[Integer]", prev_validation: "validate_re", value: "5", previous_arg1: ["thisisnotright"] }}
+ it { is_expected.to compile.and_raise_error(/Error while evaluating a Function Call, \w* expected an \w* value, got \w*/) }
+ end
+
+ describe 'validate_legacy works with multi-argument validate_ functions' do
+ let(:params) {{ type: "Integer", prev_validation: "validate_integer", value: 10, previous_arg1: 100, previous_arg2: 0 }}
+ it { is_expected.to compile }
+ end
+ end
+end