puppetlabs-stdlib/spec/functions/getvar_spec.rb
David Schmitt f3e79ddcd5 Convert tests to use plain rspec-puppet
Tests in the new style produces the following documentation output:

abs
  should not eq nil
  should run abs() and raise an Puppet::ParseError
  should run abs(-34) and return 34
  should run abs("-34") and return 34
  should run abs(34) and return 34
  should run abs("34") and return 34
2015-06-01 18:02:22 +01:00

28 lines
1.2 KiB
Ruby
Executable file

require 'spec_helper'
describe 'getvar' do
it { is_expected.not_to eq(nil) }
it { is_expected.to run.with_params().and_raise_error(Puppet::ParseError, /wrong number of arguments/i) }
it { is_expected.to run.with_params('one', 'two').and_raise_error(Puppet::ParseError, /wrong number of arguments/i) }
it { is_expected.to run.with_params().and_raise_error(Puppet::ParseError, /wrong number of arguments/i) }
context 'given variables in namespaces' do
let(:pre_condition) {
<<-'ENDofPUPPETcode'
class site::data { $foo = 'baz' }
include site::data
ENDofPUPPETcode
}
it { is_expected.to run.with_params('site::data::foo').and_return('baz') }
it { is_expected.to run.with_params('::site::data::foo').and_return('baz') }
context 'with strict variable checking', :if => RSpec.configuration.strict_variables do
it { is_expected.to run.with_params('::site::data::bar').and_raise_error(ArgumentError, /undefined_variable/) }
end
context 'without strict variable checking', :unless => RSpec.configuration.strict_variables do
it { is_expected.to run.with_params('::site::data::bar').and_return(nil) }
end
end
end