-#! /usr/bin/env ruby -S rspec
require 'spec_helper_acceptance'
-describe 'num2bool function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
+describe 'num2bool function' do
describe 'success' do
- it 'bools positive numbers and numeric strings as true' do
- pp = <<-EOS
+ pp1 = <<-DOC
$a = 1
$b = "1"
$c = "50"
notice(inline_template('a is <%= @ao.inspect %>'))
notice(inline_template('b is <%= @bo.inspect %>'))
notice(inline_template('c is <%= @co.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/a is true/)
- expect(r.stdout).to match(/b is true/)
- expect(r.stdout).to match(/c is true/)
+ DOC
+ regex_array_true = [%r{a is true}, %r{b is true}, %r{c is true}]
+ it 'bools positive numbers and numeric strings as true' do
+ apply_manifest(pp1, :catch_failures => true) do |r|
+ regex_array_true.each do |i|
+ expect(r.stdout).to match(i)
+ end
end
end
- it 'bools negative numbers as false' do
- pp = <<-EOS
+
+ pp2 = <<-DOC
$a = 0
$b = -0.1
$c = ["-50","1"]
notice(inline_template('a is <%= @ao.inspect %>'))
notice(inline_template('b is <%= @bo.inspect %>'))
notice(inline_template('c is <%= @co.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/a is false/)
- expect(r.stdout).to match(/b is false/)
- expect(r.stdout).to match(/c is false/)
+ DOC
+ regex_array_false = [%r{a is false}, %r{b is false}, %r{c is false}]
+ it 'bools negative numbers as false' do
+ apply_manifest(pp2, :catch_failures => true) do |r|
+ regex_array_false.each do |i|
+ expect(r.stdout).to match(i)
+ end
end
end
end
+
describe 'failure' do
- it 'fails on words' do
- pp = <<-EOS
+ pp3 = <<-DOC
$a = "a"
$ao = num2bool($a)
notice(inline_template('a is <%= @ao.inspect %>'))
- EOS
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/not look like a number/)
+ DOC
+ it 'fails on words' do
+ expect(apply_manifest(pp3, :expect_failures => true).stderr).to match(%r{not look like a number})
end
- it 'fails on numberwords' do
- pp = <<-EOS
+ pp4 = <<-DOC
$b = "1b"
$bo = num2bool($b)
notice(inline_template('b is <%= @bo.inspect %>'))
- EOS
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/not look like a number/)
-
+ DOC
+ it 'fails on numberwords' do
+ expect(apply_manifest(pp4, :expect_failures => true).stderr).to match(%r{not look like a number})
end
- it 'fails on non-numeric/strings' do
- pending "The function will call .to_s.to_i on anything not a Numeric or
- String, and results in 0. Is this intended?"
- pp = <<-EOS
+ pp5 = <<-DOC # rubocop:disable Lint/UselessAssignment
$c = {"c" => "-50"}
$co = num2bool($c)
notice(inline_template('c is <%= @co.inspect %>'))
- EOS
- expect(apply_manifest(ppc :expect_failures => true).stderr).to match(/Unable to parse/)
+ DOC
+ it 'fails on non-numeric/strings' do
+ pending "The function will call .to_s.to_i on anything not a Numeric or
+ String, and results in 0. Is this intended?"
+ expect(apply_manifest(pp5(:expect_failures => true)).stderr).to match(%r{Unable to parse})
end
end
end