puppetlabs-stdlib/spec/functions/delete_at_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.1 KiB
Ruby
Executable file

require 'spec_helper'
describe 'delete_at' do
it { is_expected.not_to eq(nil) }
it { is_expected.to run.with_params().and_raise_error(Puppet::ParseError) }
it { is_expected.to run.with_params('one', 1).and_raise_error(Puppet::ParseError) }
it { is_expected.to run.with_params(1, 1).and_raise_error(Puppet::ParseError) }
it { is_expected.to run.with_params(['one'], 'two').and_raise_error(Puppet::ParseError) }
it {
pending("Current implementation ignores parameters after the first two.")
is_expected.to run.with_params(['one'], 0, 1).and_raise_error(Puppet::ParseError)
}
describe 'argument validation' do
it { is_expected.to run.with_params([0, 1, 2], 3).and_raise_error(Puppet::ParseError) }
end
it { is_expected.to run.with_params([0, 1, 2], 1).and_return([0, 2]) }
it { is_expected.to run.with_params([0, 1, 2], -1).and_return([0, 1]) }
it { is_expected.to run.with_params([0, 1, 2], -4).and_return([0, 1, 2]) }
it "should leave the original array intact" do
argument = [1, 2, 3]
original = argument.dup
result = subject.call([argument,2])
expect(argument).to eq(original)
end
end