aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorintrigeri <intrigeri@boum.org>2010-12-16 13:58:10 +0100
committerintrigeri <intrigeri@boum.org>2010-12-16 13:58:10 +0100
commit5d7667b8d00cc3fc6cfa75a0413076db1dd0cff8 (patch)
treefa2369ce8c2c2579a50c7505d91fedd894c32c80
parentf61a347d84d0b47f0e32cd4746c77e61c44c4ac4 (diff)
parent7abdda7b1ef097f374bdf52c99c2e66c7346543e (diff)
downloadpuppet-common-5d7667b8d00cc3fc6cfa75a0413076db1dd0cff8.tar.gz
puppet-common-5d7667b8d00cc3fc6cfa75a0413076db1dd0cff8.tar.bz2
Merge remote branch 'immerda/master'
-rw-r--r--lib/puppet/parser/functions/array_include.rb11
-rw-r--r--spec/unit/parser/functions/array_include.rb33
2 files changed, 44 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/array_include.rb b/lib/puppet/parser/functions/array_include.rb
new file mode 100644
index 0000000..ce4748d
--- /dev/null
+++ b/lib/puppet/parser/functions/array_include.rb
@@ -0,0 +1,11 @@
+Puppet::Parser::Functions::newfunction(
+ :array_include,
+ :type => :rvalue,
+ :doc => "Checks whether an item is included or not
+
+ Example: array_include(['a','b'],'b') -> true
+ Example: array_include(['a','b'],'c') -> false"
+) do |args|
+ raise Puppet::ParseError, 'array_include() needs two arguments' if args.length != 2
+ args[0].include?(args[1])
+end
diff --git a/spec/unit/parser/functions/array_include.rb b/spec/unit/parser/functions/array_include.rb
new file mode 100644
index 0000000..fecf495
--- /dev/null
+++ b/spec/unit/parser/functions/array_include.rb
@@ -0,0 +1,33 @@
+#! /usr/bin/env ruby
+
+require File.dirname(__FILE__) + '/../../../spec_helper'
+
+describe "the array_include function" do
+
+ before :each do
+ @scope = Puppet::Parser::Scope.new
+ end
+
+ it "should exist" do
+ Puppet::Parser::Functions.function("array_include").should == "function_array_include"
+ end
+
+ it "should raise a ParseError if there is less than 2 arguments" do
+ lambda { @scope.function_array_include(["foo"]) }.should( raise_error(Puppet::ParseError))
+ end
+
+ it "should raise a ParseError if there is more than 2 arguments" do
+ lambda { @scope.function_array_include(["foo", "bar", "gazonk"]) }.should( raise_error(Puppet::ParseError))
+ end
+
+ it "should return true if an item is present in the array" do
+ result = @scope.function_array_include(['a','b'],'b')
+ result.should == true
+ end
+
+ it "should return false if an item is not present" do
+ result = @scope.function_array_include(['a','b'],'c')
+ result.should == false
+ end
+
+end