summaryrefslogtreecommitdiff
path: root/spec/functions/has_key_spec.rb
blob: 6b718005aaab92368aa17ff7956e7c281be242d2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#! /usr/bin/env ruby -S rspec
require 'spec_helper'

describe Puppet::Parser::Functions.function(:has_key) do
  let(:scope) { PuppetlabsSpec::PuppetInternals.scope }

  describe 'when calling has_key from puppet' do
    it "should not compile when no arguments are passed" do
      skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
      Puppet[:code] = '$x = has_key()'
      expect {
        scope.compiler.compile
      }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
    end

    it "should not compile when 1 argument is passed" do
      skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
      Puppet[:code] = "$x = has_key('foo')"
      expect {
        scope.compiler.compile
      }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
    end

    it "should require the first value to be a Hash" do
      skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
      Puppet[:code] = "$x = has_key('foo', 'bar')"
      expect {
        scope.compiler.compile
      }.to raise_error(Puppet::ParseError, /expects the first argument to be a hash/)
    end
  end

  describe 'when calling the function has_key from a scope instance' do
    it 'should detect existing keys' do
      expect(scope.function_has_key([{'one' => 1}, 'one'])).to be_truthy
    end

    it 'should detect existing keys' do
      expect(scope.function_has_key([{'one' => 1}, 'two'])).to be_falsey
    end
  end
end