summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeff McCune <jeff@puppetlabs.com>2012-11-26 16:34:04 -0800
committerJeff McCune <jeff@puppetlabs.com>2012-11-26 16:34:04 -0800
commit276abac257e750debe8502e67070f57bc8c79c3a (patch)
treeb2f9d204dd2c47ed389a7649c3721e06de98304a
parent0648148bfb70159dcf2eb2af3d8e67842ce96f85 (diff)
parent6f76d8dfd179d3beb73bf69d1ce31411ba3f12ed (diff)
downloadpuppet-stdlib-276abac257e750debe8502e67070f57bc8c79c3a.tar.gz
puppet-stdlib-276abac257e750debe8502e67070f57bc8c79c3a.tar.bz2
Merge branch '2.x' into 3.x
* 2.x: (#17797) min() and max() functions
-rw-r--r--lib/puppet/parser/functions/max.rb13
-rw-r--r--lib/puppet/parser/functions/min.rb13
-rwxr-xr-xspec/unit/puppet/parser/functions/max_spec.rb23
-rwxr-xr-xspec/unit/puppet/parser/functions/min_spec.rb23
4 files changed, 72 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/max.rb b/lib/puppet/parser/functions/max.rb
new file mode 100644
index 0000000..10b6f74
--- /dev/null
+++ b/lib/puppet/parser/functions/max.rb
@@ -0,0 +1,13 @@
+module Puppet::Parser::Functions
+ newfunction(:max, :type => :rvalue, :doc => <<-EOS
+ Returns the highest value of all arguments.
+ Requires at least one argument.
+ EOS
+ ) do |args|
+
+ raise(Puppet::ParseError, "max(): Wrong number of arguments " +
+ "need at least one") if args.size == 0
+
+ return args.max
+ end
+end
diff --git a/lib/puppet/parser/functions/min.rb b/lib/puppet/parser/functions/min.rb
new file mode 100644
index 0000000..abf1b62
--- /dev/null
+++ b/lib/puppet/parser/functions/min.rb
@@ -0,0 +1,13 @@
+module Puppet::Parser::Functions
+ newfunction(:min, :type => :rvalue, :doc => <<-EOS
+ Returns the lowest value of all arguments.
+ Requires at least one argument.
+ EOS
+ ) do |args|
+
+ raise(Puppet::ParseError, "min(): Wrong number of arguments " +
+ "need at least one") if args.size == 0
+
+ return args.min
+ end
+end
diff --git a/spec/unit/puppet/parser/functions/max_spec.rb b/spec/unit/puppet/parser/functions/max_spec.rb
new file mode 100755
index 0000000..604927e
--- /dev/null
+++ b/spec/unit/puppet/parser/functions/max_spec.rb
@@ -0,0 +1,23 @@
+#! /usr/bin/env ruby -S rspec
+
+require 'spec_helper'
+
+describe "the max function" do
+ let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
+
+ it "should exist" do
+ Puppet::Parser::Functions.function("max").should == "function_max"
+ end
+
+ it "should raise a ParseError if there is less than 1 arguments" do
+ lambda { scope.function_max([]) }.should( raise_error(Puppet::ParseError))
+ end
+
+ it "should be able to compare strings" do
+ scope.function_max(["albatross","dog","horse"]).should(eq("horse"))
+ end
+
+ it "should be able to compare numbers" do
+ scope.function_max([6,8,4]).should(eq(8))
+ end
+end
diff --git a/spec/unit/puppet/parser/functions/min_spec.rb b/spec/unit/puppet/parser/functions/min_spec.rb
new file mode 100755
index 0000000..781422c
--- /dev/null
+++ b/spec/unit/puppet/parser/functions/min_spec.rb
@@ -0,0 +1,23 @@
+#! /usr/bin/env ruby -S rspec
+
+require 'spec_helper'
+
+describe "the min function" do
+ let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
+
+ it "should exist" do
+ Puppet::Parser::Functions.function("min").should == "function_min"
+ end
+
+ it "should raise a ParseError if there is less than 1 arguments" do
+ lambda { scope.function_min([]) }.should( raise_error(Puppet::ParseError))
+ end
+
+ it "should be able to compare strings" do
+ scope.function_min(["albatross","dog","horse"]).should(eq("albatross"))
+ end
+
+ it "should be able to compare numbers" do
+ scope.function_min([6,8,4]).should(eq(4))
+ end
+end