summaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
authorTP Honey <tphoney@users.noreply.github.com>2016-06-30 09:55:49 +0100
committerGitHub <noreply@github.com>2016-06-30 09:55:49 +0100
commit70d543e66a9a0fdc670004784f4864e7a04dc4dc (patch)
tree450f264f6fb674a7c4be7073e98c334f11a54b9b /spec
parent50cf8bd5b77ba6353ab6477c4c76f437b834b6b0 (diff)
parentaf875b11ff284cfe2ea95d208a614576a4342b2c (diff)
Merge pull request #614 from DavidS/MODULES-3543-fix-defined_with_params
(MODULES-3543) Fix define_with_params to handle undef properly
Diffstat (limited to 'spec')
-rwxr-xr-xspec/functions/defined_with_params_spec.rb9
-rwxr-xr-xspec/functions/ensure_resource_spec.rb7
2 files changed, 16 insertions, 0 deletions
diff --git a/spec/functions/defined_with_params_spec.rb b/spec/functions/defined_with_params_spec.rb
index 516d986..e00c423 100755
--- a/spec/functions/defined_with_params_spec.rb
+++ b/spec/functions/defined_with_params_spec.rb
@@ -23,4 +23,13 @@ describe 'defined_with_params' do
it { is_expected.to run.with_params('User[dan]', {'ensure' => 'present', 'managehome' => false}).and_return(true) }
it { is_expected.to run.with_params('User[dan]', {'ensure' => 'absent', 'managehome' => false}).and_return(false) }
end
+
+ describe 'when passing undef values' do
+ let :pre_condition do
+ 'file { "/tmp/a": }'
+ end
+
+ it { is_expected.to run.with_params('File[/tmp/a]', {}).and_return(true) }
+ it { is_expected.to run.with_params('File[/tmp/a]', { 'owner' => :undef }).and_return(true) }
+ end
end
diff --git a/spec/functions/ensure_resource_spec.rb b/spec/functions/ensure_resource_spec.rb
index c4f2cbd..57b5123 100755
--- a/spec/functions/ensure_resource_spec.rb
+++ b/spec/functions/ensure_resource_spec.rb
@@ -28,6 +28,13 @@ describe 'ensure_resource' do
it { expect(lambda { catalogue }).to contain_user('username2').without_ensure }
end
+ describe 'after running ensure_resource("user", "username1", { "gid" => undef })' do
+ before { subject.call(['User', 'username1', { "gid" => :undef }]) }
+
+ # this lambda is required due to strangeness within rspec-puppet's expectation handling
+ it { expect(lambda { catalogue }).to contain_user('username1').with_ensure('present') }
+ end
+
describe 'after running ensure_resource("user", ["username1", "username2"], {})' do
before { subject.call(['User', ['username1', 'username2'], {}]) }