summaryrefslogtreecommitdiff
path: root/spec/unit
diff options
context:
space:
mode:
authorfatmcgav <gavin.williams@weareact.com>2013-02-12 15:07:18 +0000
committerJeff McCune <jeff@puppetlabs.com>2013-02-12 10:00:09 -0800
commit3cef5d9e3323115c896e76f9e217cac061ab156f (patch)
tree750b902e6ecf98bbd088001c40b9884db7ed2ae8 /spec/unit
parent8dd82d318a05c5e35bd2d8853fce8b8bf1b2c2d0 (diff)
(#19201) Add concat function to join two arrays
Without this patch applied there is no easy way to append one array to another. This is a problem because it is often desirable to join two arrays without flattening the contents into a single, one dimensional array. This patch addresses the problem by adding a `concat()` function which takes two arguments. The arguments will be concatenated together and a new array returned to the caller. Reviewed-by: Jeff McCune <jeff@puppetlabs.com>
Diffstat (limited to 'spec/unit')
-rw-r--r--spec/unit/puppet/parser/functions/concat_spec.rb15
1 files changed, 15 insertions, 0 deletions
diff --git a/spec/unit/puppet/parser/functions/concat_spec.rb b/spec/unit/puppet/parser/functions/concat_spec.rb
new file mode 100644
index 0000000..123188b
--- /dev/null
+++ b/spec/unit/puppet/parser/functions/concat_spec.rb
@@ -0,0 +1,15 @@
+#! /usr/bin/env ruby -S rspec
+require 'spec_helper'
+
+describe "the concat function" do
+ let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
+
+ it "should raise a ParseError if there is less than 1 arguments" do
+ lambda { scope.function_concat([]) }.should( raise_error(Puppet::ParseError))
+ end
+
+ it "should be able to concat an array" do
+ result = scope.function_concat([['1','2','3'],['4','5','6']])
+ result.should(eq(['1','2','3','4','5','6']))
+ end
+end