diff options
author | Erik Dalén <dalen@spotify.com> | 2013-04-10 14:38:14 +0200 |
---|---|---|
committer | Erik Dalén <dalen@spotify.com> | 2013-04-10 14:39:25 +0200 |
commit | f28550e78996f908b076cdc9aebcbe584c777cd0 (patch) | |
tree | 4fa56de8a3318a65be54f77f030027069bdb4e77 /spec/unit | |
parent | 6f9361e383982c5b719bbdf17ed72b85850b9d91 (diff) |
Add a count function
Similar to the ruby count method on arrays.
Diffstat (limited to 'spec/unit')
-rw-r--r-- | spec/unit/puppet/parser/functions/count_spec.rb | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/spec/unit/puppet/parser/functions/count_spec.rb b/spec/unit/puppet/parser/functions/count_spec.rb new file mode 100644 index 0000000..5e4a8b9 --- /dev/null +++ b/spec/unit/puppet/parser/functions/count_spec.rb @@ -0,0 +1,27 @@ +#! /usr/bin/env ruby -S rspec + +require 'spec_helper' + +describe "the count function" do + let(:scope) { PuppetlabsSpec::PuppetInternals.scope } + + it "should exist" do + Puppet::Parser::Functions.function("count").should == "function_count" + end + + it "should raise a ArgumentError if there is more than 2 arguments" do + lambda { scope.function_count(['foo', 'bar', 'baz']) }.should( raise_error(ArgumentError)) + end + + it "should be able to count arrays" do + scope.function_count([["1","2","3"]]).should(eq(3)) + end + + it "should be able to count matching elements in arrays" do + scope.function_count([["1", "2", "2"], "2"]).should(eq(2)) + end + + it "should not count :undef, nil or empty strings" do + scope.function_count([["foo","bar",:undef,nil,""]]).should(eq(2)) + end +end |