summaryrefslogtreecommitdiff
path: root/spec/functions/ensure_resource_spec.rb
diff options
context:
space:
mode:
authorAlex Cline <acline@us.ibm.com>2013-05-03 15:47:27 -0400
committerAlex Cline <acline@us.ibm.com>2013-05-03 15:47:27 -0400
commite08734af5a38cb9ad4bc2323104a1a8a76019bb8 (patch)
tree56c8ac9c38e052a56498bf22680e462aa8617b3d /spec/functions/ensure_resource_spec.rb
parent0c68ff6d66960424567f15711cb20b674fc60054 (diff)
(#20548) Allow an array of resource titles to be passed into the ensure_resource function
This patch allows an array of resource titles to be passed into the ensure_resource function. Each item in the array will be checked for existence and will be created if it doesn't already exist.
Diffstat (limited to 'spec/functions/ensure_resource_spec.rb')
-rw-r--r--spec/functions/ensure_resource_spec.rb35
1 files changed, 35 insertions, 0 deletions
diff --git a/spec/functions/ensure_resource_spec.rb b/spec/functions/ensure_resource_spec.rb
index 611666e..abd8719 100644
--- a/spec/functions/ensure_resource_spec.rb
+++ b/spec/functions/ensure_resource_spec.rb
@@ -37,4 +37,39 @@ describe 'ensure_resource' do
).and_raise_error(Puppet::Error)
end
end
+
+ describe 'when an array of new resources are passed in' do
+ it do
+ should run.with_params('User', ['dan', 'alex'], {})
+ compiler.catalog.resource('User[dan]').to_s.should == 'User[dan]'
+ compiler.catalog.resource('User[alex]').to_s.should == 'User[alex]'
+ end
+ end
+
+ describe 'when an array of existing resources is compared against existing resources' do
+ let :pre_condition do
+ 'user { "dan": ensure => present; "alex": ensure => present }'
+ end
+ it do
+ should run.with_params('User', ['dan', 'alex'], {})
+ compiler.catalog.resource('User[dan]').to_s.should == 'User[dan]'
+ compiler.catalog.resource('User[alex]').to_s.should == 'User[alex]'
+ end
+ end
+
+ describe 'when compared against existing resources with attributes' do
+ let :pre_condition do
+ 'user { "dan": ensure => present; "alex": ensure => present }'
+ end
+ it do
+ # These should not fail
+ should run.with_params('User', ['dan', 'alex'], {})
+ should run.with_params('User', ['dan', 'alex'], '')
+ should run.with_params('User', ['dan', 'alex'], {'ensure' => 'present'})
+ # This should fail
+ should run.with_params('User', ['dan', 'alex'],
+ {'ensure' => 'absent'}
+ ).and_raise_error(Puppet::Error)
+ end
+ end
end