+ let(:is_puppet_6_or_greater) { Puppet::Util::Package.versioncmp(Puppet.version, '6.0.0') >= 0 }
+ let(:undef_value) { is_puppet_6_or_greater ? nil : :undef } # even if :undef would work on 6.0.1, :undef should not be used
+
+ it { is_expected.to run.with_params('File[/tmp/a]', {}).and_return(true) }
+ it { is_expected.to run.with_params('File[/tmp/a]', 'ensure' => 'present', 'owner' => undef_value).and_return(true) }
+ end
+
+ describe 'when the reference is a' do
+ let :pre_condition do
+ 'user { "dan": }'
+ end
+
+ context 'with reference' do
+ it { is_expected.to run.with_params(Puppet::Resource.new('User[dan]'), {}).and_return(true) }
+ end
+ if Puppet::Util::Package.versioncmp(Puppet.version, '4.6.0') >= 0
+ context 'with array' do
+ it 'fails' do
+ expect {
+ subject.execute(['User[dan]'], {})
+ }.to raise_error(ArgumentError, %r{not understood: 'Array'})
+ end
+ end
+ end
+ end
+
+ describe 'when passed a defined type' do
+ let :pre_condition do
+ 'define test::deftype() { } test::deftype { "foo": }'
+ end
+
+ it { is_expected.to run.with_params('Test::Deftype[foo]', {}).and_return(true) }
+ it { is_expected.to run.with_params('Test::Deftype[bar]', {}).and_return(false) }
+ it { is_expected.to run.with_params(Puppet::Resource.new('Test::Deftype[foo]'), {}).and_return(true) }
+ it { is_expected.to run.with_params(Puppet::Resource.new('Test::Deftype[bar]'), {}).and_return(false) }
+ end
+
+ describe 'when passed a class' do
+ let :pre_condition do
+ 'class test () { } class { "test": }'
+ end
+
+ it { is_expected.to run.with_params('Class[test]', {}).and_return(true) }
+ it { is_expected.to run.with_params('Class["bar"]', {}).and_return(false) }
+ it { is_expected.to run.with_params('Class[bar]', {}).and_return(false) }
+ it { is_expected.to run.with_params(Puppet::Resource.new('class', 'test'), {}).and_return(true) }
+ it { is_expected.to run.with_params(Puppet::Resource.new('Class["bar"]'), {}).and_return(false) }
+ it { is_expected.to run.with_params(Puppet::Resource.new('Class[bar]'), {}).and_return(false) }