]> git.donarmstrong.com Git - dsa-puppet.git/blob - 3rdparty/modules/stdlib/spec/functions/values_at_spec.rb
upgrade to stdlib 4.6.1
[dsa-puppet.git] / 3rdparty / modules / stdlib / spec / functions / values_at_spec.rb
1 #! /usr/bin/env ruby -S rspec
2 require 'spec_helper'
3
4 describe "the values_at function" do
5   let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
6
7   it "should exist" do
8     expect(Puppet::Parser::Functions.function("values_at")).to eq("function_values_at")
9   end
10
11   it "should raise a ParseError if there is less than 1 arguments" do
12     expect { scope.function_values_at([]) }.to( raise_error(Puppet::ParseError))
13   end
14
15   it "should raise a ParseError if you try to use a range where stop is greater then start" do
16     expect { scope.function_values_at([['a','b'],["3-1"]]) }.to( raise_error(Puppet::ParseError))
17   end
18
19   it "should return a value at from an array" do
20     result = scope.function_values_at([['a','b','c'],"1"])
21     expect(result).to(eq(['b']))
22   end
23
24   it "should return a value at from an array when passed a range" do
25     result = scope.function_values_at([['a','b','c'],"0-1"])
26     expect(result).to(eq(['a','b']))
27   end
28
29   it "should return chosen values from an array when passed number of indexes" do
30     result = scope.function_values_at([['a','b','c'],["0","2"]])
31     expect(result).to(eq(['a','c']))
32   end
33
34   it "should return chosen values from an array when passed ranges and multiple indexes" do
35     result = scope.function_values_at([['a','b','c','d','e','f','g'],["0","2","4-5"]])
36     expect(result).to(eq(['a','c','e','f']))
37   end
38 end