2014-12-04 22:33:15 +01:00
|
|
|
#! /usr/bin/env ruby -S rspec
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe Puppet::Parser::Functions.function(:validate_numeric) do
|
|
|
|
let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
|
|
|
|
|
|
|
|
describe 'when calling validate_numeric from puppet without any argument or to many' do
|
|
|
|
it "should not compile when no argument is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric()"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /Wrong number of arguments/)
|
|
|
|
end
|
|
|
|
it "should not compile when more than three arguments are passed" do
|
|
|
|
Puppet[:code] = "validate_numeric(1, 1, 1, 1)"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /Wrong number of arguments/)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'when calling validate_numeric from puppet only with input' do
|
|
|
|
%w{ 1 -1 1.0 -1.0 }.each do |the_number|
|
|
|
|
it "should compile when #{the_number} is an encapsulated numeric" do
|
|
|
|
Puppet[:code] = "validate_numeric('#{the_number}')"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
it "should compile when #{the_number} is a bare numeric" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{the_number})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
%w{ [1,2,3,4,5] ['1','2','3','4','5'] [1.1,2.2,3.3,4.4,5.5] ['1.1','2.2','3.3','4.4','5.5'] }.each do |the_number|
|
|
|
|
it "should compile when multiple Numeric arguments are passed in an Array" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{the_number})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
%w{ true false iAmAString 1test }.each do |the_number|
|
|
|
|
it "should not compile when #{the_number} is in a string" do
|
|
|
|
Puppet[:code] = "validate_numeric('#{the_number}')"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be a Numeric/)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when #{the_number} is a bare word" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{the_number})"
|
2015-04-24 01:37:01 +02:00
|
|
|
expect { scope.compiler.compile }.to raise_error
|
2014-12-04 22:33:15 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when a Numeric is part of a larger String" do
|
|
|
|
Puppet[:code] = "validate_numeric('1.0 test')"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be a Numeric/)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when an Array with a non-Numeric value is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric([1, 'test'])"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /at array position 1 to be a Numeric/)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when a Hash is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric({ 1 => 2 })"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be a Numeric or Array/)
|
|
|
|
end
|
|
|
|
|
2015-05-27 21:05:01 +02:00
|
|
|
it "should not compile when a Hash is passed in an Array" do
|
|
|
|
Puppet[:code] = "validate_numeric([{ 1 => 2 }])"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be a Numeric/)
|
|
|
|
end
|
|
|
|
|
2014-12-04 22:33:15 +01:00
|
|
|
it "should not compile when an explicitly undef variable is passed" do
|
|
|
|
Puppet[:code] = <<-'ENDofPUPPETcode'
|
|
|
|
$foo = undef
|
|
|
|
validate_numeric($foo)
|
|
|
|
ENDofPUPPETcode
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be a Numeric/)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when an undefined variable is passed" do
|
|
|
|
Puppet[:code] = 'validate_numeric($foobarbazishouldnotexist)'
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be a Numeric/)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'when calling validate_numeric from puppet with input and a maximum' do
|
|
|
|
max = 10
|
|
|
|
%w{ 1 -1 1.0 -1.0 }.each do |the_number|
|
|
|
|
it "should compile when #{the_number} is lower than a maximum of #{max}" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{the_number},#{max})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should compile when a Numeric is equal the maximum" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{max},#{max})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when #{max+1} is greater than a maximum of #{max}" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{max+1},#{max})"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be smaller or equal to/)
|
|
|
|
end
|
|
|
|
|
|
|
|
%w{ [-10,1,2,3,4,5,10] ['-10','1','2','3','4','5','10'] }.each do |the_number|
|
|
|
|
it "should compile when each element of #{the_number} is lower than a maximum of #{max}" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{the_number},#{max})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when an element of an Array [-10,1,2,3,4,5,#{max+1}] is greater than a maximum of #{max}" do
|
|
|
|
Puppet[:code] = "validate_numeric([-10,1,2,3,4,5,#{max+1}],#{max})"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be smaller or equal to/)
|
|
|
|
end
|
|
|
|
|
|
|
|
%w{ true false iAmAString 1test }.each do |the_max|
|
|
|
|
it "should not compile when a non-Numeric maximum #{the_max}, encapsulated in a String, is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric(1,'#{the_max}')"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be unset or a Numeric/)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when a non-Numeric maximum #{the_max} bare word is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric(1,#{the_max})"
|
2015-04-24 01:37:01 +02:00
|
|
|
expect { scope.compiler.compile }.to raise_error
|
2014-12-04 22:33:15 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when an explicitly undefined variable is passed as maximum and no minimum is passed" do
|
|
|
|
Puppet[:code] = <<-'ENDofPUPPETcode'
|
|
|
|
$foo = undef
|
|
|
|
validate_numeric(10, $foo)
|
|
|
|
ENDofPUPPETcode
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be unset or a Numeric/)
|
|
|
|
end
|
|
|
|
it "should not compile when an explicitly undef is passed as maximum and no minimum is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric(10, undef)"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be unset or a Numeric/)
|
|
|
|
end
|
|
|
|
it "should not compile when an empty string is passed as maximum and no minimum is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric(10, '')"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be unset or a Numeric/)
|
|
|
|
end
|
|
|
|
it "should not compile when an undefined variable for a maximum is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric(10, $foobarbazishouldnotexist)"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be unset or a Numeric/)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'when calling validate_numeric from puppet with input, a maximum and a minimum' do
|
|
|
|
it "should not compile when a minimum larger than maximum is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric(1,1,2)"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /second argument to be larger than third argument/)
|
|
|
|
end
|
|
|
|
|
|
|
|
max = 10
|
|
|
|
min = -10
|
|
|
|
%w{ 1 -1 }.each do |the_number|
|
|
|
|
it "should compile when each element of #{the_number} is within a range from #{min} to #{max}" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{the_number},#{max},#{min})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should compile when a Numeric is equal the minimum" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{min},#{max},#{min})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should compile when a Numeric is equal the minimum and maximum" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{max},#{max},#{max})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should compile when an empty maximum is passed and the Numeric is greater than the minimum" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{max}.1,'',#{min})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
it "should compile when an explicitly undefined maximum is passed and the Numeric is greater than the minimum" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{max}.1,undef,#{min})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
it "should compile when an explicitly undefined variable is passed for maximum and the Numeric is greater than the minimum" do
|
|
|
|
Puppet[:code] = <<-"ENDofPUPPETcode"
|
|
|
|
$foo = undef
|
|
|
|
validate_numeric(#{max}.1, $foo, #{min})
|
|
|
|
ENDofPUPPETcode
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
it "should not compile when no maximum value is given and the Numeric is greater than the minimum" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{max}.1,,#{min})"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::Error, /Syntax error at ','/)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when #{min-1} is lower than a minimum of #{min}" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{min-1.0},#{max},#{min})"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be greater or equal to/)
|
|
|
|
end
|
|
|
|
|
|
|
|
%w{ [-10,1,2,3,4,5,10] ['-10.0','1','2','3','4','5','10.0'] }.each do |the_number|
|
|
|
|
it "should compile when each element of #{the_number} is within a range from #{min} to #{max}" do
|
|
|
|
Puppet[:code] = "validate_numeric(#{the_number},#{max},#{min})"
|
|
|
|
scope.compiler.compile
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when an element of an Array [#{min-1.1},1,2,3,4,5,10.0] is lower than a minimum of #{min}" do
|
|
|
|
Puppet[:code] = "validate_numeric([#{min-1},1,2,3,4,5,10],#{max},#{min})"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be greater or equal to/)
|
|
|
|
end
|
|
|
|
|
|
|
|
%w{ true false iAmAString 1test }.each do |the_min|
|
|
|
|
it "should not compile when a non-Numeric minimum #{the_min}, encapsulated in a String, is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric(1,#{max},'#{the_min}')"
|
|
|
|
expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /to be unset or a Numeric/)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not compile when a non-Numeric minimum #{the_min} bare word is passed" do
|
|
|
|
Puppet[:code] = "validate_numeric(1,#{max},#{the_min})"
|
2015-04-24 01:37:01 +02:00
|
|
|
expect { scope.compiler.compile }.to raise_error
|
2014-12-04 22:33:15 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|