summaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
Diffstat (limited to 'spec')
-rwxr-xr-xspec/acceptance/abs_spec.rb30
-rwxr-xr-xspec/acceptance/any2array_spec.rb49
-rwxr-xr-xspec/acceptance/base64_spec.rb18
-rwxr-xr-xspec/acceptance/bool2num_spec.rb34
-rwxr-xr-xspec/acceptance/build_csv.rb83
-rwxr-xr-xspec/acceptance/capitalize_spec.rb33
-rwxr-xr-xspec/acceptance/chomp_spec.rb21
-rwxr-xr-xspec/acceptance/chop_spec.rb45
-rwxr-xr-xspec/acceptance/concat_spec.rb40
-rwxr-xr-xspec/acceptance/count_spec.rb30
-rwxr-xr-xspec/acceptance/deep_merge_spec.rb20
-rwxr-xr-xspec/acceptance/defined_with_params_spec.rb22
-rwxr-xr-xspec/acceptance/delete_at_spec.rb19
-rwxr-xr-xspec/acceptance/delete_spec.rb19
-rwxr-xr-xspec/acceptance/delete_undef_values_spec.rb19
-rwxr-xr-xspec/acceptance/delete_values_spec.rb25
-rwxr-xr-xspec/acceptance/difference_spec.rb26
-rwxr-xr-xspec/acceptance/dirname_spec.rb42
-rwxr-xr-xspec/acceptance/downcase_spec.rb39
-rwxr-xr-xspec/acceptance/empty_spec.rb39
-rwxr-xr-xspec/acceptance/ensure_packages_spec.rb22
-rwxr-xr-xspec/acceptance/ensure_resource_spec.rb22
-rwxr-xr-xspec/acceptance/flatten_spec.rb39
-rwxr-xr-xspec/acceptance/floor_spec.rb39
-rwxr-xr-xspec/acceptance/fqdn_rotate_spec.rb47
-rwxr-xr-xspec/acceptance/get_module_path_spec.rb27
-rwxr-xr-xspec/acceptance/getparam_spec.rb24
-rwxr-xr-xspec/acceptance/getvar_spec.rb26
-rwxr-xr-xspec/acceptance/grep_spec.rb26
-rwxr-xr-xspec/acceptance/has_interface_with_spec.rb54
-rwxr-xr-xspec/acceptance/has_ip_address_spec.rb33
-rwxr-xr-xspec/acceptance/has_ip_network_spec.rb33
-rwxr-xr-xspec/acceptance/has_key_spec.rb41
-rwxr-xr-xspec/acceptance/hash_spec.rb26
-rwxr-xr-xspec/acceptance/intersection_spec.rb27
-rwxr-xr-xspec/acceptance/is_array_spec.rb67
-rwxr-xr-xspec/acceptance/is_bool_spec.rb81
-rwxr-xr-xspec/acceptance/is_domain_name_spec.rb83
-rwxr-xr-xspec/acceptance/is_float_spec.rb86
-rwxr-xr-xspec/acceptance/is_function_available_spec.rb58
-rwxr-xr-xspec/acceptance/is_hash_spec.rb63
-rwxr-xr-xspec/acceptance/is_integer_spec.rb95
-rwxr-xr-xspec/acceptance/is_ip_address_spec.rb80
-rwxr-xr-xspec/acceptance/is_mac_address_spec.rb38
-rwxr-xr-xspec/acceptance/is_numeric_spec.rb95
-rwxr-xr-xspec/acceptance/is_string_spec.rb102
-rwxr-xr-xspec/acceptance/join_keys_to_values_spec.rb24
-rwxr-xr-xspec/acceptance/join_spec.rb26
-rwxr-xr-xspec/acceptance/keys_spec.rb23
-rw-r--r--spec/acceptance/loadyaml_spec.rb33
-rwxr-xr-xspec/acceptance/lstrip_spec.rb34
-rwxr-xr-xspec/acceptance/max_spec.rb20
-rwxr-xr-xspec/acceptance/member_spec.rb54
-rwxr-xr-xspec/acceptance/merge_spec.rb23
-rwxr-xr-xspec/acceptance/min_spec.rb20
-rw-r--r--spec/acceptance/nodesets/centos-59-x64.yml10
-rw-r--r--spec/acceptance/nodesets/centos-6-vcloud.yml15
-rw-r--r--spec/acceptance/nodesets/centos-64-x64-pe.yml12
-rw-r--r--spec/acceptance/nodesets/centos-64-x64.yml10
-rw-r--r--spec/acceptance/nodesets/centos-65-x64.yml10
-rw-r--r--spec/acceptance/nodesets/default.yml10
-rw-r--r--spec/acceptance/nodesets/fedora-18-x64.yml10
-rw-r--r--spec/acceptance/nodesets/sles-11-x64.yml10
-rw-r--r--spec/acceptance/nodesets/ubuntu-server-10044-x64.yml10
-rw-r--r--spec/acceptance/nodesets/ubuntu-server-12042-x64.yml10
-rw-r--r--spec/acceptance/nodesets/ubuntu-server-1404-x64.yml11
-rw-r--r--spec/acceptance/nodesets/windows-2003-i386.yml26
-rw-r--r--spec/acceptance/nodesets/windows-2003-x86_64.yml26
-rw-r--r--spec/acceptance/nodesets/windows-2008-x86_64.yml26
-rw-r--r--spec/acceptance/nodesets/windows-2008r2-x86_64.yml26
-rw-r--r--spec/acceptance/nodesets/windows-2012-x86_64.yml26
-rw-r--r--spec/acceptance/nodesets/windows-2012r2-x86_64.yml26
-rwxr-xr-xspec/acceptance/num2bool_spec.rb76
-rwxr-xr-xspec/acceptance/parsejson_spec.rb34
-rwxr-xr-xspec/acceptance/parseyaml_spec.rb35
-rwxr-xr-xspec/acceptance/pick_default_spec.rb54
-rwxr-xr-xspec/acceptance/pick_spec.rb44
-rwxr-xr-xspec/acceptance/prefix_spec.rb42
-rwxr-xr-xspec/acceptance/range_spec.rb36
-rwxr-xr-xspec/acceptance/reject_spec.rb42
-rwxr-xr-xspec/acceptance/reverse_spec.rb23
-rwxr-xr-xspec/acceptance/rstrip_spec.rb34
-rwxr-xr-xspec/acceptance/shuffle_spec.rb34
-rwxr-xr-xspec/acceptance/size_spec.rb55
-rwxr-xr-xspec/acceptance/sort_spec.rb34
-rwxr-xr-xspec/acceptance/squeeze_spec.rb47
-rwxr-xr-xspec/acceptance/str2bool_spec.rb31
-rwxr-xr-xspec/acceptance/str2saltedsha512_spec.rb22
-rwxr-xr-xspec/acceptance/strftime_spec.rb22
-rwxr-xr-xspec/acceptance/strip_spec.rb34
-rwxr-xr-xspec/acceptance/suffix_spec.rb42
-rwxr-xr-xspec/acceptance/swapcase_spec.rb22
-rwxr-xr-xspec/acceptance/time_spec.rb36
-rwxr-xr-xspec/acceptance/to_bytes_spec.rb27
-rwxr-xr-xspec/acceptance/type_spec.rb37
-rwxr-xr-xspec/acceptance/union_spec.rb24
-rwxr-xr-xspec/acceptance/unique_spec.rb33
-rwxr-xr-xspec/acceptance/unsupported_spec.rb11
-rwxr-xr-xspec/acceptance/upcase_spec.rb33
-rwxr-xr-xspec/acceptance/uriescape_spec.rb23
-rwxr-xr-xspec/acceptance/validate_absolute_path_spec.rb31
-rwxr-xr-xspec/acceptance/validate_array_spec.rb37
-rwxr-xr-xspec/acceptance/validate_augeas_spec.rb63
-rwxr-xr-xspec/acceptance/validate_bool_spec.rb37
-rwxr-xr-xspec/acceptance/validate_cmd_spec.rb52
-rwxr-xr-xspec/acceptance/validate_hash_spec.rb37
-rwxr-xr-xspec/acceptance/validate_ipv4_address_spec.rb31
-rwxr-xr-xspec/acceptance/validate_ipv6_address_spec.rb31
-rwxr-xr-xspec/acceptance/validate_re_spec.rb47
-rwxr-xr-xspec/acceptance/validate_slength_spec.rb72
-rwxr-xr-xspec/acceptance/validate_string_spec.rb36
-rwxr-xr-xspec/acceptance/values_at_spec.rb73
-rwxr-xr-xspec/acceptance/values_spec.rb35
-rwxr-xr-xspec/acceptance/zip_spec.rb86
-rwxr-xr-xspec/classes/anchor_spec.rb30
-rw-r--r--spec/fixtures/dscacheutil/root8
-rwxr-xr-xspec/functions/abs_spec.rb25
-rwxr-xr-xspec/functions/any2array_spec.rb55
-rwxr-xr-xspec/functions/base64_spec.rb34
-rwxr-xr-xspec/functions/bool2num_spec.rb38
-rwxr-xr-xspec/functions/capitalize_spec.rb28
-rwxr-xr-xspec/functions/chomp_spec.rb28
-rwxr-xr-xspec/functions/chop_spec.rb28
-rwxr-xr-xspec/functions/concat_spec.rb50
-rwxr-xr-xspec/functions/count_spec.rb31
-rwxr-xr-xspec/functions/deep_merge_spec.rb105
-rwxr-xr-xspec/functions/defined_with_params_spec.rb37
-rwxr-xr-xspec/functions/delete_at_spec.rb25
-rwxr-xr-xspec/functions/delete_spec.rb61
-rwxr-xr-xspec/functions/delete_undef_values_spec.rb41
-rwxr-xr-xspec/functions/delete_values_spec.rb36
-rwxr-xr-xspec/functions/difference_spec.rb19
-rwxr-xr-xspec/functions/dirname_spec.rb24
-rwxr-xr-xspec/functions/downcase_spec.rb33
-rwxr-xr-xspec/functions/empty_spec.rb32
-rwxr-xr-xspec/functions/ensure_packages_spec.rb81
-rwxr-xr-xspec/functions/ensure_resource_spec.rb113
-rwxr-xr-xspec/functions/flatten_spec.rb27
-rwxr-xr-xspec/functions/floor_spec.rb39
-rwxr-xr-xspec/functions/fqdn_rotate_spec.rb43
-rwxr-xr-xspec/functions/get_module_path_spec.rb46
-rwxr-xr-xspec/functions/getparam_spec.rb76
-rwxr-xr-xspec/functions/getvar_spec.rb37
-rwxr-xr-xspec/functions/grep_spec.rb19
-rwxr-xr-xspec/functions/has_interface_with_spec.rb64
-rwxr-xr-xspec/functions/has_ip_address_spec.rb39
-rwxr-xr-xspec/functions/has_ip_network_spec.rb36
-rwxr-xr-xspec/functions/has_key_spec.rb42
-rwxr-xr-xspec/functions/hash_spec.rb19
-rwxr-xr-xspec/functions/intersection_spec.rb19
-rwxr-xr-xspec/functions/is_array_spec.rb29
-rwxr-xr-xspec/functions/is_bool_spec.rb44
-rwxr-xr-xspec/functions/is_domain_name_spec.rb64
-rwxr-xr-xspec/functions/is_float_spec.rb33
-rwxr-xr-xspec/functions/is_function_available.rb31
-rwxr-xr-xspec/functions/is_hash_spec.rb29
-rwxr-xr-xspec/functions/is_integer_spec.rb69
-rwxr-xr-xspec/functions/is_ip_address_spec.rb39
-rwxr-xr-xspec/functions/is_mac_address_spec.rb29
-rwxr-xr-xspec/functions/is_numeric_spec.rb119
-rwxr-xr-xspec/functions/is_string_spec.rb34
-rwxr-xr-xspec/functions/join_keys_to_values_spec.rb40
-rwxr-xr-xspec/functions/join_spec.rb19
-rwxr-xr-xspec/functions/keys_spec.rb21
-rwxr-xr-xspec/functions/loadyaml_spec.rb25
-rwxr-xr-xspec/functions/lstrip_spec.rb28
-rwxr-xr-xspec/functions/max_spec.rb27
-rwxr-xr-xspec/functions/member_spec.rb34
-rwxr-xr-xspec/functions/merge_spec.rb52
-rwxr-xr-xspec/functions/min_spec.rb27
-rwxr-xr-xspec/functions/num2bool_spec.rb67
-rwxr-xr-xspec/functions/parsejson_spec.rb22
-rwxr-xr-xspec/functions/parseyaml_spec.rb24
-rwxr-xr-xspec/functions/pick_default_spec.rb58
-rwxr-xr-xspec/functions/pick_spec.rb34
-rwxr-xr-xspec/functions/prefix_spec.rb28
-rwxr-xr-xspec/functions/private_spec.rb55
-rwxr-xr-xspec/functions/range_spec.rb86
-rwxr-xr-xspec/functions/reject_spec.rb20
-rwxr-xr-xspec/functions/reverse_spec.rb28
-rwxr-xr-xspec/functions/rstrip_spec.rb33
-rwxr-xr-xspec/functions/shuffle_spec.rb33
-rwxr-xr-xspec/functions/size_spec.rb24
-rwxr-xr-xspec/functions/sort_spec.rb24
-rwxr-xr-xspec/functions/squeeze_spec.rb24
-rwxr-xr-xspec/functions/str2bool_spec.rb31
-rwxr-xr-xspec/functions/str2saltedsha512_spec.rb45
-rwxr-xr-xspec/functions/strftime_spec.rb29
-rwxr-xr-xspec/functions/strip_spec.rb27
-rwxr-xr-xspec/functions/suffix_spec.rb27
-rwxr-xr-xspec/functions/swapcase_spec.rb28
-rwxr-xr-xspec/functions/time_spec.rb29
-rwxr-xr-xspec/functions/to_bytes_spec.rb83
-rw-r--r--spec/functions/type3x_spec.rb43
-rwxr-xr-xspec/functions/type_spec.rb44
-rwxr-xr-xspec/functions/union_spec.rb19
-rwxr-xr-xspec/functions/unique_spec.rb33
-rwxr-xr-xspec/functions/upcase_spec.rb33
-rwxr-xr-xspec/functions/uriescape_spec.rb33
-rwxr-xr-xspec/functions/validate_absolute_path_spec.rb104
-rwxr-xr-xspec/functions/validate_array_spec.rb38
-rwxr-xr-xspec/functions/validate_augeas_spec.rb103
-rwxr-xr-xspec/functions/validate_bool_spec.rb51
-rwxr-xr-xspec/functions/validate_cmd_spec.rb85
-rwxr-xr-xspec/functions/validate_hash_spec.rb43
-rwxr-xr-xspec/functions/validate_ipv4_address_spec.rb64
-rwxr-xr-xspec/functions/validate_ipv6_address_spec.rb67
-rwxr-xr-xspec/functions/validate_re_spec.rb77
-rwxr-xr-xspec/functions/validate_slength_spec.rb67
-rwxr-xr-xspec/functions/validate_string_spec.rb60
-rwxr-xr-xspec/functions/values_at_spec.rb38
-rwxr-xr-xspec/functions/values_spec.rb31
-rwxr-xr-xspec/functions/zip_spec.rb31
-rwxr-xr-xspec/lib/puppet_spec/compiler.rb47
-rwxr-xr-xspec/lib/puppet_spec/database.rb30
-rwxr-xr-xspec/lib/puppet_spec/files.rb61
-rwxr-xr-xspec/lib/puppet_spec/fixtures.rb29
-rwxr-xr-xspec/lib/puppet_spec/matchers.rb121
-rwxr-xr-xspec/lib/puppet_spec/modules.rb27
-rwxr-xr-xspec/lib/puppet_spec/pops.rb17
-rwxr-xr-xspec/lib/puppet_spec/scope.rb15
-rwxr-xr-xspec/lib/puppet_spec/settings.rb16
-rwxr-xr-xspec/lib/puppet_spec/verbose.rb10
-rwxr-xr-xspec/monkey_patches/alias_should_to_must.rb9
-rwxr-xr-xspec/monkey_patches/publicize_methods.rb11
-rw-r--r--spec/spec.opts6
-rwxr-xr-xspec/spec_helper.rb34
-rwxr-xr-xspec/spec_helper_acceptance.rb50
-rwxr-xr-xspec/unit/facter/facter_dot_d_spec.rb32
-rwxr-xr-xspec/unit/facter/pe_version_spec.rb76
-rwxr-xr-xspec/unit/facter/root_home_spec.rb52
-rwxr-xr-xspec/unit/facter/util/puppet_settings_spec.rb36
-rw-r--r--spec/unit/puppet/functions/type_of_spec.rb33
-rwxr-xr-xspec/unit/puppet/parser/functions/basename_spec.rb46
-rwxr-xr-xspec/unit/puppet/parser/functions/bool2str_spec.rb46
-rwxr-xr-xspec/unit/puppet/parser/functions/camelcase_spec.rb24
-rw-r--r--spec/unit/puppet/parser/functions/str2saltedsha1_spec.rb45
-rwxr-xr-xspec/unit/puppet/provider/file_line/ruby_spec.rb225
-rwxr-xr-xspec/unit/puppet/type/anchor_spec.rb11
-rwxr-xr-xspec/unit/puppet/type/file_line_spec.rb70
240 files changed, 0 insertions, 9536 deletions
diff --git a/spec/acceptance/abs_spec.rb b/spec/acceptance/abs_spec.rb
deleted file mode 100755
index 6e41e2fd..00000000
--- a/spec/acceptance/abs_spec.rb
+++ /dev/null
@@ -1,30 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'abs function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should accept a string' do
- pp = <<-EOS
- $input = '-34.56'
- $output = abs($input)
- notify { "$output": }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: 34.56/)
- end
- end
-
- it 'should accept a float' do
- pp = <<-EOS
- $input = -34.56
- $output = abs($input)
- notify { "$output": }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: 34.56/)
- end
- end
- end
-end
diff --git a/spec/acceptance/any2array_spec.rb b/spec/acceptance/any2array_spec.rb
deleted file mode 100755
index 18ea4cd9..00000000
--- a/spec/acceptance/any2array_spec.rb
+++ /dev/null
@@ -1,49 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'any2array function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should create an empty array' do
- pp = <<-EOS
- $input = ''
- $output = any2array($input)
- validate_array($output)
- notify { "Output: ${output}": }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: Output: /)
- end
- end
-
- it 'should leave arrays modified' do
- pp = <<-EOS
- $input = ['test', 'array']
- $output = any2array($input)
- validate_array($output)
- notify { "Output: ${output}": }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: Output: (\[|)test(,\s|)array(\]|)/)
- end
- end
-
- it 'should turn a hash into an array' do
- pp = <<-EOS
- $input = {'test' => 'array'}
- $output = any2array($input)
-
- validate_array($output)
- # Check each element of the array is a plain string.
- validate_string($output[0])
- validate_string($output[1])
- notify { "Output: ${output}": }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: Output: (\[|)test(,\s|)array(\]|)/)
- end
- end
- end
-end
diff --git a/spec/acceptance/base64_spec.rb b/spec/acceptance/base64_spec.rb
deleted file mode 100755
index 97e1738e..00000000
--- a/spec/acceptance/base64_spec.rb
+++ /dev/null
@@ -1,18 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'base64 function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should encode then decode a string' do
- pp = <<-EOS
- $encodestring = base64('encode', 'thestring')
- $decodestring = base64('decode', $encodestring)
- notify { $decodestring: }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/thestring/)
- end
- end
- end
-end
diff --git a/spec/acceptance/bool2num_spec.rb b/spec/acceptance/bool2num_spec.rb
deleted file mode 100755
index 52ff75bc..00000000
--- a/spec/acceptance/bool2num_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'bool2num function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- ['false', 'f', '0', 'n', 'no'].each do |bool|
- it "should convert a given boolean, #{bool}, to 0" do
- pp = <<-EOS
- $input = "#{bool}"
- $output = bool2num($input)
- notify { "$output": }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: 0/)
- end
- end
- end
-
- ['true', 't', '1', 'y', 'yes'].each do |bool|
- it "should convert a given boolean, #{bool}, to 1" do
- pp = <<-EOS
- $input = "#{bool}"
- $output = bool2num($input)
- notify { "$output": }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: 1/)
- end
- end
- end
- end
-end
diff --git a/spec/acceptance/build_csv.rb b/spec/acceptance/build_csv.rb
deleted file mode 100755
index 62ecbf13..00000000
--- a/spec/acceptance/build_csv.rb
+++ /dev/null
@@ -1,83 +0,0 @@
-#!/usr/bin/env ruby
-# vim: set sw=2 sts=2 et tw=80 :
-require 'rspec'
-
-#XXX Super ugly hack to keep from starting beaker nodes
-module Kernel
- # make an alias of the original require
- alias_method :original_require, :require
- # rewrite require
- def require name
- original_require name if name != 'spec_helper_acceptance'
- end
-end
-UNSUPPORTED_PLATFORMS = []
-def fact(*args) [] end
-#XXX End hax
-
-# Get a list of functions for test coverage
-function_list = Dir[File.join(File.dirname(__FILE__),"..","..","lib","puppet","parser","functions","*.rb")].collect do |function_rb|
- File.basename(function_rb,".rb")
-end
-
-## Configure rspec to parse tests
-options = RSpec::Core::ConfigurationOptions.new(['spec/acceptance'])
-configuration = RSpec::configuration
-world = RSpec::world
-options.parse_options
-options.configure(configuration)
-configuration.load_spec_files
-
-## Collect up tests and example groups into a hash
-def get_tests(children)
- children.inject({}) do |memo,c|
- memo[c.description] = Hash.new
- memo[c.description]["groups"] = get_tests(c.children) unless c.children.empty?
- memo[c.description]["tests"] = c.examples.collect { |e|
- e.description unless e.pending?
- }.compact unless c.examples.empty?
- memo[c.description]["pending_tests"] = c.examples.collect { |e|
- e.description if e.pending?
- }.compact unless c.examples.empty?
- memo
- end
-end
-
-def count_test_types_in(type,group)
- return 0 if group.nil?
- group.inject(0) do |m,(k,v)|
- m += v.length if k == type
- m += count_tests_in(v) if v.is_a?(Hash)
- m
- end
-end
-def count_tests_in(group)
- count_test_types_in('tests',group)
-end
-def count_pending_tests_in(group)
- count_test_types_in('pending_tests',group)
-end
-
-# Convert tests hash to csv format
-def to_csv(function_list,tests)
- function_list.collect do |function_name|
- if v = tests["#{function_name} function"]
- positive_tests = count_tests_in(v["groups"]["success"])
- negative_tests = count_tests_in(v["groups"]["failure"])
- pending_tests =
- count_pending_tests_in(v["groups"]["failure"]) +
- count_pending_tests_in(v["groups"]["failure"])
- else
- positive_tests = 0
- negative_tests = 0
- pending_tests = 0
- end
- sprintf("%-25s, %-9d, %-9d, %-9d", function_name,positive_tests,negative_tests,pending_tests)
- end.compact
-end
-
-tests = get_tests(world.example_groups)
-csv = to_csv(function_list,tests)
-percentage_tested = "#{tests.count*100/function_list.count}%"
-printf("%-25s, %-9s, %-9s, %-9s\n","#{percentage_tested} have tests.","Positive","Negative","Pending")
-puts csv
diff --git a/spec/acceptance/capitalize_spec.rb b/spec/acceptance/capitalize_spec.rb
deleted file mode 100755
index e5e7b7bf..00000000
--- a/spec/acceptance/capitalize_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'capitalize function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should capitalize the first letter of a string' do
- pp = <<-EOS
- $input = 'this is a string'
- $output = capitalize($input)
- notify { $output: }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: This is a string/)
- end
- end
-
- it 'should capitalize the first letter of an array of strings' do
- pp = <<-EOS
- $input = ['this', 'is', 'a', 'string']
- $output = capitalize($input)
- notify { $output: }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: This/)
- expect(r.stdout).to match(/Notice: Is/)
- expect(r.stdout).to match(/Notice: A/)
- expect(r.stdout).to match(/Notice: String/)
- end
- end
- end
-end
diff --git a/spec/acceptance/chomp_spec.rb b/spec/acceptance/chomp_spec.rb
deleted file mode 100755
index f6c15956..00000000
--- a/spec/acceptance/chomp_spec.rb
+++ /dev/null
@@ -1,21 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'chomp function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should eat the newline' do
- pp = <<-EOS
- $input = "test\n"
- if size($input) != 5 {
- fail("Size of ${input} is not 5.")
- }
- $output = chomp($input)
- if size($output) != 4 {
- fail("Size of ${input} is not 4.")
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- end
-end
diff --git a/spec/acceptance/chop_spec.rb b/spec/acceptance/chop_spec.rb
deleted file mode 100755
index a16a7102..00000000
--- a/spec/acceptance/chop_spec.rb
+++ /dev/null
@@ -1,45 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'chop function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should eat the last character' do
- pp = <<-EOS
- $input = "test"
- if size($input) != 4 {
- fail("Size of ${input} is not 4.")
- }
- $output = chop($input)
- if size($output) != 3 {
- fail("Size of ${input} is not 3.")
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
-
- it 'should eat the last two characters of \r\n' do
- pp = <<-'EOS'
- $input = "test\r\n"
- if size($input) != 6 {
- fail("Size of ${input} is not 6.")
- }
- $output = chop($input)
- if size($output) != 4 {
- fail("Size of ${input} is not 4.")
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
-
- it 'should not fail on empty strings' do
- pp = <<-EOS
- $input = ""
- $output = chop($input)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- end
-end
diff --git a/spec/acceptance/concat_spec.rb b/spec/acceptance/concat_spec.rb
deleted file mode 100755
index 06b649f1..00000000
--- a/spec/acceptance/concat_spec.rb
+++ /dev/null
@@ -1,40 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'concat function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should concat one array to another' do
- pp = <<-EOS
- $output = concat(['1','2','3'],['4','5','6'])
- validate_array($output)
- if size($output) != 6 {
- fail("${output} should have 6 elements.")
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'should concat arrays and primitives to array' do
- pp = <<-EOS
- $output = concat(['1','2','3'],'4','5','6',['7','8','9'])
- validate_array($output)
- if size($output) != 9 {
- fail("${output} should have 9 elements.")
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'should concat multiple arrays to one' do
- pp = <<-EOS
- $output = concat(['1','2','3'],['4','5','6'],['7','8','9'])
- validate_array($output)
- if size($output) != 9 {
- fail("${output} should have 9 elements.")
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- end
-end
diff --git a/spec/acceptance/count_spec.rb b/spec/acceptance/count_spec.rb
deleted file mode 100755
index fe7ca9dc..00000000
--- a/spec/acceptance/count_spec.rb
+++ /dev/null
@@ -1,30 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'count function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should count elements in an array' do
- pp = <<-EOS
- $input = [1,2,3,4]
- $output = count($input)
- notify { "$output": }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: 4/)
- end
- end
-
- it 'should count elements in an array that match a second argument' do
- pp = <<-EOS
- $input = [1,1,1,2]
- $output = count($input, 1)
- notify { "$output": }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: 3/)
- end
- end
- end
-end
diff --git a/spec/acceptance/deep_merge_spec.rb b/spec/acceptance/deep_merge_spec.rb
deleted file mode 100755
index c0f9b126..00000000
--- a/spec/acceptance/deep_merge_spec.rb
+++ /dev/null
@@ -1,20 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'deep_merge function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should deep merge two hashes' do
- pp = <<-EOS
- $hash1 = {'one' => 1, 'two' => 2, 'three' => { 'four' => 4 } }
- $hash2 = {'two' => 'dos', 'three' => { 'five' => 5 } }
- $merged_hash = deep_merge($hash1, $hash2)
-
- if $merged_hash != { 'one' => 1, 'two' => 'dos', 'three' => { 'four' => 4, 'five' => 5 } } {
- fail("Hash was incorrectly merged.")
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- end
-end
diff --git a/spec/acceptance/defined_with_params_spec.rb b/spec/acceptance/defined_with_params_spec.rb
deleted file mode 100755
index fc544508..00000000
--- a/spec/acceptance/defined_with_params_spec.rb
+++ /dev/null
@@ -1,22 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'defined_with_params function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should successfully notify' do
- pp = <<-EOS
- user { 'dan':
- ensure => present,
- }
-
- if defined_with_params(User[dan], {'ensure' => 'present' }) {
- notify { 'User defined with ensure=>present': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: User defined with ensure=>present/)
- end
- end
- end
-end
diff --git a/spec/acceptance/delete_at_spec.rb b/spec/acceptance/delete_at_spec.rb
deleted file mode 100755
index db0c01f7..00000000
--- a/spec/acceptance/delete_at_spec.rb
+++ /dev/null
@@ -1,19 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'delete_at function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should delete elements of the array' do
- pp = <<-EOS
- $output = delete_at(['a','b','c','b'], 1)
- if $output == ['a','c','b'] {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
-end
diff --git a/spec/acceptance/delete_spec.rb b/spec/acceptance/delete_spec.rb
deleted file mode 100755
index a28604ce..00000000
--- a/spec/acceptance/delete_spec.rb
+++ /dev/null
@@ -1,19 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'delete function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should delete elements of the array' do
- pp = <<-EOS
- $output = delete(['a','b','c','b'], 'b')
- if $output == ['a','c'] {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
-end
diff --git a/spec/acceptance/delete_undef_values_spec.rb b/spec/acceptance/delete_undef_values_spec.rb
deleted file mode 100755
index b7eda192..00000000
--- a/spec/acceptance/delete_undef_values_spec.rb
+++ /dev/null
@@ -1,19 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'delete_undef_values function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should delete elements of the array' do
- pp = <<-EOS
- $output = delete_undef_values({a=>'A', b=>'', c=>undef, d => false})
- if $output == { a => 'A', b => '', d => false } {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
-end
diff --git a/spec/acceptance/delete_values_spec.rb b/spec/acceptance/delete_values_spec.rb
deleted file mode 100755
index 6d2369c3..00000000
--- a/spec/acceptance/delete_values_spec.rb
+++ /dev/null
@@ -1,25 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'delete_values function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should delete elements of the hash' do
- pp = <<-EOS
- $a = { 'a' => 'A', 'b' => 'B', 'B' => 'C', 'd' => 'B' }
- $b = { 'a' => 'A', 'B' => 'C' }
- $o = delete_values($a, 'B')
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles non-hash arguments'
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/difference_spec.rb b/spec/acceptance/difference_spec.rb
deleted file mode 100755
index 2fae5c43..00000000
--- a/spec/acceptance/difference_spec.rb
+++ /dev/null
@@ -1,26 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'difference function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'returns non-duplicates in the first array' do
- pp = <<-EOS
- $a = ['a','b','c']
- $b = ['b','c','d']
- $c = ['a']
- $o = difference($a, $b)
- if $o == $c {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles non-array arguments'
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/dirname_spec.rb b/spec/acceptance/dirname_spec.rb
deleted file mode 100755
index 97913ddb..00000000
--- a/spec/acceptance/dirname_spec.rb
+++ /dev/null
@@ -1,42 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'dirname function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- context 'absolute path' do
- it 'returns the dirname' do
- pp = <<-EOS
- $a = '/path/to/a/file.txt'
- $b = '/path/to/a'
- $o = dirname($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- context 'relative path' do
- it 'returns the dirname' do
- pp = <<-EOS
- $a = 'path/to/a/file.txt'
- $b = 'path/to/a'
- $o = dirname($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/downcase_spec.rb b/spec/acceptance/downcase_spec.rb
deleted file mode 100755
index bc4e7069..00000000
--- a/spec/acceptance/downcase_spec.rb
+++ /dev/null
@@ -1,39 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'downcase function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'returns the downcase' do
- pp = <<-EOS
- $a = 'AOEU'
- $b = 'aoeu'
- $o = downcase($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'doesn\'t affect lowercase words' do
- pp = <<-EOS
- $a = 'aoeu aoeu'
- $b = 'aoeu aoeu'
- $o = downcase($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-strings'
- end
-end
diff --git a/spec/acceptance/empty_spec.rb b/spec/acceptance/empty_spec.rb
deleted file mode 100755
index 8b46aacd..00000000
--- a/spec/acceptance/empty_spec.rb
+++ /dev/null
@@ -1,39 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'empty function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'recognizes empty strings' do
- pp = <<-EOS
- $a = ''
- $b = true
- $o = empty($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'recognizes non-empty strings' do
- pp = <<-EOS
- $a = 'aoeu'
- $b = false
- $o = empty($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-strings'
- end
-end
diff --git a/spec/acceptance/ensure_packages_spec.rb b/spec/acceptance/ensure_packages_spec.rb
deleted file mode 100755
index aedcfb55..00000000
--- a/spec/acceptance/ensure_packages_spec.rb
+++ /dev/null
@@ -1,22 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'ensure_packages function', :unless => fact('osfamily') =~ /windows/i do
- describe 'success' do
- it 'ensure_packages a package' do
- apply_manifest('package { "rake": ensure => absent, provider => "gem", }')
- pp = <<-EOS
- $a = "rake"
- ensure_packages($a,{'provider' => 'gem'})
- EOS
-
- apply_manifest(pp, :expect_changes => true)
- end
- it 'ensures a package already declared'
- it 'takes defaults arguments'
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings'
- end
-end
diff --git a/spec/acceptance/ensure_resource_spec.rb b/spec/acceptance/ensure_resource_spec.rb
deleted file mode 100755
index 1cee53db..00000000
--- a/spec/acceptance/ensure_resource_spec.rb
+++ /dev/null
@@ -1,22 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'ensure_resource function', :unless => fact('osfamily') =~ /windows/i do
- describe 'success' do
- it 'ensure_resource a package' do
- apply_manifest('package { "rake": ensure => absent, provider => "gem", }')
- pp = <<-EOS
- $a = "rake"
- ensure_resource('package', $a, {'provider' => 'gem'})
- EOS
-
- apply_manifest(pp, :expect_changes => true)
- end
- it 'ensures a resource already declared'
- it 'takes defaults arguments'
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings'
- end
-end
diff --git a/spec/acceptance/flatten_spec.rb b/spec/acceptance/flatten_spec.rb
deleted file mode 100755
index c4d66e04..00000000
--- a/spec/acceptance/flatten_spec.rb
+++ /dev/null
@@ -1,39 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'flatten function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'flattens arrays' do
- pp = <<-EOS
- $a = ["a","b",["c",["d","e"],"f","g"]]
- $b = ["a","b","c","d","e","f","g"]
- $o = flatten($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'does not affect flat arrays' do
- pp = <<-EOS
- $a = ["a","b","c","d","e","f","g"]
- $b = ["a","b","c","d","e","f","g"]
- $o = flatten($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-strings'
- end
-end
diff --git a/spec/acceptance/floor_spec.rb b/spec/acceptance/floor_spec.rb
deleted file mode 100755
index 0dcdad9c..00000000
--- a/spec/acceptance/floor_spec.rb
+++ /dev/null
@@ -1,39 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'floor function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'floors floats' do
- pp = <<-EOS
- $a = 12.8
- $b = 12
- $o = floor($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'floors integers' do
- pp = <<-EOS
- $a = 7
- $b = 7
- $o = floor($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-numbers'
- end
-end
diff --git a/spec/acceptance/fqdn_rotate_spec.rb b/spec/acceptance/fqdn_rotate_spec.rb
deleted file mode 100755
index 753068bf..00000000
--- a/spec/acceptance/fqdn_rotate_spec.rb
+++ /dev/null
@@ -1,47 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'fqdn_rotate function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- let(:facts_d) do
- if fact('is_pe', '--puppet') == "true"
- if fact('osfamily') =~ /windows/i
- if fact('kernelmajversion').to_f < 6.0
- 'C:/Documents and Settings/All Users/Application Data/PuppetLabs/facter/facts.d'
- else
- 'C:/ProgramData/PuppetLabs/facter/facts.d'
- end
- else
- '/etc/puppetlabs/facter/facts.d'
- end
- else
- '/etc/facter/facts.d'
- end
- end
- after :each do
- shell("if [ -f '#{facts_d}/fqdn.txt' ] ; then rm '#{facts_d}/fqdn.txt' ; fi")
- end
- before :each do
- #No need to create on windows, PE creates by default
- if fact('osfamily') !~ /windows/i
- shell("mkdir -p '#{facts_d}'")
- end
- end
- it 'fqdn_rotates floats' do
- shell("echo fqdn=fakehost.localdomain > '#{facts_d}/fqdn.txt'")
- pp = <<-EOS
- $a = ['a','b','c','d']
- $o = fqdn_rotate($a)
- notice(inline_template('fqdn_rotate is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/fqdn_rotate is \["c", "d", "a", "b"\]/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-numbers'
- end
-end
diff --git a/spec/acceptance/get_module_path_spec.rb b/spec/acceptance/get_module_path_spec.rb
deleted file mode 100755
index 6ac690c1..00000000
--- a/spec/acceptance/get_module_path_spec.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'get_module_path function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'get_module_paths dne' do
- pp = <<-EOS
- $a = $::is_pe ? {
- 'true' => '/etc/puppetlabs/puppet/modules/dne',
- 'false' => '/etc/puppet/modules/dne',
- }
- $o = get_module_path('dne')
- if $o == $a {
- notify { 'output correct': }
- } else {
- notify { "failed; module path is '$o'": }
- }
- EOS
-
- apply_manifest(pp, :expect_failures => true)
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-numbers'
- end
-end
diff --git a/spec/acceptance/getparam_spec.rb b/spec/acceptance/getparam_spec.rb
deleted file mode 100755
index b1a677ec..00000000
--- a/spec/acceptance/getparam_spec.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'getparam function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'getparam a notify' do
- pp = <<-EOS
- notify { 'rspec':
- message => 'custom rspec message',
- }
- $o = getparam(Notify['rspec'], 'message')
- notice(inline_template('getparam is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/getparam is "custom rspec message"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings'
- end
-end
diff --git a/spec/acceptance/getvar_spec.rb b/spec/acceptance/getvar_spec.rb
deleted file mode 100755
index 333c467f..00000000
--- a/spec/acceptance/getvar_spec.rb
+++ /dev/null
@@ -1,26 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'getvar function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'getvars from classes' do
- pp = <<-EOS
- class a::data { $foo = 'aoeu' }
- include a::data
- $b = 'aoeu'
- $o = getvar("a::data::foo")
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-numbers'
- end
-end
diff --git a/spec/acceptance/grep_spec.rb b/spec/acceptance/grep_spec.rb
deleted file mode 100755
index b39d48ec..00000000
--- a/spec/acceptance/grep_spec.rb
+++ /dev/null
@@ -1,26 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'grep function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'greps arrays' do
- pp = <<-EOS
- $a = ['aaabbb','bbbccc','dddeee']
- $b = 'bbb'
- $c = ['aaabbb','bbbccc']
- $o = grep($a,$b)
- if $o == $c {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/has_interface_with_spec.rb b/spec/acceptance/has_interface_with_spec.rb
deleted file mode 100755
index 95901930..00000000
--- a/spec/acceptance/has_interface_with_spec.rb
+++ /dev/null
@@ -1,54 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'has_interface_with function', :unless => ((UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem'))) or (fact('osfamily') == 'windows') or (fact('osfamily') == 'AIX')) do
- describe 'success' do
- it 'has_interface_with existing ipaddress' do
- pp = <<-EOS
- $a = $::ipaddress
- $o = has_interface_with('ipaddress', $a)
- notice(inline_template('has_interface_with is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/has_interface_with is true/)
- end
- end
- it 'has_interface_with absent ipaddress' do
- pp = <<-EOS
- $a = '128.0.0.1'
- $o = has_interface_with('ipaddress', $a)
- notice(inline_template('has_interface_with is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/has_interface_with is false/)
- end
- end
- it 'has_interface_with existing interface' do
- pp = <<-EOS
- if $osfamily == 'Solaris' or $osfamily == 'Darwin' {
- $a = 'lo0'
- }elsif $osfamily == 'windows' {
- $a = $::kernelmajversion ? {
- /6\.(2|3|4)/ => 'Ethernet0',
- /6\.(0|1)/ => 'Local_Area_Connection',
- /5\.(1|2)/ => undef, #Broken current in facter
- }
- }else {
- $a = 'lo'
- }
- $o = has_interface_with($a)
- notice(inline_template('has_interface_with is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/has_interface_with is true/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings'
- end
-end
diff --git a/spec/acceptance/has_ip_address_spec.rb b/spec/acceptance/has_ip_address_spec.rb
deleted file mode 100755
index 149a10dc..00000000
--- a/spec/acceptance/has_ip_address_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'has_ip_address function', :unless => ((UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem'))) or (fact('osfamily') == 'windows') or (fact('osfamily') == 'AIX')) do
- describe 'success' do
- it 'has_ip_address existing ipaddress' do
- pp = <<-EOS
- $a = '127.0.0.1'
- $o = has_ip_address($a)
- notice(inline_template('has_ip_address is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/has_ip_address is true/)
- end
- end
- it 'has_ip_address absent ipaddress' do
- pp = <<-EOS
- $a = '128.0.0.1'
- $o = has_ip_address($a)
- notice(inline_template('has_ip_address is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/has_ip_address is false/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings'
- end
-end
diff --git a/spec/acceptance/has_ip_network_spec.rb b/spec/acceptance/has_ip_network_spec.rb
deleted file mode 100755
index 7d2f34ed..00000000
--- a/spec/acceptance/has_ip_network_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'has_ip_network function', :unless => ((UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem'))) or (fact('osfamily') == 'windows') or (fact('osfamily') == 'AIX')) do
- describe 'success' do
- it 'has_ip_network existing ipaddress' do
- pp = <<-EOS
- $a = '127.0.0.0'
- $o = has_ip_network($a)
- notice(inline_template('has_ip_network is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/has_ip_network is true/)
- end
- end
- it 'has_ip_network absent ipaddress' do
- pp = <<-EOS
- $a = '128.0.0.0'
- $o = has_ip_network($a)
- notice(inline_template('has_ip_network is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/has_ip_network is false/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings'
- end
-end
diff --git a/spec/acceptance/has_key_spec.rb b/spec/acceptance/has_key_spec.rb
deleted file mode 100755
index c8557cbe..00000000
--- a/spec/acceptance/has_key_spec.rb
+++ /dev/null
@@ -1,41 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'has_key function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'has_keys in hashes' do
- pp = <<-EOS
- $a = { 'aaa' => 'bbb','bbb' => 'ccc','ddd' => 'eee' }
- $b = 'bbb'
- $c = true
- $o = has_key($a,$b)
- if $o == $c {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'has_keys not in hashes' do
- pp = <<-EOS
- $a = { 'aaa' => 'bbb','bbb' => 'ccc','ddd' => 'eee' }
- $b = 'ccc'
- $c = false
- $o = has_key($a,$b)
- if $o == $c {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-hashes'
- end
-end
diff --git a/spec/acceptance/hash_spec.rb b/spec/acceptance/hash_spec.rb
deleted file mode 100755
index ed53834b..00000000
--- a/spec/acceptance/hash_spec.rb
+++ /dev/null
@@ -1,26 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'hash function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'hashs arrays' do
- pp = <<-EOS
- $a = ['aaa','bbb','bbb','ccc','ddd','eee']
- $b = { 'aaa' => 'bbb', 'bbb' => 'ccc', 'ddd' => 'eee' }
- $o = hash($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'handles odd-length arrays'
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/intersection_spec.rb b/spec/acceptance/intersection_spec.rb
deleted file mode 100755
index 66b86529..00000000
--- a/spec/acceptance/intersection_spec.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'intersection function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'intersections arrays' do
- pp = <<-EOS
- $a = ['aaa','bbb','ccc']
- $b = ['bbb','ccc','ddd','eee']
- $c = ['bbb','ccc']
- $o = intersection($a,$b)
- if $o == $c {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'intersections empty arrays'
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/is_array_spec.rb b/spec/acceptance/is_array_spec.rb
deleted file mode 100755
index 9c6bad73..00000000
--- a/spec/acceptance/is_array_spec.rb
+++ /dev/null
@@ -1,67 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_array function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_arrays arrays' do
- pp = <<-EOS
- $a = ['aaa','bbb','ccc']
- $b = true
- $o = is_array($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_arrays empty arrays' do
- pp = <<-EOS
- $a = []
- $b = true
- $o = is_array($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_arrays strings' do
- pp = <<-EOS
- $a = "aoeu"
- $b = false
- $o = is_array($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_arrays hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'bbb'}
- $b = false
- $o = is_array($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/is_bool_spec.rb b/spec/acceptance/is_bool_spec.rb
deleted file mode 100755
index 60079f95..00000000
--- a/spec/acceptance/is_bool_spec.rb
+++ /dev/null
@@ -1,81 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_bool function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_bools arrays' do
- pp = <<-EOS
- $a = ['aaa','bbb','ccc']
- $b = false
- $o = is_bool($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_bools true' do
- pp = <<-EOS
- $a = true
- $b = true
- $o = is_bool($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_bools false' do
- pp = <<-EOS
- $a = false
- $b = true
- $o = is_bool($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_bools strings' do
- pp = <<-EOS
- $a = "true"
- $b = false
- $o = is_bool($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_bools hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'bbb'}
- $b = false
- $o = is_bool($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/is_domain_name_spec.rb b/spec/acceptance/is_domain_name_spec.rb
deleted file mode 100755
index e0f03fa8..00000000
--- a/spec/acceptance/is_domain_name_spec.rb
+++ /dev/null
@@ -1,83 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_domain_name function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_domain_names arrays' do
- pp = <<-EOS
- $a = ['aaa.com','bbb','ccc']
- $o = is_domain_name($a)
- notice(inline_template('is_domain_name is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_domain_name is false/)
- end
- end
- it 'is_domain_names true' do
- pp = <<-EOS
- $a = true
- $o = is_domain_name($a)
- notice(inline_template('is_domain_name is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_domain_name is false/)
- end
- end
- it 'is_domain_names false' do
- pp = <<-EOS
- $a = false
- $o = is_domain_name($a)
- notice(inline_template('is_domain_name is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_domain_name is false/)
- end
- end
- it 'is_domain_names strings with hyphens' do
- pp = <<-EOS
- $a = "3foo-bar.2bar-fuzz.com"
- $b = true
- $o = is_domain_name($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_domain_names strings beginning with hyphens' do
- pp = <<-EOS
- $a = "-bar.2bar-fuzz.com"
- $b = false
- $o = is_domain_name($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_domain_names hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'www.com'}
- $o = is_domain_name($a)
- notice(inline_template('is_domain_name is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_domain_name is false/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/is_float_spec.rb b/spec/acceptance/is_float_spec.rb
deleted file mode 100755
index 338ba58d..00000000
--- a/spec/acceptance/is_float_spec.rb
+++ /dev/null
@@ -1,86 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_float function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_floats arrays' do
- pp = <<-EOS
- $a = ['aaa.com','bbb','ccc']
- $o = is_float($a)
- notice(inline_template('is_float is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_float is false/)
- end
- end
- it 'is_floats true' do
- pp = <<-EOS
- $a = true
- $o = is_float($a)
- notice(inline_template('is_float is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_float is false/)
- end
- end
- it 'is_floats strings' do
- pp = <<-EOS
- $a = "3.5"
- $b = true
- $o = is_float($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_floats floats' do
- pp = <<-EOS
- $a = 3.5
- $b = true
- $o = is_float($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_floats integers' do
- pp = <<-EOS
- $a = 3
- $b = false
- $o = is_float($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_floats hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'www.com'}
- $o = is_float($a)
- notice(inline_template('is_float is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_float is false/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/is_function_available_spec.rb b/spec/acceptance/is_function_available_spec.rb
deleted file mode 100755
index 2b5dd6d1..00000000
--- a/spec/acceptance/is_function_available_spec.rb
+++ /dev/null
@@ -1,58 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_function_available function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_function_availables arrays' do
- pp = <<-EOS
- $a = ['fail','include','require']
- $o = is_function_available($a)
- notice(inline_template('is_function_available is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_function_available is false/)
- end
- end
- it 'is_function_availables true' do
- pp = <<-EOS
- $a = true
- $o = is_function_available($a)
- notice(inline_template('is_function_available is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_function_available is false/)
- end
- end
- it 'is_function_availables strings' do
- pp = <<-EOS
- $a = "fail"
- $b = true
- $o = is_function_available($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_function_availables function_availables' do
- pp = <<-EOS
- $a = "is_function_available"
- $o = is_function_available($a)
- notice(inline_template('is_function_available is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_function_available is true/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/is_hash_spec.rb b/spec/acceptance/is_hash_spec.rb
deleted file mode 100755
index 2ef310ab..00000000
--- a/spec/acceptance/is_hash_spec.rb
+++ /dev/null
@@ -1,63 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_hash function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_hashs arrays' do
- pp = <<-EOS
- $a = ['aaa','bbb','ccc']
- $o = is_hash($a)
- notice(inline_template('is_hash is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_hash is false/)
- end
- end
- it 'is_hashs empty hashs' do
- pp = <<-EOS
- $a = {}
- $b = true
- $o = is_hash($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_hashs strings' do
- pp = <<-EOS
- $a = "aoeu"
- $b = false
- $o = is_hash($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_hashs hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'bbb'}
- $b = true
- $o = is_hash($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/is_integer_spec.rb b/spec/acceptance/is_integer_spec.rb
deleted file mode 100755
index bf6902b9..00000000
--- a/spec/acceptance/is_integer_spec.rb
+++ /dev/null
@@ -1,95 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_integer function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_integers arrays' do
- pp = <<-EOS
- $a = ['aaa.com','bbb','ccc']
- $b = false
- $o = is_integer($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_integers true' do
- pp = <<-EOS
- $a = true
- $b = false
- $o = is_integer($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_integers strings' do
- pp = <<-EOS
- $a = "3"
- $b = true
- $o = is_integer($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_integers floats' do
- pp = <<-EOS
- $a = 3.5
- $b = false
- $o = is_integer($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_integers integers' do
- pp = <<-EOS
- $a = 3
- $b = true
- $o = is_integer($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_integers hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'www.com'}
- $b = false
- $o = is_integer($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/is_ip_address_spec.rb b/spec/acceptance/is_ip_address_spec.rb
deleted file mode 100755
index ed7a8543..00000000
--- a/spec/acceptance/is_ip_address_spec.rb
+++ /dev/null
@@ -1,80 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_ip_address function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_ip_addresss ipv4' do
- pp = <<-EOS
- $a = '1.2.3.4'
- $b = true
- $o = is_ip_address($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_ip_addresss ipv6' do
- pp = <<-EOS
- $a = "fe80:0000:cd12:d123:e2f8:47ff:fe09:dd74"
- $b = true
- $o = is_ip_address($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_ip_addresss ipv6 compressed' do
- pp = <<-EOS
- $a = "fe00::1"
- $b = true
- $o = is_ip_address($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_ip_addresss strings' do
- pp = <<-EOS
- $a = "aoeu"
- $b = false
- $o = is_ip_address($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_ip_addresss ipv4 out of range' do
- pp = <<-EOS
- $a = '1.2.3.400'
- $b = false
- $o = is_ip_address($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/is_mac_address_spec.rb b/spec/acceptance/is_mac_address_spec.rb
deleted file mode 100755
index a2c892f4..00000000
--- a/spec/acceptance/is_mac_address_spec.rb
+++ /dev/null
@@ -1,38 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_mac_address function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_mac_addresss a mac' do
- pp = <<-EOS
- $a = '00:a0:1f:12:7f:a0'
- $b = true
- $o = is_mac_address($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_mac_addresss a mac out of range' do
- pp = <<-EOS
- $a = '00:a0:1f:12:7f:g0'
- $b = false
- $o = is_mac_address($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/is_numeric_spec.rb b/spec/acceptance/is_numeric_spec.rb
deleted file mode 100755
index 21c89884..00000000
--- a/spec/acceptance/is_numeric_spec.rb
+++ /dev/null
@@ -1,95 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_numeric function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_numerics arrays' do
- pp = <<-EOS
- $a = ['aaa.com','bbb','ccc']
- $b = false
- $o = is_numeric($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_numerics true' do
- pp = <<-EOS
- $a = true
- $b = false
- $o = is_numeric($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_numerics strings' do
- pp = <<-EOS
- $a = "3"
- $b = true
- $o = is_numeric($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_numerics floats' do
- pp = <<-EOS
- $a = 3.5
- $b = true
- $o = is_numeric($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_numerics integers' do
- pp = <<-EOS
- $a = 3
- $b = true
- $o = is_numeric($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_numerics hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'www.com'}
- $b = false
- $o = is_numeric($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- it 'handles non-arrays'
- end
-end
diff --git a/spec/acceptance/is_string_spec.rb b/spec/acceptance/is_string_spec.rb
deleted file mode 100755
index 94d8e967..00000000
--- a/spec/acceptance/is_string_spec.rb
+++ /dev/null
@@ -1,102 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'is_string function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'is_strings arrays' do
- pp = <<-EOS
- $a = ['aaa.com','bbb','ccc']
- $b = false
- $o = is_string($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_strings true' do
- pp = <<-EOS
- $a = true
- $b = false
- $o = is_string($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_strings strings' do
- pp = <<-EOS
- $a = "aoeu"
- $o = is_string($a)
- notice(inline_template('is_string is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_string is true/)
- end
- end
- it 'is_strings number strings' do
- pp = <<-EOS
- $a = "3"
- $o = is_string($a)
- notice(inline_template('is_string is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/is_string is false/)
- end
- end
- it 'is_strings floats' do
- pp = <<-EOS
- $a = 3.5
- $b = false
- $o = is_string($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_strings integers' do
- pp = <<-EOS
- $a = 3
- $b = false
- $o = is_string($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'is_strings hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'www.com'}
- $b = false
- $o = is_string($a)
- if $o == $b {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/join_keys_to_values_spec.rb b/spec/acceptance/join_keys_to_values_spec.rb
deleted file mode 100755
index 70493fd5..00000000
--- a/spec/acceptance/join_keys_to_values_spec.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'join_keys_to_values function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'join_keys_to_valuess hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'bbb','ccc'=>'ddd'}
- $b = ':'
- $o = join_keys_to_values($a,$b)
- notice(inline_template('join_keys_to_values is <%= @o.sort.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/join_keys_to_values is \["aaa:bbb", "ccc:ddd"\]/)
- end
- end
- it 'handles non hashes'
- it 'handles empty hashes'
- end
- describe 'failure' do
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/join_spec.rb b/spec/acceptance/join_spec.rb
deleted file mode 100755
index 5397ce2c..00000000
--- a/spec/acceptance/join_spec.rb
+++ /dev/null
@@ -1,26 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'join function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'joins arrays' do
- pp = <<-EOS
- $a = ['aaa','bbb','ccc']
- $b = ':'
- $c = 'aaa:bbb:ccc'
- $o = join($a,$b)
- if $o == $c {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- it 'handles non arrays'
- end
- describe 'failure' do
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/keys_spec.rb b/spec/acceptance/keys_spec.rb
deleted file mode 100755
index 176918e9..00000000
--- a/spec/acceptance/keys_spec.rb
+++ /dev/null
@@ -1,23 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'keys function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'keyss hashes' do
- pp = <<-EOS
- $a = {'aaa'=>'bbb','ccc'=>'ddd'}
- $o = keys($a)
- notice(inline_template('keys is <%= @o.sort.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/keys is \["aaa", "ccc"\]/)
- end
- end
- it 'handles non hashes'
- it 'handles empty hashes'
- end
- describe 'failure' do
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/loadyaml_spec.rb b/spec/acceptance/loadyaml_spec.rb
deleted file mode 100644
index 1e910a97..00000000
--- a/spec/acceptance/loadyaml_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-tmpdir = default.tmpdir('stdlib')
-
-describe 'loadyaml function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'loadyamls array of values' do
- shell("echo '---
- aaa: 1
- bbb: 2
- ccc: 3
- ddd: 4' > #{tmpdir}/testyaml.yaml")
- pp = <<-EOS
- $o = loadyaml('#{tmpdir}/testyaml.yaml')
- notice(inline_template('loadyaml[aaa] is <%= @o["aaa"].inspect %>'))
- notice(inline_template('loadyaml[bbb] is <%= @o["bbb"].inspect %>'))
- notice(inline_template('loadyaml[ccc] is <%= @o["ccc"].inspect %>'))
- notice(inline_template('loadyaml[ddd] is <%= @o["ddd"].inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/loadyaml\[aaa\] is 1/)
- expect(r.stdout).to match(/loadyaml\[bbb\] is 2/)
- expect(r.stdout).to match(/loadyaml\[ccc\] is 3/)
- expect(r.stdout).to match(/loadyaml\[ddd\] is 4/)
- end
- end
- end
- describe 'failure' do
- it 'fails with no arguments'
- end
-end
diff --git a/spec/acceptance/lstrip_spec.rb b/spec/acceptance/lstrip_spec.rb
deleted file mode 100755
index 3dc952fb..00000000
--- a/spec/acceptance/lstrip_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'lstrip function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'lstrips arrays' do
- pp = <<-EOS
- $a = [" the "," public "," art","galleries "]
- # Anagram: Large picture halls, I bet
- $o = lstrip($a)
- notice(inline_template('lstrip is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/lstrip is \["the ", "public ", "art", "galleries "\]/)
- end
- end
- it 'lstrips strings' do
- pp = <<-EOS
- $a = " blowzy night-frumps vex'd jack q "
- $o = lstrip($a)
- notice(inline_template('lstrip is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/lstrip is "blowzy night-frumps vex'd jack q "/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/max_spec.rb b/spec/acceptance/max_spec.rb
deleted file mode 100755
index f04e3d28..00000000
--- a/spec/acceptance/max_spec.rb
+++ /dev/null
@@ -1,20 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'max function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'maxs arrays' do
- pp = <<-EOS
- $o = max("the","public","art","galleries")
- notice(inline_template('max is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/max is "the"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- end
-end
diff --git a/spec/acceptance/member_spec.rb b/spec/acceptance/member_spec.rb
deleted file mode 100755
index fe75a078..00000000
--- a/spec/acceptance/member_spec.rb
+++ /dev/null
@@ -1,54 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'member function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- shared_examples 'item found' do
- it 'should output correctly' do
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- end
- describe 'success' do
- it 'members arrays' do
- pp = <<-EOS
- $a = ['aaa','bbb','ccc']
- $b = 'ccc'
- $c = true
- $o = member($a,$b)
- if $o == $c {
- notify { 'output correct': }
- }
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/Notice: output correct/)
- end
- end
- describe 'members array of integers' do
- it_should_behave_like 'item found' do
- let(:pp) { <<-EOS
- if member( [1,2,3,4], 4 ){
- notify { 'output correct': }
- }
- EOS
- }
- end
- end
- describe 'members of mixed array' do
- it_should_behave_like 'item found' do
- let(:pp) { <<-EOS
- if member( ['a','4',3], 'a' ){
- notify { 'output correct': }
-}
- EOS
- }
- end
- end
- it 'members arrays without members'
- end
-
- describe 'failure' do
- it 'handles improper argument counts'
- end
-end
diff --git a/spec/acceptance/merge_spec.rb b/spec/acceptance/merge_spec.rb
deleted file mode 100755
index 227b9942..00000000
--- a/spec/acceptance/merge_spec.rb
+++ /dev/null
@@ -1,23 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'merge function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'should merge two hashes' do
- pp = <<-EOS
- $a = {'one' => 1, 'two' => 2, 'three' => { 'four' => 4 } }
- $b = {'two' => 'dos', 'three' => { 'five' => 5 } }
- $o = merge($a, $b)
- notice(inline_template('merge[one] is <%= @o["one"].inspect %>'))
- notice(inline_template('merge[two] is <%= @o["two"].inspect %>'))
- notice(inline_template('merge[three] is <%= @o["three"].inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/merge\[one\] is ("1"|1)/)
- expect(r.stdout).to match(/merge\[two\] is "dos"/)
- expect(r.stdout).to match(/merge\[three\] is {"five"=>("5"|5)}/)
- end
- end
- end
-end
diff --git a/spec/acceptance/min_spec.rb b/spec/acceptance/min_spec.rb
deleted file mode 100755
index 509092d3..00000000
--- a/spec/acceptance/min_spec.rb
+++ /dev/null
@@ -1,20 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'min function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'mins arrays' do
- pp = <<-EOS
- $o = min("the","public","art","galleries")
- notice(inline_template('min is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/min is "art"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- end
-end
diff --git a/spec/acceptance/nodesets/centos-59-x64.yml b/spec/acceptance/nodesets/centos-59-x64.yml
deleted file mode 100644
index 2ad90b86..00000000
--- a/spec/acceptance/nodesets/centos-59-x64.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-HOSTS:
- centos-59-x64:
- roles:
- - master
- platform: el-5-x86_64
- box : centos-59-x64-vbox4210-nocm
- box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-59-x64-vbox4210-nocm.box
- hypervisor : vagrant
-CONFIG:
- type: git
diff --git a/spec/acceptance/nodesets/centos-6-vcloud.yml b/spec/acceptance/nodesets/centos-6-vcloud.yml
deleted file mode 100644
index ca9c1d32..00000000
--- a/spec/acceptance/nodesets/centos-6-vcloud.yml
+++ /dev/null
@@ -1,15 +0,0 @@
-HOSTS:
- 'centos-6-vcloud':
- roles:
- - master
- platform: el-6-x86_64
- hypervisor: vcloud
- template: centos-6-x86_64
-CONFIG:
- type: foss
- ssh:
- keys: "~/.ssh/id_rsa-acceptance"
- datastore: instance0
- folder: Delivery/Quality Assurance/Enterprise/Dynamic
- resourcepool: delivery/Quality Assurance/Enterprise/Dynamic
- pooling_api: http://vcloud.delivery.puppetlabs.net/
diff --git a/spec/acceptance/nodesets/centos-64-x64-pe.yml b/spec/acceptance/nodesets/centos-64-x64-pe.yml
deleted file mode 100644
index 7d9242f1..00000000
--- a/spec/acceptance/nodesets/centos-64-x64-pe.yml
+++ /dev/null
@@ -1,12 +0,0 @@
-HOSTS:
- centos-64-x64:
- roles:
- - master
- - database
- - dashboard
- platform: el-6-x86_64
- box : centos-64-x64-vbox4210-nocm
- box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-64-x64-vbox4210-nocm.box
- hypervisor : vagrant
-CONFIG:
- type: pe
diff --git a/spec/acceptance/nodesets/centos-64-x64.yml b/spec/acceptance/nodesets/centos-64-x64.yml
deleted file mode 100644
index 05540ed8..00000000
--- a/spec/acceptance/nodesets/centos-64-x64.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-HOSTS:
- centos-64-x64:
- roles:
- - master
- platform: el-6-x86_64
- box : centos-64-x64-vbox4210-nocm
- box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-64-x64-vbox4210-nocm.box
- hypervisor : vagrant
-CONFIG:
- type: foss
diff --git a/spec/acceptance/nodesets/centos-65-x64.yml b/spec/acceptance/nodesets/centos-65-x64.yml
deleted file mode 100644
index 4e2cb809..00000000
--- a/spec/acceptance/nodesets/centos-65-x64.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-HOSTS:
- centos-65-x64:
- roles:
- - master
- platform: el-6-x86_64
- box : centos-65-x64-vbox436-nocm
- box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-65-x64-virtualbox-nocm.box
- hypervisor : vagrant
-CONFIG:
- type: foss
diff --git a/spec/acceptance/nodesets/default.yml b/spec/acceptance/nodesets/default.yml
deleted file mode 100644
index 4e2cb809..00000000
--- a/spec/acceptance/nodesets/default.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-HOSTS:
- centos-65-x64:
- roles:
- - master
- platform: el-6-x86_64
- box : centos-65-x64-vbox436-nocm
- box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-65-x64-virtualbox-nocm.box
- hypervisor : vagrant
-CONFIG:
- type: foss
diff --git a/spec/acceptance/nodesets/fedora-18-x64.yml b/spec/acceptance/nodesets/fedora-18-x64.yml
deleted file mode 100644
index 13616498..00000000
--- a/spec/acceptance/nodesets/fedora-18-x64.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-HOSTS:
- fedora-18-x64:
- roles:
- - master
- platform: fedora-18-x86_64
- box : fedora-18-x64-vbox4210-nocm
- box_url : http://puppet-vagrant-boxes.puppetlabs.com/fedora-18-x64-vbox4210-nocm.box
- hypervisor : vagrant
-CONFIG:
- type: foss
diff --git a/spec/acceptance/nodesets/sles-11-x64.yml b/spec/acceptance/nodesets/sles-11-x64.yml
deleted file mode 100644
index 41abe213..00000000
--- a/spec/acceptance/nodesets/sles-11-x64.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-HOSTS:
- sles-11-x64.local:
- roles:
- - master
- platform: sles-11-x64
- box : sles-11sp1-x64-vbox4210-nocm
- box_url : http://puppet-vagrant-boxes.puppetlabs.com/sles-11sp1-x64-vbox4210-nocm.box
- hypervisor : vagrant
-CONFIG:
- type: foss
diff --git a/spec/acceptance/nodesets/ubuntu-server-10044-x64.yml b/spec/acceptance/nodesets/ubuntu-server-10044-x64.yml
deleted file mode 100644
index 5ca1514e..00000000
--- a/spec/acceptance/nodesets/ubuntu-server-10044-x64.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-HOSTS:
- ubuntu-server-10044-x64:
- roles:
- - master
- platform: ubuntu-10.04-amd64
- box : ubuntu-server-10044-x64-vbox4210-nocm
- box_url : http://puppet-vagrant-boxes.puppetlabs.com/ubuntu-server-10044-x64-vbox4210-nocm.box
- hypervisor : vagrant
-CONFIG:
- type: foss
diff --git a/spec/acceptance/nodesets/ubuntu-server-12042-x64.yml b/spec/acceptance/nodesets/ubuntu-server-12042-x64.yml
deleted file mode 100644
index d065b304..00000000
--- a/spec/acceptance/nodesets/ubuntu-server-12042-x64.yml
+++ /dev/null
@@ -1,10 +0,0 @@
-HOSTS:
- ubuntu-server-12042-x64:
- roles:
- - master
- platform: ubuntu-12.04-amd64
- box : ubuntu-server-12042-x64-vbox4210-nocm
- box_url : http://puppet-vagrant-boxes.puppetlabs.com/ubuntu-server-12042-x64-vbox4210-nocm.box
- hypervisor : vagrant
-CONFIG:
- type: foss
diff --git a/spec/acceptance/nodesets/ubuntu-server-1404-x64.yml b/spec/acceptance/nodesets/ubuntu-server-1404-x64.yml
deleted file mode 100644
index cba1cd04..00000000
--- a/spec/acceptance/nodesets/ubuntu-server-1404-x64.yml
+++ /dev/null
@@ -1,11 +0,0 @@
-HOSTS:
- ubuntu-server-1404-x64:
- roles:
- - master
- platform: ubuntu-14.04-amd64
- box : puppetlabs/ubuntu-14.04-64-nocm
- box_url : https://vagrantcloud.com/puppetlabs/ubuntu-14.04-64-nocm
- hypervisor : vagrant
-CONFIG:
- log_level : debug
- type: git
diff --git a/spec/acceptance/nodesets/windows-2003-i386.yml b/spec/acceptance/nodesets/windows-2003-i386.yml
deleted file mode 100644
index 47dadbd5..00000000
--- a/spec/acceptance/nodesets/windows-2003-i386.yml
+++ /dev/null
@@ -1,26 +0,0 @@
-HOSTS:
- ubuntu1204:
- roles:
- - master
- - database
- - dashboard
- platform: ubuntu-12.04-amd64
- template: ubuntu-1204-x86_64
- hypervisor: vcloud
- win2003_i386:
- roles:
- - agent
- - default
- platform: windows-2003-i386
- template: win-2003-i386
- hypervisor: vcloud
-CONFIG:
- nfs_server: none
- ssh:
- keys: "~/.ssh/id_rsa-acceptance"
- consoleport: 443
- datastore: instance0
- folder: Delivery/Quality Assurance/Enterprise/Dynamic
- resourcepool: delivery/Quality Assurance/Enterprise/Dynamic
- pooling_api: http://vcloud.delivery.puppetlabs.net/
- pe_dir: http://neptune.puppetlabs.lan/3.2/ci-ready/
diff --git a/spec/acceptance/nodesets/windows-2003-x86_64.yml b/spec/acceptance/nodesets/windows-2003-x86_64.yml
deleted file mode 100644
index 6a884bc9..00000000
--- a/spec/acceptance/nodesets/windows-2003-x86_64.yml
+++ /dev/null
@@ -1,26 +0,0 @@
-HOSTS:
- ubuntu1204:
- roles:
- - master
- - database
- - dashboard
- platform: ubuntu-12.04-amd64
- template: ubuntu-1204-x86_64
- hypervisor: vcloud
- win2003_x86_64:
- roles:
- - agent
- - default
- platform: windows-2003-x86_64
- template: win-2003-x86_64
- hypervisor: vcloud
-CONFIG:
- nfs_server: none
- ssh:
- keys: "~/.ssh/id_rsa-acceptance"
- consoleport: 443
- datastore: instance0
- folder: Delivery/Quality Assurance/Enterprise/Dynamic
- resourcepool: delivery/Quality Assurance/Enterprise/Dynamic
- pooling_api: http://vcloud.delivery.puppetlabs.net/
- pe_dir: http://neptune.puppetlabs.lan/3.2/ci-ready/
diff --git a/spec/acceptance/nodesets/windows-2008-x86_64.yml b/spec/acceptance/nodesets/windows-2008-x86_64.yml
deleted file mode 100644
index ae3c11dd..00000000
--- a/spec/acceptance/nodesets/windows-2008-x86_64.yml
+++ /dev/null
@@ -1,26 +0,0 @@
-HOSTS:
- ubuntu1204:
- roles:
- - master
- - database
- - dashboard
- platform: ubuntu-12.04-amd64
- template: ubuntu-1204-x86_64
- hypervisor: vcloud
- win2008_x86_64:
- roles:
- - agent
- - default
- platform: windows-2008-x86_64
- template: win-2008-x86_64
- hypervisor: vcloud
-CONFIG:
- nfs_server: none
- ssh:
- keys: "~/.ssh/id_rsa-acceptance"
- consoleport: 443
- datastore: instance0
- folder: Delivery/Quality Assurance/Enterprise/Dynamic
- resourcepool: delivery/Quality Assurance/Enterprise/Dynamic
- pooling_api: http://vcloud.delivery.puppetlabs.net/
- pe_dir: http://neptune.puppetlabs.lan/3.2/ci-ready/
diff --git a/spec/acceptance/nodesets/windows-2008r2-x86_64.yml b/spec/acceptance/nodesets/windows-2008r2-x86_64.yml
deleted file mode 100644
index 63923ac1..00000000
--- a/spec/acceptance/nodesets/windows-2008r2-x86_64.yml
+++ /dev/null
@@ -1,26 +0,0 @@
-HOSTS:
- ubuntu1204:
- roles:
- - master
- - database
- - dashboard
- platform: ubuntu-12.04-amd64
- template: ubuntu-1204-x86_64
- hypervisor: vcloud
- win2008r2:
- roles:
- - agent
- - default
- platform: windows-2008r2-x86_64
- template: win-2008r2-x86_64
- hypervisor: vcloud
-CONFIG:
- nfs_server: none
- ssh:
- keys: "~/.ssh/id_rsa-acceptance"
- consoleport: 443
- datastore: instance0
- folder: Delivery/Quality Assurance/Enterprise/Dynamic
- resourcepool: delivery/Quality Assurance/Enterprise/Dynamic
- pooling_api: http://vcloud.delivery.puppetlabs.net/
- pe_dir: http://neptune.puppetlabs.lan/3.2/ci-ready/
diff --git a/spec/acceptance/nodesets/windows-2012-x86_64.yml b/spec/acceptance/nodesets/windows-2012-x86_64.yml
deleted file mode 100644
index eaa4eca9..00000000
--- a/spec/acceptance/nodesets/windows-2012-x86_64.yml
+++ /dev/null
@@ -1,26 +0,0 @@
-HOSTS:
- ubuntu1204:
- roles:
- - master
- - database
- - dashboard
- platform: ubuntu-12.04-amd64
- template: ubuntu-1204-x86_64
- hypervisor: vcloud
- win2012:
- roles:
- - agent
- - default
- platform: windows-2012-x86_64
- template: win-2012-x86_64
- hypervisor: vcloud
-CONFIG:
- nfs_server: none
- ssh:
- keys: "~/.ssh/id_rsa-acceptance"
- consoleport: 443
- datastore: instance0
- folder: Delivery/Quality Assurance/Enterprise/Dynamic
- resourcepool: delivery/Quality Assurance/Enterprise/Dynamic
- pooling_api: http://vcloud.delivery.puppetlabs.net/
- pe_dir: http://neptune.puppetlabs.lan/3.2/ci-ready/
diff --git a/spec/acceptance/nodesets/windows-2012r2-x86_64.yml b/spec/acceptance/nodesets/windows-2012r2-x86_64.yml
deleted file mode 100644
index 1f0ea97c..00000000
--- a/spec/acceptance/nodesets/windows-2012r2-x86_64.yml
+++ /dev/null
@@ -1,26 +0,0 @@
-HOSTS:
- ubuntu1204:
- roles:
- - master
- - database
- - dashboard
- platform: ubuntu-12.04-amd64
- template: ubuntu-1204-x86_64
- hypervisor: vcloud
- win2012r2:
- roles:
- - agent
- - default
- platform: windows-2012r2-x86_64
- template: win-2012r2-x86_64
- hypervisor: vcloud
-CONFIG:
- nfs_server: none
- ssh:
- keys: "~/.ssh/id_rsa-acceptance"
- consoleport: 443
- datastore: instance0
- folder: Delivery/Quality Assurance/Enterprise/Dynamic
- resourcepool: delivery/Quality Assurance/Enterprise/Dynamic
- pooling_api: http://vcloud.delivery.puppetlabs.net/
- pe_dir: http://neptune.puppetlabs.lan/3.2/ci-ready/
diff --git a/spec/acceptance/num2bool_spec.rb b/spec/acceptance/num2bool_spec.rb
deleted file mode 100755
index 1d99ba02..00000000
--- a/spec/acceptance/num2bool_spec.rb
+++ /dev/null
@@ -1,76 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'num2bool function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'bools positive numbers and numeric strings as true' do
- pp = <<-EOS
- $a = 1
- $b = "1"
- $c = "50"
- $ao = num2bool($a)
- $bo = num2bool($b)
- $co = num2bool($c)
- 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/)
- end
- end
- it 'bools negative numbers as false' do
- pp = <<-EOS
- $a = 0
- $b = -0.1
- $c = ["-50","1"]
- $ao = num2bool($a)
- $bo = num2bool($b)
- $co = num2bool($c)
- 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/)
- end
- end
- end
- describe 'failure' do
- it 'fails on words' do
- pp = <<-EOS
- $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/)
- end
-
- it 'fails on numberwords' do
- pp = <<-EOS
- $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/)
-
- 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
- $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/)
- end
- end
-end
diff --git a/spec/acceptance/parsejson_spec.rb b/spec/acceptance/parsejson_spec.rb
deleted file mode 100755
index 50978102..00000000
--- a/spec/acceptance/parsejson_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'parsejson function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'parses valid json' do
- pp = <<-EOS
- $a = '{"hunter": "washere", "tests": "passing"}'
- $ao = parsejson($a)
- $tests = $ao['tests']
- notice(inline_template('tests are <%= @tests.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/tests are "passing"/)
- end
- end
- end
- describe 'failure' do
- it 'raises error on incorrect json' do
- pp = <<-EOS
- $a = '{"hunter": "washere", "tests": "passing",}'
- $ao = parsejson($a)
- notice(inline_template('a is <%= @ao.inspect %>'))
- EOS
-
- apply_manifest(pp, :expect_failures => true) do |r|
- expect(r.stderr).to match(/expected next name/)
- end
- end
-
- it 'raises error on incorrect number of arguments'
- end
-end
diff --git a/spec/acceptance/parseyaml_spec.rb b/spec/acceptance/parseyaml_spec.rb
deleted file mode 100755
index 5819837c..00000000
--- a/spec/acceptance/parseyaml_spec.rb
+++ /dev/null
@@ -1,35 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'parseyaml function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'parses valid yaml' do
- pp = <<-EOS
- $a = "---\nhunter: washere\ntests: passing\n"
- $o = parseyaml($a)
- $tests = $o['tests']
- notice(inline_template('tests are <%= @tests.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/tests are "passing"/)
- end
- end
- end
- describe 'failure' do
- it 'raises error on incorrect yaml' do
- pp = <<-EOS
- $a = "---\nhunter: washere\ntests: passing\n:"
- $o = parseyaml($a)
- $tests = $o['tests']
- notice(inline_template('tests are <%= @tests.inspect %>'))
- EOS
-
- apply_manifest(pp, :expect_failures => true) do |r|
- expect(r.stderr).to match(/(syntax error|did not find expected key)/)
- end
- end
-
- it 'raises error on incorrect number of arguments'
- end
-end
diff --git a/spec/acceptance/pick_default_spec.rb b/spec/acceptance/pick_default_spec.rb
deleted file mode 100755
index a663f54e..00000000
--- a/spec/acceptance/pick_default_spec.rb
+++ /dev/null
@@ -1,54 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'pick_default function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'pick_defaults a default value' do
- pp = <<-EOS
- $a = undef
- $o = pick_default($a, 'default')
- notice(inline_template('picked is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/picked is "default"/)
- end
- end
- it 'pick_defaults with no value' do
- pp = <<-EOS
- $a = undef
- $b = undef
- $o = pick_default($a,$b)
- notice(inline_template('picked is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/picked is ""/)
- end
- end
- it 'pick_defaults the first set value' do
- pp = <<-EOS
- $a = "something"
- $b = "long"
- $o = pick_default($a, $b, 'default')
- notice(inline_template('picked is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/picked is "something"/)
- end
- end
- end
- describe 'failure' do
- it 'raises error with no values' do
- pp = <<-EOS
- $o = pick_default()
- notice(inline_template('picked is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :expect_failures => true) do |r|
- expect(r.stderr).to match(/Must receive at least one argument/)
- end
- end
- end
-end
diff --git a/spec/acceptance/pick_spec.rb b/spec/acceptance/pick_spec.rb
deleted file mode 100755
index 46cf63f2..00000000
--- a/spec/acceptance/pick_spec.rb
+++ /dev/null
@@ -1,44 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'pick function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'picks a default value' do
- pp = <<-EOS
- $a = undef
- $o = pick($a, 'default')
- notice(inline_template('picked is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/picked is "default"/)
- end
- end
- it 'picks the first set value' do
- pp = <<-EOS
- $a = "something"
- $b = "long"
- $o = pick($a, $b, 'default')
- notice(inline_template('picked is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/picked is "something"/)
- end
- end
- end
- describe 'failure' do
- it 'raises error with all undef values' do
- pp = <<-EOS
- $a = undef
- $b = undef
- $o = pick($a, $b)
- notice(inline_template('picked is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :expect_failures => true) do |r|
- expect(r.stderr).to match(/must receive at least one non empty value/)
- end
- end
- end
-end
diff --git a/spec/acceptance/prefix_spec.rb b/spec/acceptance/prefix_spec.rb
deleted file mode 100755
index de55530e..00000000
--- a/spec/acceptance/prefix_spec.rb
+++ /dev/null
@@ -1,42 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'prefix function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'prefixes array of values' do
- pp = <<-EOS
- $o = prefix(['a','b','c'],'p')
- notice(inline_template('prefix is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/prefix is \["pa", "pb", "pc"\]/)
- end
- end
- it 'prefixs with empty array' do
- pp = <<-EOS
- $o = prefix([],'p')
- notice(inline_template('prefix is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/prefix is \[\]/)
- end
- end
- it 'prefixs array of values with undef' do
- pp = <<-EOS
- $o = prefix(['a','b','c'], undef)
- notice(inline_template('prefix is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/prefix is \["a", "b", "c"\]/)
- end
- end
- end
- describe 'failure' do
- it 'fails with no arguments'
- it 'fails when first argument is not array'
- it 'fails when second argument is not string'
- end
-end
diff --git a/spec/acceptance/range_spec.rb b/spec/acceptance/range_spec.rb
deleted file mode 100755
index a3ccd339..00000000
--- a/spec/acceptance/range_spec.rb
+++ /dev/null
@@ -1,36 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'range function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'ranges letters' do
- pp = <<-EOS
- $o = range('a','d')
- notice(inline_template('range is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/range is \["a", "b", "c", "d"\]/)
- end
- end
- it 'ranges letters with a step' do
- pp = <<-EOS
- $o = range('a','d', '2')
- notice(inline_template('range is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/range is \["a", "c"\]/)
- end
- end
- it 'ranges letters with a negative step'
- it 'ranges numbers'
- it 'ranges numbers with a step'
- it 'ranges numbers with a negative step'
- it 'ranges numeric strings'
- it 'ranges zero padded numbers'
- end
- describe 'failure' do
- it 'fails with no arguments'
- end
-end
diff --git a/spec/acceptance/reject_spec.rb b/spec/acceptance/reject_spec.rb
deleted file mode 100755
index 7f16a008..00000000
--- a/spec/acceptance/reject_spec.rb
+++ /dev/null
@@ -1,42 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'reject function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'rejects array of values' do
- pp = <<-EOS
- $o = reject(['aaa','bbb','ccc','aaaddd'], 'aaa')
- notice(inline_template('reject is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/reject is \["bbb", "ccc"\]/)
- end
- end
- it 'rejects with empty array' do
- pp = <<-EOS
- $o = reject([],'aaa')
- notice(inline_template('reject is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/reject is \[\]/)
- end
- end
- it 'rejects array of values with undef' do
- pp = <<-EOS
- $o = reject(['aaa','bbb','ccc','aaaddd'], undef)
- notice(inline_template('reject is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/reject is \[\]/)
- end
- end
- end
- describe 'failure' do
- it 'fails with no arguments'
- it 'fails when first argument is not array'
- it 'fails when second argument is not string'
- end
-end
diff --git a/spec/acceptance/reverse_spec.rb b/spec/acceptance/reverse_spec.rb
deleted file mode 100755
index c3f01567..00000000
--- a/spec/acceptance/reverse_spec.rb
+++ /dev/null
@@ -1,23 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'reverse function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'reverses strings' do
- pp = <<-EOS
- $a = "the public art galleries"
- # Anagram: Large picture halls, I bet
- $o = reverse($a)
- notice(inline_template('reverse is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/reverse is "seirellag tra cilbup eht"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/rstrip_spec.rb b/spec/acceptance/rstrip_spec.rb
deleted file mode 100755
index b57a8b04..00000000
--- a/spec/acceptance/rstrip_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'rstrip function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'rstrips arrays' do
- pp = <<-EOS
- $a = [" the "," public "," art","galleries "]
- # Anagram: Large picture halls, I bet
- $o = rstrip($a)
- notice(inline_template('rstrip is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/rstrip is \[" the", " public", " art", "galleries"\]/)
- end
- end
- it 'rstrips strings' do
- pp = <<-EOS
- $a = " blowzy night-frumps vex'd jack q "
- $o = rstrip($a)
- notice(inline_template('rstrip is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/rstrip is " blowzy night-frumps vex'd jack q"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/shuffle_spec.rb b/spec/acceptance/shuffle_spec.rb
deleted file mode 100755
index b840d1f1..00000000
--- a/spec/acceptance/shuffle_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'shuffle function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'shuffles arrays' do
- pp = <<-EOS
- $a = ["1", "2", "3", "4", "5", "6", "7", "8", "the","public","art","galleries"]
- # Anagram: Large picture halls, I bet
- $o = shuffle($a)
- notice(inline_template('shuffle is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to_not match(/shuffle is \["1", "2", "3", "4", "5", "6", "7", "8", "the", "public", "art", "galleries"\]/)
- end
- end
- it 'shuffles strings' do
- pp = <<-EOS
- $a = "blowzy night-frumps vex'd jack q"
- $o = shuffle($a)
- notice(inline_template('shuffle is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to_not match(/shuffle is "blowzy night-frumps vex'd jack q"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/size_spec.rb b/spec/acceptance/size_spec.rb
deleted file mode 100755
index a52b778b..00000000
--- a/spec/acceptance/size_spec.rb
+++ /dev/null
@@ -1,55 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'size function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'single string size' do
- pp = <<-EOS
- $a = 'discombobulate'
- $o = size($a)
- notice(inline_template('size is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/size is 14/)
- end
- end
- it 'with empty string' do
- pp = <<-EOS
- $a = ''
- $o = size($a)
- notice(inline_template('size is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/size is 0/)
- end
- end
- it 'with undef' do
- pp = <<-EOS
- $a = undef
- $o = size($a)
- notice(inline_template('size is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/size is 0/)
- end
- end
- it 'strings in array' do
- pp = <<-EOS
- $a = ['discombobulate', 'moo']
- $o = size($a)
- notice(inline_template('size is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/size is 2/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/sort_spec.rb b/spec/acceptance/sort_spec.rb
deleted file mode 100755
index c85bfabd..00000000
--- a/spec/acceptance/sort_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'sort function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'sorts arrays' do
- pp = <<-EOS
- $a = ["the","public","art","galleries"]
- # Anagram: Large picture halls, I bet
- $o = sort($a)
- notice(inline_template('sort is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/sort is \["art", "galleries", "public", "the"\]/)
- end
- end
- it 'sorts strings' do
- pp = <<-EOS
- $a = "blowzy night-frumps vex'd jack q"
- $o = sort($a)
- notice(inline_template('sort is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/sort is " '-abcdefghijklmnopqrstuvwxyz"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/squeeze_spec.rb b/spec/acceptance/squeeze_spec.rb
deleted file mode 100755
index 400a458c..00000000
--- a/spec/acceptance/squeeze_spec.rb
+++ /dev/null
@@ -1,47 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'squeeze function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'squeezes arrays' do
- pp = <<-EOS
- # Real words!
- $a = ["wallless", "laparohysterosalpingooophorectomy", "brrr", "goddessship"]
- $o = squeeze($a)
- notice(inline_template('squeeze is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/squeeze is \["wales", "laparohysterosalpingophorectomy", "br", "godeship"\]/)
- end
- end
- it 'squeezez arrays with an argument'
- it 'squeezes strings' do
- pp = <<-EOS
- $a = "wallless laparohysterosalpingooophorectomy brrr goddessship"
- $o = squeeze($a)
- notice(inline_template('squeeze is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/squeeze is "wales laparohysterosalpingophorectomy br godeship"/)
- end
- end
-
- it 'squeezes strings with an argument' do
- pp = <<-EOS
- $a = "countessship duchessship governessship hostessship"
- $o = squeeze($a, 's')
- notice(inline_template('squeeze is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/squeeze is "counteship ducheship governeship hosteship"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/str2bool_spec.rb b/spec/acceptance/str2bool_spec.rb
deleted file mode 100755
index cf549dab..00000000
--- a/spec/acceptance/str2bool_spec.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'str2bool function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'works with "y"' do
- pp = <<-EOS
- $o = str2bool('y')
- notice(inline_template('str2bool is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/str2bool is true/)
- end
- end
- it 'works with "Y"'
- it 'works with "yes"'
- it 'works with "1"'
- it 'works with "true"'
- it 'works with "n"'
- it 'works with "N"'
- it 'works with "no"'
- it 'works with "0"'
- it 'works with "false"'
- it 'works with undef'
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non arrays or strings'
- end
-end
diff --git a/spec/acceptance/str2saltedsha512_spec.rb b/spec/acceptance/str2saltedsha512_spec.rb
deleted file mode 100755
index 993e63ba..00000000
--- a/spec/acceptance/str2saltedsha512_spec.rb
+++ /dev/null
@@ -1,22 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'str2saltedsha512 function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'works with "y"' do
- pp = <<-EOS
- $o = str2saltedsha512('password')
- notice(inline_template('str2saltedsha512 is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/str2saltedsha512 is "[a-f0-9]{136}"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles more than one argument'
- it 'handles non strings'
- end
-end
diff --git a/spec/acceptance/strftime_spec.rb b/spec/acceptance/strftime_spec.rb
deleted file mode 100755
index 53b7f903..00000000
--- a/spec/acceptance/strftime_spec.rb
+++ /dev/null
@@ -1,22 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'strftime function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'gives the Century' do
- pp = <<-EOS
- $o = strftime('%C')
- notice(inline_template('strftime is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/strftime is "20"/)
- end
- end
- it 'takes a timezone argument'
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles invalid format strings'
- end
-end
diff --git a/spec/acceptance/strip_spec.rb b/spec/acceptance/strip_spec.rb
deleted file mode 100755
index 906fd7ab..00000000
--- a/spec/acceptance/strip_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'strip function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'strips arrays' do
- pp = <<-EOS
- $a = [" the "," public "," art","galleries "]
- # Anagram: Large picture halls, I bet
- $o = strip($a)
- notice(inline_template('strip is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/strip is \["the", "public", "art", "galleries"\]/)
- end
- end
- it 'strips strings' do
- pp = <<-EOS
- $a = " blowzy night-frumps vex'd jack q "
- $o = strip($a)
- notice(inline_template('strip is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/strip is "blowzy night-frumps vex'd jack q"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/suffix_spec.rb b/spec/acceptance/suffix_spec.rb
deleted file mode 100755
index 630f866d..00000000
--- a/spec/acceptance/suffix_spec.rb
+++ /dev/null
@@ -1,42 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'suffix function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'suffixes array of values' do
- pp = <<-EOS
- $o = suffix(['a','b','c'],'p')
- notice(inline_template('suffix is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/suffix is \["ap", "bp", "cp"\]/)
- end
- end
- it 'suffixs with empty array' do
- pp = <<-EOS
- $o = suffix([],'p')
- notice(inline_template('suffix is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/suffix is \[\]/)
- end
- end
- it 'suffixs array of values with undef' do
- pp = <<-EOS
- $o = suffix(['a','b','c'], undef)
- notice(inline_template('suffix is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/suffix is \["a", "b", "c"\]/)
- end
- end
- end
- describe 'failure' do
- it 'fails with no arguments'
- it 'fails when first argument is not array'
- it 'fails when second argument is not string'
- end
-end
diff --git a/spec/acceptance/swapcase_spec.rb b/spec/acceptance/swapcase_spec.rb
deleted file mode 100755
index b7894fbe..00000000
--- a/spec/acceptance/swapcase_spec.rb
+++ /dev/null
@@ -1,22 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'swapcase function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'works with strings' do
- pp = <<-EOS
- $o = swapcase('aBcD')
- notice(inline_template('swapcase is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/swapcase is "AbCd"/)
- end
- end
- it 'works with arrays'
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non arrays or strings'
- end
-end
diff --git a/spec/acceptance/time_spec.rb b/spec/acceptance/time_spec.rb
deleted file mode 100755
index cdb29607..00000000
--- a/spec/acceptance/time_spec.rb
+++ /dev/null
@@ -1,36 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'time function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'gives the time' do
- pp = <<-EOS
- $o = time()
- notice(inline_template('time is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- m = r.stdout.match(/time is (\d+)\D/)
-
- # When I wrote this test
- expect(Integer(m[1])).to be > 1398894170
- end
- end
- it 'takes a timezone argument' do
- pp = <<-EOS
- $o = time('UTC')
- notice(inline_template('time is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- m = r.stdout.match(/time is (\d+)\D/)
-
- expect(Integer(m[1])).to be > 1398894170
- end
- end
- end
- describe 'failure' do
- it 'handles more arguments'
- it 'handles invalid timezones'
- end
-end
diff --git a/spec/acceptance/to_bytes_spec.rb b/spec/acceptance/to_bytes_spec.rb
deleted file mode 100755
index 2b4c61f4..00000000
--- a/spec/acceptance/to_bytes_spec.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'to_bytes function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'converts kB to B' do
- pp = <<-EOS
- $o = to_bytes('4 kB')
- notice(inline_template('to_bytes is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- m = r.stdout.match(/to_bytes is (\d+)\D/)
- expect(m[1]).to eq("4096")
- end
- end
- it 'works without the B in unit'
- it 'works without a space before unit'
- it 'works without a unit'
- it 'converts fractions'
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non integer arguments'
- it 'handles unknown units like uB'
- end
-end
diff --git a/spec/acceptance/type_spec.rb b/spec/acceptance/type_spec.rb
deleted file mode 100755
index 67e32480..00000000
--- a/spec/acceptance/type_spec.rb
+++ /dev/null
@@ -1,37 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'type function', :unless => (UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) || is_future_parser_enabled?) do
- describe 'success' do
- it 'types arrays' do
- pp = <<-EOS
- $a = ["the","public","art","galleries"]
- # Anagram: Large picture halls, I bet
- $o = type($a)
- notice(inline_template('type is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/type is "array"/)
- end
- end
- it 'types strings' do
- pp = <<-EOS
- $a = "blowzy night-frumps vex'd jack q"
- $o = type($a)
- notice(inline_template('type is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/type is "string"/)
- end
- end
- it 'types hashes'
- it 'types integers'
- it 'types floats'
- it 'types booleans'
- end
- describe 'failure' do
- it 'handles no arguments'
- end
-end
diff --git a/spec/acceptance/union_spec.rb b/spec/acceptance/union_spec.rb
deleted file mode 100755
index 6db8d0cf..00000000
--- a/spec/acceptance/union_spec.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'union function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'unions arrays' do
- pp = <<-EOS
- $a = ["the","public"]
- $b = ["art","galleries"]
- # Anagram: Large picture halls, I bet
- $o = union($a,$b)
- notice(inline_template('union is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/union is \["the", "public", "art", "galleries"\]/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non arrays'
- end
-end
diff --git a/spec/acceptance/unique_spec.rb b/spec/acceptance/unique_spec.rb
deleted file mode 100755
index bfadad19..00000000
--- a/spec/acceptance/unique_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'unique function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'uniques arrays' do
- pp = <<-EOS
- $a = ["wallless", "wallless", "brrr", "goddessship"]
- $o = unique($a)
- notice(inline_template('unique is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/unique is \["wallless", "brrr", "goddessship"\]/)
- end
- end
- it 'uniques strings' do
- pp = <<-EOS
- $a = "wallless laparohysterosalpingooophorectomy brrr goddessship"
- $o = unique($a)
- notice(inline_template('unique is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/unique is "wales prohytingcmbd"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/unsupported_spec.rb b/spec/acceptance/unsupported_spec.rb
deleted file mode 100755
index 1c559f67..00000000
--- a/spec/acceptance/unsupported_spec.rb
+++ /dev/null
@@ -1,11 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'unsupported distributions and OSes', :if => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- it 'should fail' do
- pp = <<-EOS
- class { 'mysql::server': }
- EOS
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/unsupported osfamily/i)
- end
-end
diff --git a/spec/acceptance/upcase_spec.rb b/spec/acceptance/upcase_spec.rb
deleted file mode 100755
index 3d2906d7..00000000
--- a/spec/acceptance/upcase_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'upcase function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'upcases arrays' do
- pp = <<-EOS
- $a = ["wallless", "laparohysterosalpingooophorectomy", "brrr", "goddessship"]
- $o = upcase($a)
- notice(inline_template('upcase is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/upcase is \["WALLLESS", "LAPAROHYSTEROSALPINGOOOPHORECTOMY", "BRRR", "GODDESSSHIP"\]/)
- end
- end
- it 'upcases strings' do
- pp = <<-EOS
- $a = "wallless laparohysterosalpingooophorectomy brrr goddessship"
- $o = upcase($a)
- notice(inline_template('upcase is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/upcase is "WALLLESS LAPAROHYSTEROSALPINGOOOPHORECTOMY BRRR GODDESSSHIP"/)
- end
- end
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/uriescape_spec.rb b/spec/acceptance/uriescape_spec.rb
deleted file mode 100755
index 7e30205e..00000000
--- a/spec/acceptance/uriescape_spec.rb
+++ /dev/null
@@ -1,23 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'uriescape function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'uriescape strings' do
- pp = <<-EOS
- $a = ":/?#[]@!$&'()*+,;= \\\"{}"
- $o = uriescape($a)
- notice(inline_template('uriescape is <%= @o.inspect %>'))
- EOS
-
- apply_manifest(pp, :catch_failures => true) do |r|
- expect(r.stdout).to match(/uriescape is ":\/\?%23\[\]@!\$&'\(\)\*\+,;=%20%22%7B%7D"/)
- end
- end
- it 'does nothing if a string is already safe'
- end
- describe 'failure' do
- it 'handles no arguments'
- it 'handles non strings or arrays'
- end
-end
diff --git a/spec/acceptance/validate_absolute_path_spec.rb b/spec/acceptance/validate_absolute_path_spec.rb
deleted file mode 100755
index 7082e848..00000000
--- a/spec/acceptance/validate_absolute_path_spec.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_absolute_path function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- %w{
- C:/
- C:\\\\
- C:\\\\WINDOWS\\\\System32
- C:/windows/system32
- X:/foo/bar
- X:\\\\foo\\\\bar
- /var/tmp
- /var/lib/puppet
- /var/opt/../lib/puppet
- }.each do |path|
- it "validates a single argument #{path}" do
- pp = <<-EOS
- $one = '#{path}'
- validate_absolute_path($one)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- it 'handles relative paths'
- end
-end
diff --git a/spec/acceptance/validate_array_spec.rb b/spec/acceptance/validate_array_spec.rb
deleted file mode 100755
index b53e98c2..00000000
--- a/spec/acceptance/validate_array_spec.rb
+++ /dev/null
@@ -1,37 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_array function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'validates a single argument' do
- pp = <<-EOS
- $one = ['a', 'b']
- validate_array($one)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates an multiple arguments' do
- pp = <<-EOS
- $one = ['a', 'b']
- $two = [['c'], 'd']
- validate_array($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates a non-array' do
- {
- %{validate_array({'a' => 'hash' })} => "Hash",
- %{validate_array('string')} => "String",
- %{validate_array(false)} => "FalseClass",
- %{validate_array(undef)} => "String"
- }.each do |pp,type|
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/a #{type}/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- end
-end
diff --git a/spec/acceptance/validate_augeas_spec.rb b/spec/acceptance/validate_augeas_spec.rb
deleted file mode 100755
index 71a4c842..00000000
--- a/spec/acceptance/validate_augeas_spec.rb
+++ /dev/null
@@ -1,63 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_augeas function', :unless => ((UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem'))) or (fact('osfamily') == 'windows')) do
- describe 'prep' do
- it 'installs augeas for tests'
- end
- describe 'success' do
- context 'valid inputs with no 3rd argument' do
- {
- 'root:x:0:0:root:/root:/bin/bash\n' => 'Passwd.lns',
- 'proc /proc proc nodev,noexec,nosuid 0 0\n' => 'Fstab.lns'
- }.each do |line,lens|
- it "validates a single argument for #{lens}" do
- pp = <<-EOS
- $line = "#{line}"
- $lens = "#{lens}"
- validate_augeas($line, $lens)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- end
- end
- context 'valid inputs with 3rd and 4th arguments' do
- it "validates a restricted value" do
- line = 'root:x:0:0:root:/root:/bin/barsh\n'
- lens = 'Passwd.lns'
- restriction = '$file/*[shell="/bin/barsh"]'
- pp = <<-EOS
- $line = "#{line}"
- $lens = "#{lens}"
- $restriction = ['#{restriction}']
- validate_augeas($line, $lens, $restriction, "my custom failure message")
- EOS
-
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/my custom failure message/)
- end
- end
- context 'invalid inputs' do
- {
- 'root:x:0:0:root' => 'Passwd.lns',
- '127.0.1.1' => 'Hosts.lns'
- }.each do |line,lens|
- it "validates a single argument for #{lens}" do
- pp = <<-EOS
- $line = "#{line}"
- $lens = "#{lens}"
- validate_augeas($line, $lens)
- EOS
-
- apply_manifest(pp, :expect_failures => true)
- end
- end
- end
- context 'garbage inputs' do
- it 'raises an error on invalid inputs'
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- end
-end
diff --git a/spec/acceptance/validate_bool_spec.rb b/spec/acceptance/validate_bool_spec.rb
deleted file mode 100755
index c837f089..00000000
--- a/spec/acceptance/validate_bool_spec.rb
+++ /dev/null
@@ -1,37 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_bool function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'validates a single argument' do
- pp = <<-EOS
- $one = true
- validate_bool($one)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates an multiple arguments' do
- pp = <<-EOS
- $one = true
- $two = false
- validate_bool($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates a non-bool' do
- {
- %{validate_bool('true')} => "String",
- %{validate_bool('false')} => "String",
- %{validate_bool([true])} => "Array",
- %{validate_bool(undef)} => "String",
- }.each do |pp,type|
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/a #{type}/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- end
-end
diff --git a/spec/acceptance/validate_cmd_spec.rb b/spec/acceptance/validate_cmd_spec.rb
deleted file mode 100755
index 5ac66fdb..00000000
--- a/spec/acceptance/validate_cmd_spec.rb
+++ /dev/null
@@ -1,52 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_cmd function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'validates a true command' do
- pp = <<-EOS
- $one = 'foo'
- if $::osfamily == 'windows' {
- $two = 'echo' #shell built-in
- } else {
- $two = '/bin/echo'
- }
- validate_cmd($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates a fail command' do
- pp = <<-EOS
- $one = 'foo'
- if $::osfamily == 'windows' {
- $two = 'C:/aoeu'
- } else {
- $two = '/bin/aoeu'
- }
- validate_cmd($one,$two)
- EOS
-
- apply_manifest(pp, :expect_failures => true)
- end
- it 'validates a fail command with a custom error message' do
- pp = <<-EOS
- $one = 'foo'
- if $::osfamily == 'windows' {
- $two = 'C:/aoeu'
- } else {
- $two = '/bin/aoeu'
- }
- validate_cmd($one,$two,"aoeu is dvorak")
- EOS
-
- apply_manifest(pp, :expect_failures => true) do |output|
- expect(output.stderr).to match(/aoeu is dvorak/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- it 'handles improper argument types'
- end
-end
diff --git a/spec/acceptance/validate_hash_spec.rb b/spec/acceptance/validate_hash_spec.rb
deleted file mode 100755
index 52fb615b..00000000
--- a/spec/acceptance/validate_hash_spec.rb
+++ /dev/null
@@ -1,37 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_hash function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'validates a single argument' do
- pp = <<-EOS
- $one = { 'a' => 1 }
- validate_hash($one)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates an multiple arguments' do
- pp = <<-EOS
- $one = { 'a' => 1 }
- $two = { 'b' => 2 }
- validate_hash($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates a non-hash' do
- {
- %{validate_hash('{ "not" => "hash" }')} => "String",
- %{validate_hash('string')} => "String",
- %{validate_hash(["array"])} => "Array",
- %{validate_hash(undef)} => "String",
- }.each do |pp,type|
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/a #{type}/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- end
-end
diff --git a/spec/acceptance/validate_ipv4_address_spec.rb b/spec/acceptance/validate_ipv4_address_spec.rb
deleted file mode 100755
index 64841c37..00000000
--- a/spec/acceptance/validate_ipv4_address_spec.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_ipv4_address function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'validates a single argument' do
- pp = <<-EOS
- $one = '1.2.3.4'
- validate_ipv4_address($one)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates an multiple arguments' do
- pp = <<-EOS
- $one = '1.2.3.4'
- $two = '5.6.7.8'
- validate_ipv4_address($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- it 'handles ipv6 addresses'
- it 'handles non-ipv4 strings'
- it 'handles numbers'
- it 'handles no arguments'
- end
-end
diff --git a/spec/acceptance/validate_ipv6_address_spec.rb b/spec/acceptance/validate_ipv6_address_spec.rb
deleted file mode 100755
index 6426d1a5..00000000
--- a/spec/acceptance/validate_ipv6_address_spec.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_ipv6_address function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'validates a single argument' do
- pp = <<-EOS
- $one = '3ffe:0505:0002::'
- validate_ipv6_address($one)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates an multiple arguments' do
- pp = <<-EOS
- $one = '3ffe:0505:0002::'
- $two = '3ffe:0505:0001::'
- validate_ipv6_address($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- it 'handles ipv6 addresses'
- it 'handles non-ipv6 strings'
- it 'handles numbers'
- it 'handles no arguments'
- end
-end
diff --git a/spec/acceptance/validate_re_spec.rb b/spec/acceptance/validate_re_spec.rb
deleted file mode 100755
index 22f6d47d..00000000
--- a/spec/acceptance/validate_re_spec.rb
+++ /dev/null
@@ -1,47 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_re function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'validates a string' do
- pp = <<-EOS
- $one = 'one'
- $two = '^one$'
- validate_re($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates an array' do
- pp = <<-EOS
- $one = 'one'
- $two = ['^one$', '^two']
- validate_re($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates a failed array' do
- pp = <<-EOS
- $one = 'one'
- $two = ['^two$', '^three']
- validate_re($one,$two)
- EOS
-
- apply_manifest(pp, :expect_failures => true)
- end
- it 'validates a failed array with a custom error message' do
- pp = <<-EOS
- $one = '3.4.3'
- $two = '^2.7'
- validate_re($one,$two,"The $puppetversion fact does not match 2.7")
- EOS
-
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/does not match/)
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- it 'handles improper argument types'
- end
-end
diff --git a/spec/acceptance/validate_slength_spec.rb b/spec/acceptance/validate_slength_spec.rb
deleted file mode 100755
index 1ab2bb98..00000000
--- a/spec/acceptance/validate_slength_spec.rb
+++ /dev/null
@@ -1,72 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_slength function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'validates a single string max' do
- pp = <<-EOS
- $one = 'discombobulate'
- $two = 17
- validate_slength($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates multiple string maxes' do
- pp = <<-EOS
- $one = ['discombobulate', 'moo']
- $two = 17
- validate_slength($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates min/max of strings in array' do
- pp = <<-EOS
- $one = ['discombobulate', 'moo']
- $two = 17
- $three = 3
- validate_slength($one,$two,$three)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates a single string max of incorrect length' do
- pp = <<-EOS
- $one = 'discombobulate'
- $two = 1
- validate_slength($one,$two)
- EOS
-
- apply_manifest(pp, :expect_failures => true)
- end
- it 'validates multiple string maxes of incorrect length' do
- pp = <<-EOS
- $one = ['discombobulate', 'moo']
- $two = 3
- validate_slength($one,$two)
- EOS
-
- apply_manifest(pp, :expect_failures => true)
- end
- it 'validates multiple strings min/maxes of incorrect length' do
- pp = <<-EOS
- $one = ['discombobulate', 'moo']
- $two = 17
- $three = 10
- validate_slength($one,$two,$three)
- EOS
-
- apply_manifest(pp, :expect_failures => true)
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- it 'handles improper first argument type'
- it 'handles non-strings in array of first argument'
- it 'handles improper second argument type'
- it 'handles improper third argument type'
- it 'handles negative ranges'
- it 'handles improper ranges'
- end
-end
diff --git a/spec/acceptance/validate_string_spec.rb b/spec/acceptance/validate_string_spec.rb
deleted file mode 100755
index 8956f48c..00000000
--- a/spec/acceptance/validate_string_spec.rb
+++ /dev/null
@@ -1,36 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'validate_string function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'validates a single argument' do
- pp = <<-EOS
- $one = 'string'
- validate_string($one)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates an multiple arguments' do
- pp = <<-EOS
- $one = 'string'
- $two = 'also string'
- validate_string($one,$two)
- EOS
-
- apply_manifest(pp, :catch_failures => true)
- end
- it 'validates a non-string' do
- {
- %{validate_string({ 'a' => 'hash' })} => "Hash",
- %{validate_string(['array'])} => "Array",
- %{validate_string(false)} => "FalseClass",
- }.each do |pp,type|
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/a #{type}/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments'
- end
-end
diff --git a/spec/acceptance/values_at_spec.rb b/spec/acceptance/values_at_spec.rb
deleted file mode 100755
index da63cf30..00000000
--- a/spec/acceptance/values_at_spec.rb
+++ /dev/null
@@ -1,73 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'values_at function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'returns a specific value' do
- pp = <<-EOS
- $one = ['a','b','c','d','e']
- $two = 1
- $output = values_at($one,$two)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
-
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\["b"\]/)
- end
- it 'returns a specific negative index value' do
- pending("negative numbers don't work")
- pp = <<-EOS
- $one = ['a','b','c','d','e']
- $two = -1
- $output = values_at($one,$two)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
-
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\["e"\]/)
- end
- it 'returns a range of values' do
- pp = <<-EOS
- $one = ['a','b','c','d','e']
- $two = "1-3"
- $output = values_at($one,$two)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
-
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\["b", "c", "d"\]/)
- end
- it 'returns a negative specific value and range of values' do
- pp = <<-EOS
- $one = ['a','b','c','d','e']
- $two = ["1-3",0]
- $output = values_at($one,$two)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
-
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\["b", "c", "d", "a"\]/)
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments' do
- pp = <<-EOS
- $one = ['a','b','c','d','e']
- $output = values_at($one)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
-
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/Wrong number of arguments/)
- end
- it 'handles non-indicies arguments' do
- pp = <<-EOS
- $one = ['a','b','c','d','e']
- $two = []
- $output = values_at($one,$two)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
-
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/at least one positive index/)
- end
-
- it 'detects index ranges smaller than the start range'
- it 'handles index ranges larger than array'
- it 'handles non-integer indicies'
- end
-end
diff --git a/spec/acceptance/values_spec.rb b/spec/acceptance/values_spec.rb
deleted file mode 100755
index a2eff329..00000000
--- a/spec/acceptance/values_spec.rb
+++ /dev/null
@@ -1,35 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-
-describe 'values function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'returns an array of values' do
- pp = <<-EOS
- $arg = {
- 'a' => 1,
- 'b' => 2,
- 'c' => 3,
- }
- $output = values($arg)
- notice(inline_template('<%= @output.sort.inspect %>'))
- EOS
- if is_future_parser_enabled?
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\[1, 2, 3\]/)
- else
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\["1", "2", "3"\]/)
- end
-
- end
- end
- describe 'failure' do
- it 'handles non-hash arguments' do
- pp = <<-EOS
- $arg = "foo"
- $output = values($arg)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
-
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/Requires hash/)
- end
- end
-end
diff --git a/spec/acceptance/zip_spec.rb b/spec/acceptance/zip_spec.rb
deleted file mode 100755
index 139079e3..00000000
--- a/spec/acceptance/zip_spec.rb
+++ /dev/null
@@ -1,86 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper_acceptance'
-require 'puppet'
-
-describe 'zip function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
- describe 'success' do
- it 'zips two arrays of numbers together' do
- pp = <<-EOS
- $one = [1,2,3,4]
- $two = [5,6,7,8]
- $output = zip($one,$two)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
- if is_future_parser_enabled?
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\[\[1, 5\], \[2, 6\], \[3, 7\], \[4, 8\]\]/)
- else
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\[\["1", "5"\], \["2", "6"\], \["3", "7"\], \["4", "8"\]\]/)
- end
- end
- it 'zips two arrays of numbers & bools together' do
- pp = <<-EOS
- $one = [1,2,"three",4]
- $two = [true,true,false,false]
- $output = zip($one,$two)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
- if is_future_parser_enabled?
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\[\[1, true\], \[2, true\], \["three", false\], \[4, false\]\]/)
- else
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\[\["1", true\], \["2", true\], \["three", false\], \["4", false\]\]/)
- end
- end
- it 'zips two arrays of numbers together and flattens them' do
- # XXX This only tests the argument `true`, even though the following are valid:
- # 1 t y true yes
- # 0 f n false no
- # undef undefined
- pp = <<-EOS
- $one = [1,2,3,4]
- $two = [5,6,7,8]
- $output = zip($one,$two,true)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
- if is_future_parser_enabled?
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\[1, 5, 2, 6, 3, 7, 4, 8\]/)
- else
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\["1", "5", "2", "6", "3", "7", "4", "8"\]/)
- end
- end
- it 'handles unmatched length' do
- # XXX Is this expected behavior?
- pp = <<-EOS
- $one = [1,2]
- $two = [5,6,7,8]
- $output = zip($one,$two)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
- if is_future_parser_enabled?
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\[\[1, 5\], \[2, 6\]\]/)
- else
- expect(apply_manifest(pp, :catch_failures => true).stdout).to match(/\[\["1", "5"\], \["2", "6"\]\]/)
- end
- end
- end
- describe 'failure' do
- it 'handles improper number of arguments' do
- pp = <<-EOS
- $one = [1,2]
- $output = zip($one)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
-
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/Wrong number of arguments/)
- end
- it 'handles improper argument types' do
- pp = <<-EOS
- $one = "a string"
- $two = [5,6,7,8]
- $output = zip($one,$two)
- notice(inline_template('<%= @output.inspect %>'))
- EOS
-
- expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/Requires array/)
- end
- end
-end
diff --git a/spec/classes/anchor_spec.rb b/spec/classes/anchor_spec.rb
deleted file mode 100755
index 2d4455e4..00000000
--- a/spec/classes/anchor_spec.rb
+++ /dev/null
@@ -1,30 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-require 'puppet_spec/compiler'
-
-describe "anchorrefresh" do
- include PuppetSpec::Compiler
-
- let :transaction do
- apply_compiled_manifest(<<-ANCHORCLASS)
- class anchored {
- anchor { 'anchored::begin': }
- ~> anchor { 'anchored::end': }
- }
-
- class anchorrefresh {
- notify { 'first': }
- ~> class { 'anchored': }
- ~> anchor { 'final': }
- }
-
- include anchorrefresh
- ANCHORCLASS
- end
-
- it 'propagates events through the anchored class' do
- resource = transaction.resource_status('Anchor[final]')
-
- expect(resource.restarted).to eq(true)
- end
-end
diff --git a/spec/fixtures/dscacheutil/root b/spec/fixtures/dscacheutil/root
deleted file mode 100644
index 1e34519b..00000000
--- a/spec/fixtures/dscacheutil/root
+++ /dev/null
@@ -1,8 +0,0 @@
-name: root
-password: *
-uid: 0
-gid: 0
-dir: /var/root
-shell: /bin/bash
-gecos: rawr Root
-
diff --git a/spec/functions/abs_spec.rb b/spec/functions/abs_spec.rb
deleted file mode 100755
index 3c25ce28..00000000
--- a/spec/functions/abs_spec.rb
+++ /dev/null
@@ -1,25 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe "the abs function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("abs")).to eq("function_abs")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_abs([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should convert a negative number into a positive" do
- result = scope.function_abs(["-34"])
- expect(result).to(eq(34))
- end
-
- it "should do nothing with a positive number" do
- result = scope.function_abs(["5678"])
- expect(result).to(eq(5678))
- end
-end
diff --git a/spec/functions/any2array_spec.rb b/spec/functions/any2array_spec.rb
deleted file mode 100755
index 87cd04b5..00000000
--- a/spec/functions/any2array_spec.rb
+++ /dev/null
@@ -1,55 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the any2array function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("any2array")).to eq("function_any2array")
- end
-
- it "should return an empty array if there is less than 1 argument" do
- result = scope.function_any2array([])
- expect(result).to(eq([]))
- end
-
- it "should convert boolean true to [ true ] " do
- result = scope.function_any2array([true])
- expect(result).to(eq([true]))
- end
-
- it "should convert one object to [object]" do
- result = scope.function_any2array(['one'])
- expect(result).to(eq(['one']))
- end
-
- it "should convert multiple objects to [objects]" do
- result = scope.function_any2array(['one', 'two'])
- expect(result).to(eq(['one', 'two']))
- end
-
- it "should return empty array it was called with" do
- result = scope.function_any2array([[]])
- expect(result).to(eq([]))
- end
-
- it "should return one-member array it was called with" do
- result = scope.function_any2array([['string']])
- expect(result).to(eq(['string']))
- end
-
- it "should return multi-member array it was called with" do
- result = scope.function_any2array([['one', 'two']])
- expect(result).to(eq(['one', 'two']))
- end
-
- it "should return members of a hash it was called with" do
- result = scope.function_any2array([{ 'key' => 'value' }])
- expect(result).to(eq(['key', 'value']))
- end
-
- it "should return an empty array if it was called with an empty hash" do
- result = scope.function_any2array([{ }])
- expect(result).to(eq([]))
- end
-end
diff --git a/spec/functions/base64_spec.rb b/spec/functions/base64_spec.rb
deleted file mode 100755
index e93fafcd..00000000
--- a/spec/functions/base64_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe "the base64 function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("base64")).to eq("function_base64")
- end
-
- it "should raise a ParseError if there are other than 2 arguments" do
- expect { scope.function_base64([]) }.to(raise_error(Puppet::ParseError))
- expect { scope.function_base64(["asdf"]) }.to(raise_error(Puppet::ParseError))
- expect { scope.function_base64(["asdf","moo","cow"]) }.to(raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if argument 1 isn't 'encode' or 'decode'" do
- expect { scope.function_base64(["bees","astring"]) }.to(raise_error(Puppet::ParseError, /first argument must be one of/))
- end
-
- it "should raise a ParseError if argument 2 isn't a string" do
- expect { scope.function_base64(["encode",["2"]]) }.to(raise_error(Puppet::ParseError, /second argument must be a string/))
- end
-
- it "should encode a encoded string" do
- result = scope.function_base64(["encode",'thestring'])
- expect(result).to match(/\AdGhlc3RyaW5n\n\Z/)
- end
- it "should decode a base64 encoded string" do
- result = scope.function_base64(["decode",'dGhlc3RyaW5n'])
- expect(result).to eq('thestring')
- end
-end
diff --git a/spec/functions/bool2num_spec.rb b/spec/functions/bool2num_spec.rb
deleted file mode 100755
index 3904d7e4..00000000
--- a/spec/functions/bool2num_spec.rb
+++ /dev/null
@@ -1,38 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the bool2num function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("bool2num")).to eq("function_bool2num")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_bool2num([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should convert true to 1" do
- result = scope.function_bool2num([true])
- expect(result).to(eq(1))
- end
-
- it "should convert 'true' to 1" do
- result = scope.function_bool2num(['true'])
- result.should(eq(1))
- end
-
- it "should convert 'false' to 0" do
- result = scope.function_bool2num(['false'])
- expect(result).to(eq(0))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new('true')
- result = scope.function_bool2num([value])
- result.should(eq(1))
- end
-end
diff --git a/spec/functions/capitalize_spec.rb b/spec/functions/capitalize_spec.rb
deleted file mode 100755
index fd0e92ba..00000000
--- a/spec/functions/capitalize_spec.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the capitalize function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("capitalize")).to eq("function_capitalize")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_capitalize([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should capitalize the beginning of a string" do
- result = scope.function_capitalize(["abc"])
- expect(result).to(eq("Abc"))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new('abc')
- result = scope.function_capitalize([value])
- result.should(eq('Abc'))
- end
-end
diff --git a/spec/functions/chomp_spec.rb b/spec/functions/chomp_spec.rb
deleted file mode 100755
index b1e1e60f..00000000
--- a/spec/functions/chomp_spec.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the chomp function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("chomp")).to eq("function_chomp")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_chomp([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should chomp the end of a string" do
- result = scope.function_chomp(["abc\n"])
- expect(result).to(eq("abc"))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new("abc\n")
- result = scope.function_chomp([value])
- result.should(eq("abc"))
- end
-end
diff --git a/spec/functions/chop_spec.rb b/spec/functions/chop_spec.rb
deleted file mode 100755
index c8a19519..00000000
--- a/spec/functions/chop_spec.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the chop function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("chop")).to eq("function_chop")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_chop([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should chop the end of a string" do
- result = scope.function_chop(["asdf\n"])
- expect(result).to(eq("asdf"))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new("abc\n")
- result = scope.function_chop([value])
- result.should(eq('abc'))
- end
-end
diff --git a/spec/functions/concat_spec.rb b/spec/functions/concat_spec.rb
deleted file mode 100755
index 49fa6bb3..00000000
--- a/spec/functions/concat_spec.rb
+++ /dev/null
@@ -1,50 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the concat function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should raise a ParseError if the client does not provide at least two arguments" do
- expect { scope.function_concat([]) }.to(raise_error(Puppet::ParseError))
- expect { scope.function_concat([[1]]) }.to(raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if the first parameter is not an array" do
- expect { scope.function_concat([1, []])}.to(raise_error(Puppet::ParseError))
- end
-
- it "should not raise a ParseError if the client provides more than two arguments" do
- expect { scope.function_concat([[1],[2],[3]]) }.not_to raise_error
- end
-
- it "should be able to concat an array" do
- result = scope.function_concat([['1','2','3'],['4','5','6']])
- expect(result).to(eq(['1','2','3','4','5','6']))
- end
-
- it "should be able to concat a primitive to an array" do
- result = scope.function_concat([['1','2','3'],'4'])
- expect(result).to(eq(['1','2','3','4']))
- end
-
- it "should not accidentally flatten nested arrays" do
- result = scope.function_concat([['1','2','3'],[['4','5'],'6']])
- expect(result).to(eq(['1','2','3',['4','5'],'6']))
- end
-
- it "should leave the original array intact" do
- array_original = ['1','2','3']
- result = scope.function_concat([array_original,['4','5','6']])
- array_original.should(eq(['1','2','3']))
- end
-
- it "should be able to concat multiple arrays" do
- result = scope.function_concat([['1','2','3'],['4','5','6'],['7','8','9']])
- expect(result).to(eq(['1','2','3','4','5','6','7','8','9']))
- end
-
- it "should be able to concat mix of primitives and arrays to a final array" do
- result = scope.function_concat([['1','2','3'],'4',['5','6','7']])
- expect(result).to(eq(['1','2','3','4','5','6','7']))
- end
-end
diff --git a/spec/functions/count_spec.rb b/spec/functions/count_spec.rb
deleted file mode 100755
index f8f1d484..00000000
--- a/spec/functions/count_spec.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe "the count function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("count")).to eq("function_count")
- end
-
- it "should raise a ArgumentError if there is more than 2 arguments" do
- expect { scope.function_count(['foo', 'bar', 'baz']) }.to( raise_error(ArgumentError))
- end
-
- it "should be able to count arrays" do
- expect(scope.function_count([["1","2","3"]])).to(eq(3))
- end
-
- it "should be able to count matching elements in arrays" do
- expect(scope.function_count([["1", "2", "2"], "2"])).to(eq(2))
- end
-
- it "should not count nil or empty strings" do
- expect(scope.function_count([["foo","bar",nil,""]])).to(eq(2))
- end
-
- it 'does not count an undefined hash key or an out of bound array index (which are both :undef)' do
- expect(scope.function_count([["foo",:undef,:undef]])).to eq(1)
- end
-end
diff --git a/spec/functions/deep_merge_spec.rb b/spec/functions/deep_merge_spec.rb
deleted file mode 100755
index 7087904a..00000000
--- a/spec/functions/deep_merge_spec.rb
+++ /dev/null
@@ -1,105 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:deep_merge) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- describe 'when calling deep_merge from puppet' do
- it "should not compile when no arguments are passed" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = '$x = deep_merge()'
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
-
- it "should not compile when 1 argument is passed" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = "$my_hash={'one' => 1}\n$x = deep_merge($my_hash)"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
- end
-
- describe 'when calling deep_merge on the scope instance' do
- it 'should require all parameters are hashes' do
- expect { new_hash = scope.function_deep_merge([{}, '2'])}.to raise_error(Puppet::ParseError, /unexpected argument type String/)
- expect { new_hash = scope.function_deep_merge([{}, 2])}.to raise_error(Puppet::ParseError, /unexpected argument type Fixnum/)
- end
-
- it 'should accept empty strings as puppet undef' do
- expect { new_hash = scope.function_deep_merge([{}, ''])}.not_to raise_error
- end
-
- it 'should be able to deep_merge two hashes' do
- new_hash = scope.function_deep_merge([{'one' => '1', 'two' => '1'}, {'two' => '2', 'three' => '2'}])
- expect(new_hash['one']).to eq('1')
- expect(new_hash['two']).to eq('2')
- expect(new_hash['three']).to eq('2')
- end
-
- it 'should deep_merge multiple hashes' do
- hash = scope.function_deep_merge([{'one' => 1}, {'one' => '2'}, {'one' => '3'}])
- expect(hash['one']).to eq('3')
- end
-
- it 'should accept empty hashes' do
- expect(scope.function_deep_merge([{},{},{}])).to eq({})
- end
-
- it 'should deep_merge subhashes' do
- hash = scope.function_deep_merge([{'one' => 1}, {'two' => 2, 'three' => { 'four' => 4 } }])
- expect(hash['one']).to eq(1)
- expect(hash['two']).to eq(2)
- expect(hash['three']).to eq({ 'four' => 4 })
- end
-
- it 'should append to subhashes' do
- hash = scope.function_deep_merge([{'one' => { 'two' => 2 } }, { 'one' => { 'three' => 3 } }])
- expect(hash['one']).to eq({ 'two' => 2, 'three' => 3 })
- end
-
- it 'should append to subhashes 2' do
- hash = scope.function_deep_merge([{'one' => 1, 'two' => 2, 'three' => { 'four' => 4 } }, {'two' => 'dos', 'three' => { 'five' => 5 } }])
- expect(hash['one']).to eq(1)
- expect(hash['two']).to eq('dos')
- expect(hash['three']).to eq({ 'four' => 4, 'five' => 5 })
- end
-
- it 'should append to subhashes 3' do
- hash = scope.function_deep_merge([{ 'key1' => { 'a' => 1, 'b' => 2 }, 'key2' => { 'c' => 3 } }, { 'key1' => { 'b' => 99 } }])
- expect(hash['key1']).to eq({ 'a' => 1, 'b' => 99 })
- expect(hash['key2']).to eq({ 'c' => 3 })
- end
-
- it 'should not change the original hashes' do
- hash1 = {'one' => { 'two' => 2 } }
- hash2 = { 'one' => { 'three' => 3 } }
- hash = scope.function_deep_merge([hash1, hash2])
- expect(hash1).to eq({'one' => { 'two' => 2 } })
- expect(hash2).to eq({ 'one' => { 'three' => 3 } })
- expect(hash['one']).to eq({ 'two' => 2, 'three' => 3 })
- end
-
- it 'should not change the original hashes 2' do
- hash1 = {'one' => { 'two' => [1,2] } }
- hash2 = { 'one' => { 'three' => 3 } }
- hash = scope.function_deep_merge([hash1, hash2])
- expect(hash1).to eq({'one' => { 'two' => [1,2] } })
- expect(hash2).to eq({ 'one' => { 'three' => 3 } })
- expect(hash['one']).to eq({ 'two' => [1,2], 'three' => 3 })
- end
-
- it 'should not change the original hashes 3' do
- hash1 = {'one' => { 'two' => [1,2, {'two' => 2} ] } }
- hash2 = { 'one' => { 'three' => 3 } }
- hash = scope.function_deep_merge([hash1, hash2])
- expect(hash1).to eq({'one' => { 'two' => [1,2, {'two' => 2}] } })
- expect(hash2).to eq({ 'one' => { 'three' => 3 } })
- expect(hash['one']).to eq({ 'two' => [1,2, {'two' => 2} ], 'three' => 3 })
- expect(hash['one']['two']).to eq([1,2, {'two' => 2}])
- end
- end
-end
diff --git a/spec/functions/defined_with_params_spec.rb b/spec/functions/defined_with_params_spec.rb
deleted file mode 100755
index 35903047..00000000
--- a/spec/functions/defined_with_params_spec.rb
+++ /dev/null
@@ -1,37 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-require 'rspec-puppet'
-describe 'defined_with_params' do
- describe 'when a resource is not specified' do
- it { is_expected.to run.with_params().and_raise_error(ArgumentError) }
- end
- describe 'when compared against a resource with no attributes' do
- let :pre_condition do
- 'user { "dan": }'
- end
- it do
- is_expected.to run.with_params('User[dan]', {}).and_return(true)
- is_expected.to run.with_params('User[bob]', {}).and_return(false)
- is_expected.to run.with_params('User[dan]', {'foo' => 'bar'}).and_return(false)
- end
- end
-
- describe 'when compared against a resource with attributes' do
- let :pre_condition do
- 'user { "dan": ensure => present, shell => "/bin/csh", managehome => false}'
- end
- it do
- is_expected.to run.with_params('User[dan]', {}).and_return(true)
- is_expected.to run.with_params('User[dan]', '').and_return(true)
- is_expected.to run.with_params('User[dan]', {'ensure' => 'present'}
- ).and_return(true)
- is_expected.to run.with_params('User[dan]',
- {'ensure' => 'present', 'managehome' => false}
- ).and_return(true)
- is_expected.to run.with_params('User[dan]',
- {'ensure' => 'absent', 'managehome' => false}
- ).and_return(false)
- end
- end
-end
diff --git a/spec/functions/delete_at_spec.rb b/spec/functions/delete_at_spec.rb
deleted file mode 100755
index 7c20aec4..00000000
--- a/spec/functions/delete_at_spec.rb
+++ /dev/null
@@ -1,25 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the delete_at function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("delete_at")).to eq("function_delete_at")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_delete_at([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should delete an item at specified location from an array" do
- result = scope.function_delete_at([['a','b','c'],1])
- expect(result).to(eq(['a','c']))
- end
-
- it "should not change origin array passed as argument" do
- origin_array = ['a','b','c','d']
- result = scope.function_delete_at([origin_array, 1])
- expect(origin_array).to(eq(['a','b','c','d']))
- end
-end
diff --git a/spec/functions/delete_spec.rb b/spec/functions/delete_spec.rb
deleted file mode 100755
index c8edd78e..00000000
--- a/spec/functions/delete_spec.rb
+++ /dev/null
@@ -1,61 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the delete function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("delete")).to eq("function_delete")
- end
-
- it "should raise a ParseError if there are fewer than 2 arguments" do
- expect { scope.function_delete([]) }.to(raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if there are greater than 2 arguments" do
- expect { scope.function_delete([[], 'foo', 'bar']) }.to(raise_error(Puppet::ParseError))
- end
-
- it "should raise a TypeError if a number is passed as the first argument" do
- expect { scope.function_delete([1, 'bar']) }.to(raise_error(TypeError))
- end
-
- it "should delete all instances of an element from an array" do
- result = scope.function_delete([['a', 'b', 'c', 'b'], 'b'])
- expect(result).to(eq(['a', 'c']))
- end
-
- it "should delete all instances of a substring from a string" do
- result = scope.function_delete(['foobarbabarz', 'bar'])
- expect(result).to(eq('foobaz'))
- end
-
- it "should delete a key from a hash" do
- result = scope.function_delete([{'a' => 1, 'b' => 2, 'c' => 3}, 'b'])
- expect(result).to(eq({'a' => 1, 'c' => 3}))
- end
-
- it 'should accept an array of items to delete' do
- result = scope.function_delete([{'a' => 1, 'b' => 2, 'c' => 3}, ['b', 'c']])
- expect(result).to(eq({'a' => 1}))
- end
-
- it "should not change origin array passed as argument" do
- origin_array = ['a', 'b', 'c', 'd']
- result = scope.function_delete([origin_array, 'b'])
- expect(origin_array).to(eq(['a', 'b', 'c', 'd']))
- end
-
- it "should not change the origin string passed as argument" do
- origin_string = 'foobarbabarz'
- result = scope.function_delete([origin_string, 'bar'])
- expect(origin_string).to(eq('foobarbabarz'))
- end
-
- it "should not change origin hash passed as argument" do
- origin_hash = {'a' => 1, 'b' => 2, 'c' => 3}
- result = scope.function_delete([origin_hash, 'b'])
- expect(origin_hash).to(eq({'a' => 1, 'b' => 2, 'c' => 3}))
- end
-
-end
diff --git a/spec/functions/delete_undef_values_spec.rb b/spec/functions/delete_undef_values_spec.rb
deleted file mode 100755
index dc679535..00000000
--- a/spec/functions/delete_undef_values_spec.rb
+++ /dev/null
@@ -1,41 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the delete_undef_values function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("delete_undef_values")).to eq("function_delete_undef_values")
- end
-
- it "should raise a ParseError if there is less than 1 argument" do
- expect { scope.function_delete_undef_values([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if the argument is not Array nor Hash" do
- expect { scope.function_delete_undef_values(['']) }.to( raise_error(Puppet::ParseError))
- expect { scope.function_delete_undef_values([nil]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should delete all undef items from Array and only these" do
- result = scope.function_delete_undef_values([['a',:undef,'c','undef']])
- expect(result).to(eq(['a','c','undef']))
- end
-
- it "should delete all undef items from Hash and only these" do
- result = scope.function_delete_undef_values([{'a'=>'A','b'=>:undef,'c'=>'C','d'=>'undef'}])
- expect(result).to(eq({'a'=>'A','c'=>'C','d'=>'undef'}))
- end
-
- it "should not change origin array passed as argument" do
- origin_array = ['a',:undef,'c','undef']
- result = scope.function_delete_undef_values([origin_array])
- expect(origin_array).to(eq(['a',:undef,'c','undef']))
- end
-
- it "should not change origin hash passed as argument" do
- origin_hash = { 'a' => 1, 'b' => :undef, 'c' => 'undef' }
- result = scope.function_delete_undef_values([origin_hash])
- expect(origin_hash).to(eq({ 'a' => 1, 'b' => :undef, 'c' => 'undef' }))
- end
-end
diff --git a/spec/functions/delete_values_spec.rb b/spec/functions/delete_values_spec.rb
deleted file mode 100755
index 4f4d411b..00000000
--- a/spec/functions/delete_values_spec.rb
+++ /dev/null
@@ -1,36 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the delete_values function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("delete_values")).to eq("function_delete_values")
- end
-
- it "should raise a ParseError if there are fewer than 2 arguments" do
- expect { scope.function_delete_values([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if there are greater than 2 arguments" do
- expect { scope.function_delete_values([[], 'foo', 'bar']) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should raise a TypeError if the argument is not a hash" do
- expect { scope.function_delete_values([1,'bar']) }.to( raise_error(TypeError))
- expect { scope.function_delete_values(['foo','bar']) }.to( raise_error(TypeError))
- expect { scope.function_delete_values([[],'bar']) }.to( raise_error(TypeError))
- end
-
- it "should delete all instances of a value from a hash" do
- result = scope.function_delete_values([{ 'a'=>'A', 'b'=>'B', 'B'=>'C', 'd'=>'B' },'B'])
- expect(result).to(eq({ 'a'=>'A', 'B'=>'C' }))
- end
-
- it "should not change origin hash passed as argument" do
- origin_hash = { 'a' => 1, 'b' => 2, 'c' => 3 }
- result = scope.function_delete_values([origin_hash, 2])
- expect(origin_hash).to(eq({ 'a' => 1, 'b' => 2, 'c' => 3 }))
- end
-
-end
diff --git a/spec/functions/difference_spec.rb b/spec/functions/difference_spec.rb
deleted file mode 100755
index 24b2b1bc..00000000
--- a/spec/functions/difference_spec.rb
+++ /dev/null
@@ -1,19 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the difference function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("difference")).to eq("function_difference")
- end
-
- it "should raise a ParseError if there are fewer than 2 arguments" do
- expect { scope.function_difference([]) }.to( raise_error(Puppet::ParseError) )
- end
-
- it "should return the difference between two arrays" do
- result = scope.function_difference([["a","b","c"],["b","c","d"]])
- expect(result).to(eq(["a"]))
- end
-end
diff --git a/spec/functions/dirname_spec.rb b/spec/functions/dirname_spec.rb
deleted file mode 100755
index 8a3bcabf..00000000
--- a/spec/functions/dirname_spec.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the dirname function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("dirname")).to eq("function_dirname")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_dirname([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return dirname for an absolute path" do
- result = scope.function_dirname(['/path/to/a/file.ext'])
- expect(result).to(eq('/path/to/a'))
- end
-
- it "should return dirname for a relative path" do
- result = scope.function_dirname(['path/to/a/file.ext'])
- expect(result).to(eq('path/to/a'))
- end
-end
diff --git a/spec/functions/downcase_spec.rb b/spec/functions/downcase_spec.rb
deleted file mode 100755
index edebc44f..00000000
--- a/spec/functions/downcase_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the downcase function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("downcase")).to eq("function_downcase")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_downcase([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should downcase a string" do
- result = scope.function_downcase(["ASFD"])
- expect(result).to(eq("asfd"))
- end
-
- it "should do nothing to a string that is already downcase" do
- result = scope.function_downcase(["asdf asdf"])
- expect(result).to(eq("asdf asdf"))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new("ASFD")
- result = scope.function_downcase([value])
- result.should(eq('asfd'))
- end
-end
diff --git a/spec/functions/empty_spec.rb b/spec/functions/empty_spec.rb
deleted file mode 100755
index 6a97c4cd..00000000
--- a/spec/functions/empty_spec.rb
+++ /dev/null
@@ -1,32 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the empty function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
- it "should exist" do
- expect(Puppet::Parser::Functions.function("empty")).to eq("function_empty")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_empty([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return a true for an empty string" do
- result = scope.function_empty([''])
- expect(result).to(eq(true))
- end
-
- it "should return a false for a non-empty string" do
- result = scope.function_empty(['asdf'])
- expect(result).to(eq(false))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new()
- result = scope.function_empty([value])
- result.should(eq(true))
- end
-end
diff --git a/spec/functions/ensure_packages_spec.rb b/spec/functions/ensure_packages_spec.rb
deleted file mode 100755
index 436be10b..00000000
--- a/spec/functions/ensure_packages_spec.rb
+++ /dev/null
@@ -1,81 +0,0 @@
-#! /usr/bin/env ruby
-
-require 'spec_helper'
-require 'rspec-puppet'
-require 'puppet_spec/compiler'
-
-describe 'ensure_packages' do
- include PuppetSpec::Compiler
-
- before :each do
- Puppet::Parser::Functions.autoloader.loadall
- Puppet::Parser::Functions.function(:ensure_packages)
- Puppet::Parser::Functions.function(:ensure_resource)
- Puppet::Parser::Functions.function(:defined_with_params)
- Puppet::Parser::Functions.function(:create_resources)
- end
-
- let :node do Puppet::Node.new('localhost') end
- let :compiler do Puppet::Parser::Compiler.new(node) end
- let :scope do
- if Puppet.version.to_f >= 3.0
- Puppet::Parser::Scope.new(compiler)
- else
- newscope = Puppet::Parser::Scope.new
- newscope.compiler = compiler
- newscope.source = Puppet::Resource::Type.new(:node, :localhost)
- newscope
- end
- end
-
- describe 'argument handling' do
- it 'fails with no arguments' do
- expect {
- scope.function_ensure_packages([])
- }.to raise_error(Puppet::ParseError, /0 for 1 or 2/)
- end
-
- it 'accepts an array of values' do
- scope.function_ensure_packages([['foo']])
- end
-
- it 'accepts a single package name as a string' do
- scope.function_ensure_packages(['foo'])
- end
- end
-
- context 'given a catalog with puppet package => absent' do
- let :catalog do
- compile_to_catalog(<<-EOS
- ensure_packages(['facter'])
- package { puppet: ensure => absent }
- EOS
- )
- end
-
- it 'has no effect on Package[puppet]' do
- expect(catalog.resource(:package, 'puppet')['ensure']).to eq('absent')
- end
- end
-
- context 'given a clean catalog' do
- let :catalog do
- compile_to_catalog('ensure_packages(["facter"])')
- end
-
- it 'declares package resources with ensure => present' do
- expect(catalog.resource(:package, 'facter')['ensure']).to eq('present')
- end
- end
-
- context 'given a clean catalog and specified defaults' do
- let :catalog do
- compile_to_catalog('ensure_packages(["facter"], {"provider" => "gem"})')
- end
-
- it 'declares package resources with ensure => present' do
- expect(catalog.resource(:package, 'facter')['ensure']).to eq('present')
- expect(catalog.resource(:package, 'facter')['provider']).to eq('gem')
- end
- end
-end
diff --git a/spec/functions/ensure_resource_spec.rb b/spec/functions/ensure_resource_spec.rb
deleted file mode 100755
index 33bcac0d..00000000
--- a/spec/functions/ensure_resource_spec.rb
+++ /dev/null
@@ -1,113 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-require 'rspec-puppet'
-require 'puppet_spec/compiler'
-
-describe 'ensure_resource' do
- include PuppetSpec::Compiler
-
- before :all do
- Puppet::Parser::Functions.autoloader.loadall
- Puppet::Parser::Functions.function(:ensure_packages)
- end
-
- let :node do Puppet::Node.new('localhost') end
- let :compiler do Puppet::Parser::Compiler.new(node) end
- let :scope do Puppet::Parser::Scope.new(compiler) end
-
- describe 'when a type or title is not specified' do
- it { expect { scope.function_ensure_resource([]) }.to raise_error }
- it { expect { scope.function_ensure_resource(['type']) }.to raise_error }
- end
-
- describe 'when compared against a resource with no attributes' do
- let :catalog do
- compile_to_catalog(<<-EOS
- user { "dan": }
- ensure_resource('user', 'dan', {})
- EOS
- )
- end
-
- it 'should contain the the ensured resources' do
- expect(catalog.resource(:user, 'dan').to_s).to eq('User[dan]')
- end
- end
-
- describe 'works when compared against a resource with non-conflicting attributes' do
- [
- "ensure_resource('User', 'dan', {})",
- "ensure_resource('User', 'dan', '')",
- "ensure_resource('User', 'dan', {'ensure' => 'present'})",
- "ensure_resource('User', 'dan', {'ensure' => 'present', 'managehome' => false})"
- ].each do |ensure_resource|
- pp = <<-EOS
- user { "dan": ensure => present, shell => "/bin/csh", managehome => false}
- #{ensure_resource}
- EOS
-
- it { expect { compile_to_catalog(pp) }.to_not raise_error }
- end
- end
-
- describe 'fails when compared against a resource with conflicting attributes' do
- pp = <<-EOS
- user { "dan": ensure => present, shell => "/bin/csh", managehome => false}
- ensure_resource('User', 'dan', {'ensure' => 'absent', 'managehome' => false})
- EOS
-
- it { expect { compile_to_catalog(pp) }.to raise_error }
- end
-
- describe 'when an array of new resources are passed in' do
- let :catalog do
- compile_to_catalog("ensure_resource('User', ['dan', 'alex'], {})")
- end
-
- it 'should contain the ensured resources' do
- expect(catalog.resource('User[dan]').to_s).to eq('User[dan]')
- expect(catalog.resource('User[alex]').to_s).to eq('User[alex]')
- end
- end
-
- describe 'when an array of existing resources is compared against existing resources' do
- pp = <<-EOS
- user { 'dan': ensure => present; 'alex': ensure => present }
- ensure_resource('User', ['dan', 'alex'], {})
- EOS
-
- let :catalog do
- compile_to_catalog(pp)
- end
-
- it 'should return the existing resources' do
- expect(catalog.resource('User[dan]').to_s).to eq('User[dan]')
- expect(catalog.resource('User[alex]').to_s).to eq('User[alex]')
- end
- end
-
- describe 'works when compared against existing resources with attributes' do
- [
- "ensure_resource('User', ['dan', 'alex'], {})",
- "ensure_resource('User', ['dan', 'alex'], '')",
- "ensure_resource('User', ['dan', 'alex'], {'ensure' => 'present'})",
- ].each do |ensure_resource|
- pp = <<-EOS
- user { 'dan': ensure => present; 'alex': ensure => present }
- #{ensure_resource}
- EOS
-
- it { expect { compile_to_catalog(pp) }.to_not raise_error }
- end
- end
-
- describe 'fails when compared against existing resources with conflicting attributes' do
- pp = <<-EOS
- user { 'dan': ensure => present; 'alex': ensure => present }
- ensure_resource('User', ['dan', 'alex'], {'ensure' => 'absent'})
- EOS
-
- it { expect { compile_to_catalog(pp) }.to raise_error }
- end
-
-end
diff --git a/spec/functions/flatten_spec.rb b/spec/functions/flatten_spec.rb
deleted file mode 100755
index de8c66d6..00000000
--- a/spec/functions/flatten_spec.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the flatten function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
- it "should exist" do
- expect(Puppet::Parser::Functions.function("flatten")).to eq("function_flatten")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_flatten([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if there is more than 1 argument" do
- expect { scope.function_flatten([[], []]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should flatten a complex data structure" do
- result = scope.function_flatten([["a","b",["c",["d","e"],"f","g"]]])
- expect(result).to(eq(["a","b","c","d","e","f","g"]))
- end
-
- it "should do nothing to a structure that is already flat" do
- result = scope.function_flatten([["a","b","c","d"]])
- expect(result).to(eq(["a","b","c","d"]))
- end
-end
diff --git a/spec/functions/floor_spec.rb b/spec/functions/floor_spec.rb
deleted file mode 100755
index 12a69179..00000000
--- a/spec/functions/floor_spec.rb
+++ /dev/null
@@ -1,39 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe "the floor function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("floor")).to eq("function_floor")
- end
-
- it "should raise a ParseError if there is less than 1 argument" do
- expect { scope.function_floor([]) }.to( raise_error(Puppet::ParseError, /Wrong number of arguments/))
- end
-
- it "should should raise a ParseError if input isn't numeric (eg. String)" do
- expect { scope.function_floor(["foo"]) }.to( raise_error(Puppet::ParseError, /Wrong argument type/))
- end
-
- it "should should raise a ParseError if input isn't numeric (eg. Boolean)" do
- expect { scope.function_floor([true]) }.to( raise_error(Puppet::ParseError, /Wrong argument type/))
- end
-
- it "should return an integer when a numeric type is passed" do
- result = scope.function_floor([12.4])
- expect(result.is_a?(Integer)).to(eq(true))
- end
-
- it "should return the input when an integer is passed" do
- result = scope.function_floor([7])
- expect(result).to(eq(7))
- end
-
- it "should return the largest integer less than or equal to the input" do
- result = scope.function_floor([3.8])
- expect(result).to(eq(3))
- end
-end
-
diff --git a/spec/functions/fqdn_rotate_spec.rb b/spec/functions/fqdn_rotate_spec.rb
deleted file mode 100755
index 40057d4f..00000000
--- a/spec/functions/fqdn_rotate_spec.rb
+++ /dev/null
@@ -1,43 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the fqdn_rotate function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("fqdn_rotate")).to eq("function_fqdn_rotate")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_fqdn_rotate([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should rotate a string and the result should be the same size" do
- scope.expects(:lookupvar).with("::fqdn").returns("127.0.0.1")
- result = scope.function_fqdn_rotate(["asdf"])
- expect(result.size).to(eq(4))
- end
-
- it "should rotate a string to give the same results for one host" do
- scope.expects(:lookupvar).with("::fqdn").returns("127.0.0.1").twice
- expect(scope.function_fqdn_rotate(["abcdefg"])).to eql(scope.function_fqdn_rotate(["abcdefg"]))
- end
-
- it "should rotate a string to give different values on different hosts" do
- scope.expects(:lookupvar).with("::fqdn").returns("127.0.0.1")
- val1 = scope.function_fqdn_rotate(["abcdefghijklmnopqrstuvwxyz01234567890987654321"])
- scope.expects(:lookupvar).with("::fqdn").returns("127.0.0.2")
- val2 = scope.function_fqdn_rotate(["abcdefghijklmnopqrstuvwxyz01234567890987654321"])
- expect(val1).not_to eql(val2)
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- scope.expects(:lookupvar).with("::fqdn").returns("127.0.0.1")
- value = AlsoString.new("asdf")
- result = scope.function_fqdn_rotate([value])
- result.size.should(eq(4))
- end
-end
diff --git a/spec/functions/get_module_path_spec.rb b/spec/functions/get_module_path_spec.rb
deleted file mode 100755
index 38ce6459..00000000
--- a/spec/functions/get_module_path_spec.rb
+++ /dev/null
@@ -1,46 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:get_module_path) do
- Internals = PuppetlabsSpec::PuppetInternals
- class StubModule
- attr_reader :path
- def initialize(path)
- @path = path
- end
- end
-
- def scope(environment = "production")
- Internals.scope(:compiler => Internals.compiler(:node => Internals.node(:environment => environment)))
- end
-
- it 'should only allow one argument' do
- expect { scope.function_get_module_path([]) }.to raise_error(Puppet::ParseError, /Wrong number of arguments, expects one/)
- expect { scope.function_get_module_path(['1','2','3']) }.to raise_error(Puppet::ParseError, /Wrong number of arguments, expects one/)
- end
- it 'should raise an exception when the module cannot be found' do
- expect { scope.function_get_module_path(['foo']) }.to raise_error(Puppet::ParseError, /Could not find module/)
- end
- describe 'when locating a module' do
- let(:modulepath) { "/tmp/does_not_exist" }
- let(:path_of_module_foo) { StubModule.new("/tmp/does_not_exist/foo") }
-
- before(:each) { Puppet[:modulepath] = modulepath }
-
- it 'should be able to find module paths from the modulepath setting' do
- Puppet::Module.expects(:find).with('foo', 'production').returns(path_of_module_foo)
- expect(scope.function_get_module_path(['foo'])).to eq(path_of_module_foo.path)
- end
- it 'should be able to find module paths when the modulepath is a list' do
- Puppet[:modulepath] = modulepath + ":/tmp"
- Puppet::Module.expects(:find).with('foo', 'production').returns(path_of_module_foo)
- expect(scope.function_get_module_path(['foo'])).to eq(path_of_module_foo.path)
- end
- it 'should respect the environment' do
- skip("Disabled on Puppet 2.6.x") if Puppet.version =~ /^2\.6\b/
- Puppet.settings[:environment] = 'danstestenv'
- Puppet::Module.expects(:find).with('foo', 'danstestenv').returns(path_of_module_foo)
- expect(scope('danstestenv').function_get_module_path(['foo'])).to eq(path_of_module_foo.path)
- end
- end
-end
diff --git a/spec/functions/getparam_spec.rb b/spec/functions/getparam_spec.rb
deleted file mode 100755
index 833c4d4f..00000000
--- a/spec/functions/getparam_spec.rb
+++ /dev/null
@@ -1,76 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-require 'rspec-puppet'
-require 'puppet_spec/compiler'
-
-describe 'getparam' do
- include PuppetSpec::Compiler
-
- before :each do
- Puppet::Parser::Functions.autoloader.loadall
- Puppet::Parser::Functions.function(:getparam)
- end
-
- let :node do Puppet::Node.new('localhost') end
- let :compiler do Puppet::Parser::Compiler.new(node) end
- if Puppet.version.to_f >= 3.0
- let :scope do Puppet::Parser::Scope.new(compiler) end
- else
- let :scope do
- newscope = Puppet::Parser::Scope.new
- newscope.compiler = compiler
- newscope.source = Puppet::Resource::Type.new(:node, :localhost)
- newscope
- end
- end
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("getparam")).to eq("function_getparam")
- end
-
- describe 'when a resource is not specified' do
- it { expect { scope.function_getparam([]) }.to raise_error }
- it { expect { scope.function_getparam(['User[dan]']) }.to raise_error }
- it { expect { scope.function_getparam(['User[dan]']) }.to raise_error }
- it { expect { scope.function_getparam(['User[dan]', {}]) }.to raise_error }
- # This seems to be OK because we just check for a string.
- it { expect { scope.function_getparam(['User[dan]', '']) }.to_not raise_error }
- end
-
- describe 'when compared against a resource with no params' do
- let :catalog do
- compile_to_catalog(<<-EOS
- user { "dan": }
- EOS
- )
- end
-
- it do
- expect(scope.function_getparam(['User[dan]', 'shell'])).to eq('')
- end
- end
-
- describe 'when compared against a resource with params' do
- let :catalog do
- compile_to_catalog(<<-EOS
- user { 'dan': ensure => present, shell => '/bin/sh', managehome => false}
- $test = getparam(User[dan], 'shell')
- EOS
- )
- end
-
- it do
- resource = Puppet::Parser::Resource.new(:user, 'dan', {:scope => scope})
- resource.set_parameter('ensure', 'present')
- resource.set_parameter('shell', '/bin/sh')
- resource.set_parameter('managehome', false)
- compiler.add_resource(scope, resource)
-
- expect(scope.function_getparam(['User[dan]', 'shell'])).to eq('/bin/sh')
- expect(scope.function_getparam(['User[dan]', ''])).to eq('')
- expect(scope.function_getparam(['User[dan]', 'ensure'])).to eq('present')
- # TODO: Expected this to be false, figure out why we're getting '' back.
- expect(scope.function_getparam(['User[dan]', 'managehome'])).to eq('')
- end
- end
-end
diff --git a/spec/functions/getvar_spec.rb b/spec/functions/getvar_spec.rb
deleted file mode 100755
index 87ab9b5a..00000000
--- a/spec/functions/getvar_spec.rb
+++ /dev/null
@@ -1,37 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:getvar) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
- describe 'when calling getvar from puppet' do
-
- it "should not compile when no arguments are passed" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = '$foo = getvar()'
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
-
- it "should not compile when too many arguments are passed" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = '$foo = getvar("foo::bar", "baz")'
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
-
- it "should lookup variables in other namespaces" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = <<-'ENDofPUPPETcode'
- class site::data { $foo = 'baz' }
- include site::data
- $foo = getvar("site::data::foo")
- if $foo != 'baz' {
- fail('getvar did not return what we expect')
- }
- ENDofPUPPETcode
- scope.compiler.compile
- end
- end
-end
diff --git a/spec/functions/grep_spec.rb b/spec/functions/grep_spec.rb
deleted file mode 100755
index 9c671dd8..00000000
--- a/spec/functions/grep_spec.rb
+++ /dev/null
@@ -1,19 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the grep function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("grep")).to eq("function_grep")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_grep([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should grep contents from an array" do
- result = scope.function_grep([["aaabbb","bbbccc","dddeee"], "bbb"])
- expect(result).to(eq(["aaabbb","bbbccc"]))
- end
-end
diff --git a/spec/functions/has_interface_with_spec.rb b/spec/functions/has_interface_with_spec.rb
deleted file mode 100755
index 23e09a95..00000000
--- a/spec/functions/has_interface_with_spec.rb
+++ /dev/null
@@ -1,64 +0,0 @@
-#!/usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:has_interface_with) do
-
- let(:scope) do
- PuppetlabsSpec::PuppetInternals.scope
- end
-
- # The subject of these examples is the method itself.
- subject do
- function_name = Puppet::Parser::Functions.function(:has_interface_with)
- scope.method(function_name)
- end
-
- # We need to mock out the Facts so we can specify how we expect this function
- # to behave on different platforms.
- context "On Mac OS X Systems" do
- before :each do
- scope.stubs(:lookupvar).with("interfaces").returns('lo0,gif0,stf0,en1,p2p0,fw0,en0,vmnet1,vmnet8,utun0')
- end
- it 'should have loopback (lo0)' do
- expect(subject.call(['lo0'])).to be_truthy
- end
- it 'should not have loopback (lo)' do
- expect(subject.call(['lo'])).to be_falsey
- end
- end
- context "On Linux Systems" do
- before :each do
- scope.stubs(:lookupvar).with("interfaces").returns('eth0,lo')
- scope.stubs(:lookupvar).with("ipaddress").returns('10.0.0.1')
- scope.stubs(:lookupvar).with("ipaddress_lo").returns('127.0.0.1')
- scope.stubs(:lookupvar).with("ipaddress_eth0").returns('10.0.0.1')
- scope.stubs(:lookupvar).with('muppet').returns('kermit')
- scope.stubs(:lookupvar).with('muppet_lo').returns('mspiggy')
- scope.stubs(:lookupvar).with('muppet_eth0').returns('kermit')
- end
- it 'should have loopback (lo)' do
- expect(subject.call(['lo'])).to be_truthy
- end
- it 'should not have loopback (lo0)' do
- expect(subject.call(['lo0'])).to be_falsey
- end
- it 'should have ipaddress with 127.0.0.1' do
- expect(subject.call(['ipaddress', '127.0.0.1'])).to be_truthy
- end
- it 'should have ipaddress with 10.0.0.1' do
- expect(subject.call(['ipaddress', '10.0.0.1'])).to be_truthy
- end
- it 'should not have ipaddress with 10.0.0.2' do
- expect(subject.call(['ipaddress', '10.0.0.2'])).to be_falsey
- end
- it 'should have muppet named kermit' do
- expect(subject.call(['muppet', 'kermit'])).to be_truthy
- end
- it 'should have muppet named mspiggy' do
- expect(subject.call(['muppet', 'mspiggy'])).to be_truthy
- end
- it 'should not have muppet named bigbird' do
- expect(subject.call(['muppet', 'bigbird'])).to be_falsey
- end
- end
-end
diff --git a/spec/functions/has_ip_address_spec.rb b/spec/functions/has_ip_address_spec.rb
deleted file mode 100755
index 0df12a7b..00000000
--- a/spec/functions/has_ip_address_spec.rb
+++ /dev/null
@@ -1,39 +0,0 @@
-#!/usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:has_ip_address) do
-
- let(:scope) do
- PuppetlabsSpec::PuppetInternals.scope
- end
-
- subject do
- function_name = Puppet::Parser::Functions.function(:has_ip_address)
- scope.method(function_name)
- end
-
- context "On Linux Systems" do
- before :each do
- scope.stubs(:lookupvar).with('interfaces').returns('eth0,lo')
- scope.stubs(:lookupvar).with('ipaddress').returns('10.0.2.15')
- scope.stubs(:lookupvar).with('ipaddress_eth0').returns('10.0.2.15')
- scope.stubs(:lookupvar).with('ipaddress_lo').returns('127.0.0.1')
- end
-
- it 'should have primary address (10.0.2.15)' do
- expect(subject.call(['10.0.2.15'])).to be_truthy
- end
-
- it 'should have lookupback address (127.0.0.1)' do
- expect(subject.call(['127.0.0.1'])).to be_truthy
- end
-
- it 'should not have other address' do
- expect(subject.call(['192.1681.1.1'])).to be_falsey
- end
-
- it 'should not have "mspiggy" on an interface' do
- expect(subject.call(['mspiggy'])).to be_falsey
- end
- end
-end
diff --git a/spec/functions/has_ip_network_spec.rb b/spec/functions/has_ip_network_spec.rb
deleted file mode 100755
index 2a2578e2..00000000
--- a/spec/functions/has_ip_network_spec.rb
+++ /dev/null
@@ -1,36 +0,0 @@
-#!/usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:has_ip_network) do
-
- let(:scope) do
- PuppetlabsSpec::PuppetInternals.scope
- end
-
- subject do
- function_name = Puppet::Parser::Functions.function(:has_ip_network)
- scope.method(function_name)
- end
-
- context "On Linux Systems" do
- before :each do
- scope.stubs(:lookupvar).with('interfaces').returns('eth0,lo')
- scope.stubs(:lookupvar).with('network').returns(:undefined)
- scope.stubs(:lookupvar).with('network_eth0').returns('10.0.2.0')
- scope.stubs(:lookupvar).with('network_lo').returns('127.0.0.1')
- end
-
- it 'should have primary network (10.0.2.0)' do
- expect(subject.call(['10.0.2.0'])).to be_truthy
- end
-
- it 'should have loopback network (127.0.0.0)' do
- expect(subject.call(['127.0.0.1'])).to be_truthy
- end
-
- it 'should not have other network' do
- expect(subject.call(['192.168.1.0'])).to be_falsey
- end
- end
-end
-
diff --git a/spec/functions/has_key_spec.rb b/spec/functions/has_key_spec.rb
deleted file mode 100755
index 6b718005..00000000
--- a/spec/functions/has_key_spec.rb
+++ /dev/null
@@ -1,42 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:has_key) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- describe 'when calling has_key from puppet' do
- it "should not compile when no arguments are passed" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = '$x = has_key()'
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
-
- it "should not compile when 1 argument is passed" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = "$x = has_key('foo')"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
-
- it "should require the first value to be a Hash" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = "$x = has_key('foo', 'bar')"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /expects the first argument to be a hash/)
- end
- end
-
- describe 'when calling the function has_key from a scope instance' do
- it 'should detect existing keys' do
- expect(scope.function_has_key([{'one' => 1}, 'one'])).to be_truthy
- end
-
- it 'should detect existing keys' do
- expect(scope.function_has_key([{'one' => 1}, 'two'])).to be_falsey
- end
- end
-end
diff --git a/spec/functions/hash_spec.rb b/spec/functions/hash_spec.rb
deleted file mode 100755
index ec2988b0..00000000
--- a/spec/functions/hash_spec.rb
+++ /dev/null
@@ -1,19 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the hash function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("hash")).to eq("function_hash")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_hash([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should convert an array to a hash" do
- result = scope.function_hash([['a',1,'b',2,'c',3]])
- expect(result).to(eq({'a'=>1,'b'=>2,'c'=>3}))
- end
-end
diff --git a/spec/functions/intersection_spec.rb b/spec/functions/intersection_spec.rb
deleted file mode 100755
index 6361304f..00000000
--- a/spec/functions/intersection_spec.rb
+++ /dev/null
@@ -1,19 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the intersection function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("intersection")).to eq("function_intersection")
- end
-
- it "should raise a ParseError if there are fewer than 2 arguments" do
- expect { scope.function_intersection([]) }.to( raise_error(Puppet::ParseError) )
- end
-
- it "should return the intersection of two arrays" do
- result = scope.function_intersection([["a","b","c"],["b","c","d"]])
- expect(result).to(eq(["b","c"]))
- end
-end
diff --git a/spec/functions/is_array_spec.rb b/spec/functions/is_array_spec.rb
deleted file mode 100755
index 94920a4c..00000000
--- a/spec/functions/is_array_spec.rb
+++ /dev/null
@@ -1,29 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_array function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_array")).to eq("function_is_array")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_is_array([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if passed an array" do
- result = scope.function_is_array([[1,2,3]])
- expect(result).to(eq(true))
- end
-
- it "should return false if passed a hash" do
- result = scope.function_is_array([{'a'=>1}])
- expect(result).to(eq(false))
- end
-
- it "should return false if passed a string" do
- result = scope.function_is_array(["asdf"])
- expect(result).to(eq(false))
- end
-end
diff --git a/spec/functions/is_bool_spec.rb b/spec/functions/is_bool_spec.rb
deleted file mode 100755
index 4a342ba4..00000000
--- a/spec/functions/is_bool_spec.rb
+++ /dev/null
@@ -1,44 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_bool function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_bool")).to eq("function_is_bool")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_is_bool([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if passed a TrueClass" do
- result = scope.function_is_bool([true])
- expect(result).to(eq(true))
- end
-
- it "should return true if passed a FalseClass" do
- result = scope.function_is_bool([false])
- expect(result).to(eq(true))
- end
-
- it "should return false if passed the string 'true'" do
- result = scope.function_is_bool(['true'])
- expect(result).to(eq(false))
- end
-
- it "should return false if passed the string 'false'" do
- result = scope.function_is_bool(['false'])
- expect(result).to(eq(false))
- end
-
- it "should return false if passed an array" do
- result = scope.function_is_bool([["a","b"]])
- expect(result).to(eq(false))
- end
-
- it "should return false if passed a hash" do
- result = scope.function_is_bool([{"a" => "b"}])
- expect(result).to(eq(false))
- end
-end
diff --git a/spec/functions/is_domain_name_spec.rb b/spec/functions/is_domain_name_spec.rb
deleted file mode 100755
index 4d05f5cd..00000000
--- a/spec/functions/is_domain_name_spec.rb
+++ /dev/null
@@ -1,64 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_domain_name function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_domain_name")).to eq("function_is_domain_name")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_is_domain_name([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if a valid short domain name" do
- result = scope.function_is_domain_name(["x.com"])
- expect(result).to(be_truthy)
- end
-
- it "should return true if the domain is ." do
- result = scope.function_is_domain_name(["."])
- expect(result).to(be_truthy)
- end
-
- it "should return true if the domain is x.com." do
- result = scope.function_is_domain_name(["x.com."])
- expect(result).to(be_truthy)
- end
-
- it "should return true if a valid domain name" do
- result = scope.function_is_domain_name(["foo.bar.com"])
- expect(result).to(be_truthy)
- end
-
- it "should allow domain parts to start with numbers" do
- result = scope.function_is_domain_name(["3foo.2bar.com"])
- expect(result).to(be_truthy)
- end
-
- it "should allow domain to end with a dot" do
- result = scope.function_is_domain_name(["3foo.2bar.com."])
- expect(result).to(be_truthy)
- end
-
- it "should allow a single part domain" do
- result = scope.function_is_domain_name(["orange"])
- expect(result).to(be_truthy)
- end
-
- it "should return false if domain parts start with hyphens" do
- result = scope.function_is_domain_name(["-3foo.2bar.com"])
- expect(result).to(be_falsey)
- end
-
- it "should return true if domain contains hyphens" do
- result = scope.function_is_domain_name(["3foo-bar.2bar-fuzz.com"])
- expect(result).to(be_truthy)
- end
-
- it "should return false if domain name contains spaces" do
- result = scope.function_is_domain_name(["not valid"])
- expect(result).to(be_falsey)
- end
-end
diff --git a/spec/functions/is_float_spec.rb b/spec/functions/is_float_spec.rb
deleted file mode 100755
index d926634e..00000000
--- a/spec/functions/is_float_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_float function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_float")).to eq("function_is_float")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_is_float([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if a float" do
- result = scope.function_is_float(["0.12"])
- expect(result).to(eq(true))
- end
-
- it "should return false if a string" do
- result = scope.function_is_float(["asdf"])
- expect(result).to(eq(false))
- end
-
- it "should return false if an integer" do
- result = scope.function_is_float(["3"])
- expect(result).to(eq(false))
- end
- it "should return true if a float is created from an arithmetical operation" do
- result = scope.function_is_float([3.2*2])
- expect(result).to(eq(true))
- end
-end
diff --git a/spec/functions/is_function_available.rb b/spec/functions/is_function_available.rb
deleted file mode 100755
index 3a9aa1b2..00000000
--- a/spec/functions/is_function_available.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#!/usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_function_available function" do
- before :all do
- Puppet::Parser::Functions.autoloader.loadall
- end
-
- before :each do
- @scope = Puppet::Parser::Scope.new
- end
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_function_available")).to eq("function_is_function_available")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { @scope.function_is_function_available([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return false if a nonexistent function is passed" do
- result = @scope.function_is_function_available(['jeff_mccunes_left_sock'])
- expect(result).to(eq(false))
- end
-
- it "should return true if an available function is passed" do
- result = @scope.function_is_function_available(['require'])
- expect(result).to(eq(true))
- end
-
-end
diff --git a/spec/functions/is_hash_spec.rb b/spec/functions/is_hash_spec.rb
deleted file mode 100755
index a8494111..00000000
--- a/spec/functions/is_hash_spec.rb
+++ /dev/null
@@ -1,29 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_hash function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_hash")).to eq("function_is_hash")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_is_hash([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if passed a hash" do
- result = scope.function_is_hash([{"a"=>1,"b"=>2}])
- expect(result).to(eq(true))
- end
-
- it "should return false if passed an array" do
- result = scope.function_is_hash([["a","b"]])
- expect(result).to(eq(false))
- end
-
- it "should return false if passed a string" do
- result = scope.function_is_hash(["asdf"])
- expect(result).to(eq(false))
- end
-end
diff --git a/spec/functions/is_integer_spec.rb b/spec/functions/is_integer_spec.rb
deleted file mode 100755
index f0cbca80..00000000
--- a/spec/functions/is_integer_spec.rb
+++ /dev/null
@@ -1,69 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_integer function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_integer")).to eq("function_is_integer")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_is_integer([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if an integer" do
- result = scope.function_is_integer(["3"])
- expect(result).to(eq(true))
- end
-
- it "should return true if a negative integer" do
- result = scope.function_is_integer(["-7"])
- expect(result).to(eq(true))
- end
-
- it "should return false if a float" do
- result = scope.function_is_integer(["3.2"])
- expect(result).to(eq(false))
- end
-
- it "should return false if a string" do
- result = scope.function_is_integer(["asdf"])
- expect(result).to(eq(false))
- end
-
- it "should return true if an integer is created from an arithmetical operation" do
- result = scope.function_is_integer([3*2])
- expect(result).to(eq(true))
- end
-
- it "should return false if an array" do
- result = scope.function_is_numeric([["asdf"]])
- expect(result).to(eq(false))
- end
-
- it "should return false if a hash" do
- result = scope.function_is_numeric([{"asdf" => false}])
- expect(result).to(eq(false))
- end
-
- it "should return false if a boolean" do
- result = scope.function_is_numeric([true])
- expect(result).to(eq(false))
- end
-
- it "should return false if a whitespace is in the string" do
- result = scope.function_is_numeric([" -1324"])
- expect(result).to(eq(false))
- end
-
- it "should return false if it is zero prefixed" do
- result = scope.function_is_numeric(["0001234"])
- expect(result).to(eq(false))
- end
-
- it "should return false if it is wrapped inside an array" do
- result = scope.function_is_numeric([[1234]])
- expect(result).to(eq(false))
- end
-end
diff --git a/spec/functions/is_ip_address_spec.rb b/spec/functions/is_ip_address_spec.rb
deleted file mode 100755
index c16d12b1..00000000
--- a/spec/functions/is_ip_address_spec.rb
+++ /dev/null
@@ -1,39 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_ip_address function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_ip_address")).to eq("function_is_ip_address")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_is_ip_address([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if an IPv4 address" do
- result = scope.function_is_ip_address(["1.2.3.4"])
- expect(result).to(eq(true))
- end
-
- it "should return true if a full IPv6 address" do
- result = scope.function_is_ip_address(["fe80:0000:cd12:d123:e2f8:47ff:fe09:dd74"])
- expect(result).to(eq(true))
- end
-
- it "should return true if a compressed IPv6 address" do
- result = scope.function_is_ip_address(["fe00::1"])
- expect(result).to(eq(true))
- end
-
- it "should return false if not valid" do
- result = scope.function_is_ip_address(["asdf"])
- expect(result).to(eq(false))
- end
-
- it "should return false if IP octets out of range" do
- result = scope.function_is_ip_address(["1.1.1.300"])
- expect(result).to(eq(false))
- end
-end
diff --git a/spec/functions/is_mac_address_spec.rb b/spec/functions/is_mac_address_spec.rb
deleted file mode 100755
index 66edd197..00000000
--- a/spec/functions/is_mac_address_spec.rb
+++ /dev/null
@@ -1,29 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_mac_address function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_mac_address")).to eq("function_is_mac_address")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_is_mac_address([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if a valid mac address" do
- result = scope.function_is_mac_address(["00:a0:1f:12:7f:a0"])
- expect(result).to(eq(true))
- end
-
- it "should return false if octets are out of range" do
- result = scope.function_is_mac_address(["00:a0:1f:12:7f:g0"])
- expect(result).to(eq(false))
- end
-
- it "should return false if not valid" do
- result = scope.function_is_mac_address(["not valid"])
- expect(result).to(eq(false))
- end
-end
diff --git a/spec/functions/is_numeric_spec.rb b/spec/functions/is_numeric_spec.rb
deleted file mode 100755
index 4176961d..00000000
--- a/spec/functions/is_numeric_spec.rb
+++ /dev/null
@@ -1,119 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_numeric function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_numeric")).to eq("function_is_numeric")
- end
-
- it "should raise a ParseError if there is less than 1 argument" do
- expect { scope.function_is_numeric([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if an integer" do
- result = scope.function_is_numeric(["3"])
- expect(result).to(eq(true))
- end
-
- it "should return true if a float" do
- result = scope.function_is_numeric(["3.2"])
- expect(result).to(eq(true))
- end
-
- it "should return true if an integer is created from an arithmetical operation" do
- result = scope.function_is_numeric([3*2])
- expect(result).to(eq(true))
- end
-
- it "should return true if a float is created from an arithmetical operation" do
- result = scope.function_is_numeric([3.2*2])
- expect(result).to(eq(true))
- end
-
- it "should return false if a string" do
- result = scope.function_is_numeric(["asdf"])
- expect(result).to(eq(false))
- end
-
- it "should return false if an array" do
- result = scope.function_is_numeric([["asdf"]])
- expect(result).to(eq(false))
- end
-
- it "should return false if an array of integers" do
- result = scope.function_is_numeric([[1,2,3,4]])
- expect(result).to(eq(false))
- end
-
- it "should return false if a hash" do
- result = scope.function_is_numeric([{"asdf" => false}])
- expect(result).to(eq(false))
- end
-
- it "should return false if a hash with numbers in it" do
- result = scope.function_is_numeric([{1 => 2}])
- expect(result).to(eq(false))
- end
-
- it "should return false if a boolean" do
- result = scope.function_is_numeric([true])
- expect(result).to(eq(false))
- end
-
- it "should return true if a negative float with exponent" do
- result = scope.function_is_numeric(["-342.2315e-12"])
- expect(result).to(eq(true))
- end
-
- it "should return false if a negative integer with whitespaces before/after the dash" do
- result = scope.function_is_numeric([" - 751"])
- expect(result).to(eq(false))
- end
-
-# it "should return true if a hexadecimal" do
-# result = scope.function_is_numeric(["0x52F8c"])
-# result.should(eq(true))
-# end
-#
-# it "should return true if a hexadecimal with uppercase 0X prefix" do
-# result = scope.function_is_numeric(["0X52F8c"])
-# result.should(eq(true))
-# end
-#
-# it "should return false if a hexadecimal without a prefix" do
-# result = scope.function_is_numeric(["52F8c"])
-# result.should(eq(false))
-# end
-#
-# it "should return true if a octal" do
-# result = scope.function_is_numeric(["0751"])
-# result.should(eq(true))
-# end
-#
-# it "should return true if a negative hexadecimal" do
-# result = scope.function_is_numeric(["-0x52F8c"])
-# result.should(eq(true))
-# end
-#
-# it "should return true if a negative octal" do
-# result = scope.function_is_numeric(["-0751"])
-# result.should(eq(true))
-# end
-#
-# it "should return false if a negative octal with whitespaces before/after the dash" do
-# result = scope.function_is_numeric([" - 0751"])
-# result.should(eq(false))
-# end
-#
-# it "should return false if a bad hexadecimal" do
-# result = scope.function_is_numeric(["0x23d7g"])
-# result.should(eq(false))
-# end
-#
-# it "should return false if a bad octal" do
-# result = scope.function_is_numeric(["0287"])
-# result.should(eq(false))
-# end
-end
diff --git a/spec/functions/is_string_spec.rb b/spec/functions/is_string_spec.rb
deleted file mode 100755
index 6a0801ae..00000000
--- a/spec/functions/is_string_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the is_string function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("is_string")).to eq("function_is_string")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_is_string([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if a string" do
- result = scope.function_is_string(["asdf"])
- expect(result).to(eq(true))
- end
-
- it "should return false if an integer" do
- result = scope.function_is_string(["3"])
- expect(result).to(eq(false))
- end
-
- it "should return false if a float" do
- result = scope.function_is_string(["3.23"])
- expect(result).to(eq(false))
- end
-
- it "should return false if an array" do
- result = scope.function_is_string([["a","b","c"]])
- expect(result).to(eq(false))
- end
-end
diff --git a/spec/functions/join_keys_to_values_spec.rb b/spec/functions/join_keys_to_values_spec.rb
deleted file mode 100755
index 4a9ae87a..00000000
--- a/spec/functions/join_keys_to_values_spec.rb
+++ /dev/null
@@ -1,40 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the join_keys_to_values function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("join_keys_to_values")).to eq("function_join_keys_to_values")
- end
-
- it "should raise a ParseError if there are fewer than two arguments" do
- expect { scope.function_join_keys_to_values([{}]) }.to raise_error Puppet::ParseError
- end
-
- it "should raise a ParseError if there are greater than two arguments" do
- expect { scope.function_join_keys_to_values([{}, 'foo', 'bar']) }.to raise_error Puppet::ParseError
- end
-
- it "should raise a TypeError if the first argument is an array" do
- expect { scope.function_join_keys_to_values([[1,2], ',']) }.to raise_error TypeError
- end
-
- it "should raise a TypeError if the second argument is an array" do
- expect { scope.function_join_keys_to_values([{}, [1,2]]) }.to raise_error TypeError
- end
-
- it "should raise a TypeError if the second argument is a number" do
- expect { scope.function_join_keys_to_values([{}, 1]) }.to raise_error TypeError
- end
-
- it "should return an empty array given an empty hash" do
- result = scope.function_join_keys_to_values([{}, ":"])
- expect(result).to eq([])
- end
-
- it "should join hash's keys to its values" do
- result = scope.function_join_keys_to_values([{'a'=>1,2=>'foo',:b=>nil}, ":"])
- expect(result).to match_array(['a:1','2:foo','b:'])
- end
-end
diff --git a/spec/functions/join_spec.rb b/spec/functions/join_spec.rb
deleted file mode 100755
index 793c36fa..00000000
--- a/spec/functions/join_spec.rb
+++ /dev/null
@@ -1,19 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the join function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("join")).to eq("function_join")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_join([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should join an array into a string" do
- result = scope.function_join([["a","b","c"], ":"])
- expect(result).to(eq("a:b:c"))
- end
-end
diff --git a/spec/functions/keys_spec.rb b/spec/functions/keys_spec.rb
deleted file mode 100755
index f2e7d428..00000000
--- a/spec/functions/keys_spec.rb
+++ /dev/null
@@ -1,21 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the keys function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("keys")).to eq("function_keys")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_keys([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return an array of keys when given a hash" do
- result = scope.function_keys([{'a'=>1, 'b'=>2}])
- # =~ performs 'array with same elements' (set) matching
- # For more info see RSpec::Matchers::MatchArray
- expect(result).to match_array(['a','b'])
- end
-end
diff --git a/spec/functions/loadyaml_spec.rb b/spec/functions/loadyaml_spec.rb
deleted file mode 100755
index cdc3d6f5..00000000
--- a/spec/functions/loadyaml_spec.rb
+++ /dev/null
@@ -1,25 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the loadyaml function" do
- include PuppetlabsSpec::Files
-
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("loadyaml")).to eq("function_loadyaml")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_loadyaml([]) }.to raise_error(Puppet::ParseError)
- end
-
- it "should convert YAML file to a data structure" do
- yaml_file = tmpfilename ('yamlfile')
- File.open(yaml_file, 'w') do |fh|
- fh.write("---\n aaa: 1\n bbb: 2\n ccc: 3\n ddd: 4\n")
- end
- result = scope.function_loadyaml([yaml_file])
- expect(result).to eq({"aaa" => 1, "bbb" => 2, "ccc" => 3, "ddd" => 4 })
- end
-end
diff --git a/spec/functions/lstrip_spec.rb b/spec/functions/lstrip_spec.rb
deleted file mode 100755
index 68cca1c5..00000000
--- a/spec/functions/lstrip_spec.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the lstrip function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("lstrip")).to eq("function_lstrip")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_lstrip([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should lstrip a string" do
- result = scope.function_lstrip([" asdf"])
- expect(result).to(eq('asdf'))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new(" asdf")
- result = scope.function_lstrip([value])
- result.should(eq("asdf"))
- end
-end
diff --git a/spec/functions/max_spec.rb b/spec/functions/max_spec.rb
deleted file mode 100755
index c3d8a132..00000000
--- a/spec/functions/max_spec.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe "the max function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("max")).to eq("function_max")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_max([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should be able to compare strings" do
- expect(scope.function_max(["albatross","dog","horse"])).to(eq("horse"))
- end
-
- it "should be able to compare numbers" do
- expect(scope.function_max([6,8,4])).to(eq(8))
- end
-
- it "should be able to compare a number with a stringified number" do
- expect(scope.function_max([1,"2"])).to(eq("2"))
- end
-end
diff --git a/spec/functions/member_spec.rb b/spec/functions/member_spec.rb
deleted file mode 100755
index 1a1d7c66..00000000
--- a/spec/functions/member_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the member function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("member")).to eq("function_member")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_member([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if a member is in an array" do
- result = scope.function_member([["a","b","c"], "a"])
- expect(result).to(eq(true))
- end
-
- it "should return false if a member is not in an array" do
- result = scope.function_member([["a","b","c"], "d"])
- expect(result).to(eq(false))
- end
-
- it "should return true if a member array is in an array" do
- result = scope.function_member([["a","b","c"], ["a", "b"]])
- expect(result).to(eq(true))
- end
-
- it "should return false if a member array is not in an array" do
- result = scope.function_member([["a","b","c"], ["d", "e"]])
- expect(result).to(eq(false))
- end
-end
diff --git a/spec/functions/merge_spec.rb b/spec/functions/merge_spec.rb
deleted file mode 100755
index 2abf9762..00000000
--- a/spec/functions/merge_spec.rb
+++ /dev/null
@@ -1,52 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:merge) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- describe 'when calling merge from puppet' do
- it "should not compile when no arguments are passed" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = '$x = merge()'
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
-
- it "should not compile when 1 argument is passed" do
- skip("Fails on 2.6.x, see bug #15912") if Puppet.version =~ /^2\.6\./
- Puppet[:code] = "$my_hash={'one' => 1}\n$x = merge($my_hash)"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
- end
-
- describe 'when calling merge on the scope instance' do
- it 'should require all parameters are hashes' do
- expect { new_hash = scope.function_merge([{}, '2'])}.to raise_error(Puppet::ParseError, /unexpected argument type String/)
- expect { new_hash = scope.function_merge([{}, 2])}.to raise_error(Puppet::ParseError, /unexpected argument type Fixnum/)
- end
-
- it 'should accept empty strings as puppet undef' do
- expect { new_hash = scope.function_merge([{}, ''])}.not_to raise_error
- end
-
- it 'should be able to merge two hashes' do
- new_hash = scope.function_merge([{'one' => '1', 'two' => '1'}, {'two' => '2', 'three' => '2'}])
- expect(new_hash['one']).to eq('1')
- expect(new_hash['two']).to eq('2')
- expect(new_hash['three']).to eq('2')
- end
-
- it 'should merge multiple hashes' do
- hash = scope.function_merge([{'one' => 1}, {'one' => '2'}, {'one' => '3'}])
- expect(hash['one']).to eq('3')
- end
-
- it 'should accept empty hashes' do
- expect(scope.function_merge([{},{},{}])).to eq({})
- end
- end
-end
diff --git a/spec/functions/min_spec.rb b/spec/functions/min_spec.rb
deleted file mode 100755
index 35a08900..00000000
--- a/spec/functions/min_spec.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe "the min function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("min")).to eq("function_min")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_min([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should be able to compare strings" do
- expect(scope.function_min(["albatross","dog","horse"])).to(eq("albatross"))
- end
-
- it "should be able to compare numbers" do
- expect(scope.function_min([6,8,4])).to(eq(4))
- end
-
- it "should be able to compare a number with a stringified number" do
- expect(scope.function_min([1,"2"])).to(eq(1))
- end
-end
diff --git a/spec/functions/num2bool_spec.rb b/spec/functions/num2bool_spec.rb
deleted file mode 100755
index d0ba9354..00000000
--- a/spec/functions/num2bool_spec.rb
+++ /dev/null
@@ -1,67 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the num2bool function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("num2bool")).to eq("function_num2bool")
- end
-
- it "should raise a ParseError if there are no arguments" do
- expect { scope.function_num2bool([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if there are more than 1 arguments" do
- expect { scope.function_num2bool(["foo","bar"]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if passed something non-numeric" do
- expect { scope.function_num2bool(["xyzzy"]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return true if passed string 1" do
- result = scope.function_num2bool(["1"])
- expect(result).to(be_truthy)
- end
-
- it "should return true if passed string 1.5" do
- result = scope.function_num2bool(["1.5"])
- expect(result).to(be_truthy)
- end
-
- it "should return true if passed number 1" do
- result = scope.function_num2bool([1])
- expect(result).to(be_truthy)
- end
-
- it "should return false if passed string 0" do
- result = scope.function_num2bool(["0"])
- expect(result).to(be_falsey)
- end
-
- it "should return false if passed number 0" do
- result = scope.function_num2bool([0])
- expect(result).to(be_falsey)
- end
-
- it "should return false if passed string -1" do
- result = scope.function_num2bool(["-1"])
- expect(result).to(be_falsey)
- end
-
- it "should return false if passed string -1.5" do
- result = scope.function_num2bool(["-1.5"])
- expect(result).to(be_falsey)
- end
-
- it "should return false if passed number -1" do
- result = scope.function_num2bool([-1])
- expect(result).to(be_falsey)
- end
-
- it "should return false if passed float -1.5" do
- result = scope.function_num2bool([-1.5])
- expect(result).to(be_falsey)
- end
-end
diff --git a/spec/functions/parsejson_spec.rb b/spec/functions/parsejson_spec.rb
deleted file mode 100755
index 1dd41b96..00000000
--- a/spec/functions/parsejson_spec.rb
+++ /dev/null
@@ -1,22 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the parsejson function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("parsejson")).to eq("function_parsejson")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_parsejson([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should convert JSON to a data structure" do
- json = <<-EOS
-["aaa","bbb","ccc"]
-EOS
- result = scope.function_parsejson([json])
- expect(result).to(eq(['aaa','bbb','ccc']))
- end
-end
diff --git a/spec/functions/parseyaml_spec.rb b/spec/functions/parseyaml_spec.rb
deleted file mode 100755
index e5f145ba..00000000
--- a/spec/functions/parseyaml_spec.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the parseyaml function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("parseyaml")).to eq("function_parseyaml")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_parseyaml([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should convert YAML to a data structure" do
- yaml = <<-EOS
-- aaa
-- bbb
-- ccc
-EOS
- result = scope.function_parseyaml([yaml])
- expect(result).to(eq(['aaa','bbb','ccc']))
- end
-end
diff --git a/spec/functions/pick_default_spec.rb b/spec/functions/pick_default_spec.rb
deleted file mode 100755
index db10cc35..00000000
--- a/spec/functions/pick_default_spec.rb
+++ /dev/null
@@ -1,58 +0,0 @@
-#!/usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the pick_default function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("pick_default")).to eq("function_pick_default")
- end
-
- it 'should return the correct value' do
- expect(scope.function_pick_default(['first', 'second'])).to eq('first')
- end
-
- it 'should return the correct value if the first value is empty' do
- expect(scope.function_pick_default(['', 'second'])).to eq('second')
- end
-
- it 'should skip empty string values' do
- expect(scope.function_pick_default(['', 'first'])).to eq('first')
- end
-
- it 'should skip :undef values' do
- expect(scope.function_pick_default([:undef, 'first'])).to eq('first')
- end
-
- it 'should skip :undefined values' do
- expect(scope.function_pick_default([:undefined, 'first'])).to eq('first')
- end
-
- it 'should return the empty string if it is the last possibility' do
- expect(scope.function_pick_default([:undef, :undefined, ''])).to eq('')
- end
-
- it 'should return :undef if it is the last possibility' do
- expect(scope.function_pick_default(['', :undefined, :undef])).to eq(:undef)
- end
-
- it 'should return :undefined if it is the last possibility' do
- expect(scope.function_pick_default([:undef, '', :undefined])).to eq(:undefined)
- end
-
- it 'should return the empty string if it is the only possibility' do
- expect(scope.function_pick_default([''])).to eq('')
- end
-
- it 'should return :undef if it is the only possibility' do
- expect(scope.function_pick_default([:undef])).to eq(:undef)
- end
-
- it 'should return :undefined if it is the only possibility' do
- expect(scope.function_pick_default([:undefined])).to eq(:undefined)
- end
-
- it 'should error if no values are passed' do
- expect { scope.function_pick_default([]) }.to raise_error(Puppet::Error, /Must receive at least one argument./)
- end
-end
diff --git a/spec/functions/pick_spec.rb b/spec/functions/pick_spec.rb
deleted file mode 100755
index 8be8f587..00000000
--- a/spec/functions/pick_spec.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#!/usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the pick function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("pick")).to eq("function_pick")
- end
-
- it 'should return the correct value' do
- expect(scope.function_pick(['first', 'second'])).to eq('first')
- end
-
- it 'should return the correct value if the first value is empty' do
- expect(scope.function_pick(['', 'second'])).to eq('second')
- end
-
- it 'should remove empty string values' do
- expect(scope.function_pick(['', 'first'])).to eq('first')
- end
-
- it 'should remove :undef values' do
- expect(scope.function_pick([:undef, 'first'])).to eq('first')
- end
-
- it 'should remove :undefined values' do
- expect(scope.function_pick([:undefined, 'first'])).to eq('first')
- end
-
- it 'should error if no values are passed' do
- expect { scope.function_pick([]) }.to( raise_error(Puppet::ParseError, "pick(): must receive at least one non empty value"))
- end
-end
diff --git a/spec/functions/prefix_spec.rb b/spec/functions/prefix_spec.rb
deleted file mode 100755
index 34cac530..00000000
--- a/spec/functions/prefix_spec.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the prefix function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "raises a ParseError if there is less than 1 arguments" do
- expect { scope.function_prefix([]) }.to raise_error(Puppet::ParseError, /number of arguments/)
- end
-
- it "raises an error if the first argument is not an array" do
- expect {
- scope.function_prefix([Object.new])
- }.to raise_error(Puppet::ParseError, /expected first argument to be an Array/)
- end
-
-
- it "raises an error if the second argument is not a string" do
- expect {
- scope.function_prefix([['first', 'second'], 42])
- }.to raise_error(Puppet::ParseError, /expected second argument to be a String/)
- end
-
- it "returns a prefixed array" do
- result = scope.function_prefix([['a','b','c'], 'p'])
- expect(result).to(eq(['pa','pb','pc']))
- end
-end
diff --git a/spec/functions/private_spec.rb b/spec/functions/private_spec.rb
deleted file mode 100755
index c70759fa..00000000
--- a/spec/functions/private_spec.rb
+++ /dev/null
@@ -1,55 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:private) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- subject do
- function_name = Puppet::Parser::Functions.function(:private)
- scope.method(function_name)
- end
-
- context "when called from inside module" do
- it "should not fail" do
- scope.expects(:lookupvar).with('module_name').returns('foo')
- scope.expects(:lookupvar).with('caller_module_name').returns('foo')
- expect {
- subject.call []
- }.not_to raise_error
- end
- end
-
- context "with an explicit failure message" do
- it "prints the failure message on error" do
- scope.expects(:lookupvar).with('module_name').returns('foo')
- scope.expects(:lookupvar).with('caller_module_name').returns('bar')
- expect {
- subject.call ['failure message!']
- }.to raise_error Puppet::ParseError, /failure message!/
- end
- end
-
- context "when called from private class" do
- it "should fail with a class error message" do
- scope.expects(:lookupvar).with('module_name').returns('foo')
- scope.expects(:lookupvar).with('caller_module_name').returns('bar')
- scope.source.expects(:name).returns('foo::baz')
- scope.source.expects(:type).returns('hostclass')
- expect {
- subject.call []
- }.to raise_error Puppet::ParseError, /Class foo::baz is private/
- end
- end
-
- context "when called from private definition" do
- it "should fail with a class error message" do
- scope.expects(:lookupvar).with('module_name').returns('foo')
- scope.expects(:lookupvar).with('caller_module_name').returns('bar')
- scope.source.expects(:name).returns('foo::baz')
- scope.source.expects(:type).returns('definition')
- expect {
- subject.call []
- }.to raise_error Puppet::ParseError, /Definition foo::baz is private/
- end
- end
-end
diff --git a/spec/functions/range_spec.rb b/spec/functions/range_spec.rb
deleted file mode 100755
index ef86f971..00000000
--- a/spec/functions/range_spec.rb
+++ /dev/null
@@ -1,86 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the range function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "exists" do
- expect(Puppet::Parser::Functions.function("range")).to eq("function_range")
- end
-
- it "raises a ParseError if there is less than 1 arguments" do
- expect { scope.function_range([]) }.to raise_error Puppet::ParseError, /Wrong number of arguments.*0 for 1/
- end
-
- describe 'with a letter range' do
- it "returns a letter range" do
- result = scope.function_range(["a","d"])
- expect(result).to eq ['a','b','c','d']
- end
-
- it "returns a letter range given a step of 1" do
- result = scope.function_range(["a","d","1"])
- expect(result).to eq ['a','b','c','d']
- end
-
- it "returns a stepped letter range" do
- result = scope.function_range(["a","d","2"])
- expect(result).to eq ['a','c']
- end
-
- it "returns a stepped letter range given a negative step" do
- result = scope.function_range(["a","d","-2"])
- expect(result).to eq ['a','c']
- end
- end
-
- describe 'with a number range' do
- it "returns a number range" do
- result = scope.function_range(["1","4"])
- expect(result).to eq [1,2,3,4]
- end
-
- it "returns a number range given a step of 1" do
- result = scope.function_range(["1","4","1"])
- expect(result).to eq [1,2,3,4]
- end
-
- it "returns a stepped number range" do
- result = scope.function_range(["1","4","2"])
- expect(result).to eq [1,3]
- end
-
- it "returns a stepped number range given a negative step" do
- result = scope.function_range(["1","4","-2"])
- expect(result).to eq [1,3]
- end
- end
-
- describe 'with a numeric-like string range' do
- it "works with padded hostname like strings" do
- expected = ("host01".."host10").to_a
- expect(scope.function_range(["host01","host10"])).to eq expected
- end
-
- it "coerces zero padded digits to integers" do
- expected = (0..10).to_a
- expect(scope.function_range(["00", "10"])).to eq expected
- end
- end
-
- describe 'with a numeric range' do
- it "returns a range of numbers" do
- expected = (1..10).to_a
- expect(scope.function_range([1,10])).to eq expected
- end
- it "returns a range of numbers with step parameter" do
- expected = (1..10).step(2).to_a
- expect(scope.function_range([1,10,2])).to eq expected
- end
- it "works with mixed numeric like strings and numeric arguments" do
- expected = (1..10).to_a
- expect(scope.function_range(['1',10])).to eq expected
- expect(scope.function_range([1,'10'])).to eq expected
- end
- end
-end
diff --git a/spec/functions/reject_spec.rb b/spec/functions/reject_spec.rb
deleted file mode 100755
index 88a992ef..00000000
--- a/spec/functions/reject_spec.rb
+++ /dev/null
@@ -1,20 +0,0 @@
-#!/usr/bin/env ruby
-
-require 'spec_helper'
-
-describe "the reject function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("reject")).to eq("function_reject")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_reject([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should reject contents from an array" do
- result = scope.function_reject([["1111", "aaabbb","bbbccc","dddeee"], "bbb"])
- expect(result).to(eq(["1111", "dddeee"]))
- end
-end
diff --git a/spec/functions/reverse_spec.rb b/spec/functions/reverse_spec.rb
deleted file mode 100755
index 1f047943..00000000
--- a/spec/functions/reverse_spec.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the reverse function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("reverse")).to eq("function_reverse")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_reverse([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should reverse a string" do
- result = scope.function_reverse(["asdfghijkl"])
- expect(result).to(eq('lkjihgfdsa'))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new('asdfghjkl')
- result = scope.function_reverse([value])
- result.should(eq('lkjhgfdsa'))
- end
-end
diff --git a/spec/functions/rstrip_spec.rb b/spec/functions/rstrip_spec.rb
deleted file mode 100755
index f6b48389..00000000
--- a/spec/functions/rstrip_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the rstrip function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("rstrip")).to eq("function_rstrip")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_rstrip([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should rstrip a string" do
- result = scope.function_rstrip(["asdf "])
- expect(result).to(eq('asdf'))
- end
-
- it "should rstrip each element in an array" do
- result = scope.function_rstrip([["a ","b ", "c "]])
- expect(result).to(eq(['a','b','c']))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new('asdf ')
- result = scope.function_rstrip([value])
- result.should(eq('asdf'))
- end
-end
diff --git a/spec/functions/shuffle_spec.rb b/spec/functions/shuffle_spec.rb
deleted file mode 100755
index a62c1fb5..00000000
--- a/spec/functions/shuffle_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the shuffle function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("shuffle")).to eq("function_shuffle")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_shuffle([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should shuffle a string and the result should be the same size" do
- result = scope.function_shuffle(["asdf"])
- expect(result.size).to(eq(4))
- end
-
- it "should shuffle a string but the sorted contents should still be the same" do
- result = scope.function_shuffle(["adfs"])
- expect(result.split("").sort.join("")).to(eq("adfs"))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new('asdf')
- result = scope.function_shuffle([value])
- result.size.should(eq(4))
- end
-end
diff --git a/spec/functions/size_spec.rb b/spec/functions/size_spec.rb
deleted file mode 100755
index 18eb48f9..00000000
--- a/spec/functions/size_spec.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the size function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("size")).to eq("function_size")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_size([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return the size of a string" do
- result = scope.function_size(["asdf"])
- expect(result).to(eq(4))
- end
-
- it "should return the size of an array" do
- result = scope.function_size([["a","b","c"]])
- expect(result).to(eq(3))
- end
-end
diff --git a/spec/functions/sort_spec.rb b/spec/functions/sort_spec.rb
deleted file mode 100755
index 4c2a66cf..00000000
--- a/spec/functions/sort_spec.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the sort function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("sort")).to eq("function_sort")
- end
-
- it "should raise a ParseError if there is not 1 arguments" do
- expect { scope.function_sort(['','']) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should sort an array" do
- result = scope.function_sort([["a","c","b"]])
- expect(result).to(eq(['a','b','c']))
- end
-
- it "should sort a string" do
- result = scope.function_sort(["acb"])
- expect(result).to(eq('abc'))
- end
-end
diff --git a/spec/functions/squeeze_spec.rb b/spec/functions/squeeze_spec.rb
deleted file mode 100755
index cd0eb37f..00000000
--- a/spec/functions/squeeze_spec.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the squeeze function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("squeeze")).to eq("function_squeeze")
- end
-
- it "should raise a ParseError if there is less than 2 arguments" do
- expect { scope.function_squeeze([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should squeeze a string" do
- result = scope.function_squeeze(["aaabbbbcccc"])
- expect(result).to(eq('abc'))
- end
-
- it "should squeeze all elements in an array" do
- result = scope.function_squeeze([["aaabbbbcccc","dddfff"]])
- expect(result).to(eq(['abc','df']))
- end
-end
diff --git a/spec/functions/str2bool_spec.rb b/spec/functions/str2bool_spec.rb
deleted file mode 100755
index 1d205d75..00000000
--- a/spec/functions/str2bool_spec.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the str2bool function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("str2bool")).to eq("function_str2bool")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_str2bool([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should convert string 'true' to true" do
- result = scope.function_str2bool(["true"])
- expect(result).to(eq(true))
- end
-
- it "should convert string 'undef' to false" do
- result = scope.function_str2bool(["undef"])
- expect(result).to(eq(false))
- end
-
- it "should return the boolean it was called with" do
- result = scope.function_str2bool([true])
- expect(result).to(eq(true))
- result = scope.function_str2bool([false])
- expect(result).to(eq(false))
- end
-end
diff --git a/spec/functions/str2saltedsha512_spec.rb b/spec/functions/str2saltedsha512_spec.rb
deleted file mode 100755
index ab7f57f1..00000000
--- a/spec/functions/str2saltedsha512_spec.rb
+++ /dev/null
@@ -1,45 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the str2saltedsha512 function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("str2saltedsha512")).to eq("function_str2saltedsha512")
- end
-
- it "should raise a ParseError if there is less than 1 argument" do
- expect { scope.function_str2saltedsha512([]) }.to( raise_error(Puppet::ParseError) )
- end
-
- it "should raise a ParseError if there is more than 1 argument" do
- expect { scope.function_str2saltedsha512(['foo', 'bar', 'baz']) }.to( raise_error(Puppet::ParseError) )
- end
-
- it "should return a salted-sha512 password hash 136 characters in length" do
- result = scope.function_str2saltedsha512(["password"])
- expect(result.length).to(eq(136))
- end
-
- it "should raise an error if you pass a non-string password" do
- expect { scope.function_str2saltedsha512([1234]) }.to( raise_error(Puppet::ParseError) )
- end
-
- it "should generate a valid password" do
- # Allow the function to generate a password based on the string 'password'
- password_hash = scope.function_str2saltedsha512(["password"])
-
- # Separate the Salt and Password from the Password Hash
- salt = password_hash[0..7]
- password = password_hash[8..-1]
-
- # Convert the Salt and Password from Hex to Binary Data
- str_salt = Array(salt.lines).pack('H*')
- str_password = Array(password.lines).pack('H*')
-
- # Combine the Binary Salt with 'password' and compare the end result
- saltedpass = Digest::SHA512.digest(str_salt + 'password')
- result = (str_salt + saltedpass).unpack('H*')[0]
- expect(result).to eq(password_hash)
- end
-end
diff --git a/spec/functions/strftime_spec.rb b/spec/functions/strftime_spec.rb
deleted file mode 100755
index ebec54b8..00000000
--- a/spec/functions/strftime_spec.rb
+++ /dev/null
@@ -1,29 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the strftime function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("strftime")).to eq("function_strftime")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_strftime([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "using %s should be higher then when I wrote this test" do
- result = scope.function_strftime(["%s"])
- expect(result.to_i).to(be > 1311953157)
- end
-
- it "using %s should be lower then 1.5 trillion" do
- result = scope.function_strftime(["%s"])
- expect(result.to_i).to(be < 1500000000)
- end
-
- it "should return a date when given %Y-%m-%d" do
- result = scope.function_strftime(["%Y-%m-%d"])
- expect(result).to match(/^\d{4}-\d{2}-\d{2}$/)
- end
-end
diff --git a/spec/functions/strip_spec.rb b/spec/functions/strip_spec.rb
deleted file mode 100755
index 4ac8daf8..00000000
--- a/spec/functions/strip_spec.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the strip function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
- it "should exist" do
- expect(Puppet::Parser::Functions.function("strip")).to eq("function_strip")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_strip([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should strip a string" do
- result = scope.function_strip([" ab cd "])
- expect(result).to(eq('ab cd'))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new(' as df ')
- result = scope.function_strip([value])
- result.should(eq('as df'))
- end
-end
diff --git a/spec/functions/suffix_spec.rb b/spec/functions/suffix_spec.rb
deleted file mode 100755
index c7783c64..00000000
--- a/spec/functions/suffix_spec.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the suffix function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "raises a ParseError if there is less than 1 arguments" do
- expect { scope.function_suffix([]) }.to raise_error(Puppet::ParseError, /number of arguments/)
- end
-
- it "raises an error if the first argument is not an array" do
- expect {
- scope.function_suffix([Object.new])
- }.to raise_error(Puppet::ParseError, /expected first argument to be an Array/)
- end
-
- it "raises an error if the second argument is not a string" do
- expect {
- scope.function_suffix([['first', 'second'], 42])
- }.to raise_error(Puppet::ParseError, /expected second argument to be a String/)
- end
-
- it "returns a suffixed array" do
- result = scope.function_suffix([['a','b','c'], 'p'])
- expect(result).to(eq(['ap','bp','cp']))
- end
-end
diff --git a/spec/functions/swapcase_spec.rb b/spec/functions/swapcase_spec.rb
deleted file mode 100755
index 791d1dfa..00000000
--- a/spec/functions/swapcase_spec.rb
+++ /dev/null
@@ -1,28 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the swapcase function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("swapcase")).to eq("function_swapcase")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_swapcase([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should swapcase a string" do
- result = scope.function_swapcase(["aaBBccDD"])
- expect(result).to(eq('AAbbCCdd'))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new("aaBBccDD")
- result = scope.function_swapcase([value])
- result.should(eq("AAbbCCdd"))
- end
-end
diff --git a/spec/functions/time_spec.rb b/spec/functions/time_spec.rb
deleted file mode 100755
index 6e22515f..00000000
--- a/spec/functions/time_spec.rb
+++ /dev/null
@@ -1,29 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the time function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("time")).to eq("function_time")
- end
-
- it "should raise a ParseError if there is more than 2 arguments" do
- expect { scope.function_time(['','']) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return a number" do
- result = scope.function_time([])
- expect(result).to be_an(Integer)
- end
-
- it "should be higher then when I wrote this test" do
- result = scope.function_time([])
- expect(result).to(be > 1311953157)
- end
-
- it "should be lower then 1.5 trillion" do
- result = scope.function_time([])
- expect(result).to(be < 1500000000)
- end
-end
diff --git a/spec/functions/to_bytes_spec.rb b/spec/functions/to_bytes_spec.rb
deleted file mode 100755
index 0f6ade91..00000000
--- a/spec/functions/to_bytes_spec.rb
+++ /dev/null
@@ -1,83 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe "the to_bytes function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("to_bytes")).to eq("function_to_bytes")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_to_bytes([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should convert kB to B" do
- result = scope.function_to_bytes(["4 kB"])
- expect(result).to(eq(4096))
- end
-
- it "should convert MB to B" do
- result = scope.function_to_bytes(["4 MB"])
- expect(result).to(eq(4194304))
- end
-
- it "should convert GB to B" do
- result = scope.function_to_bytes(["4 GB"])
- expect(result).to(eq(4294967296))
- end
-
- it "should convert TB to B" do
- result = scope.function_to_bytes(["4 TB"])
- expect(result).to(eq(4398046511104))
- end
-
- it "should convert PB to B" do
- result = scope.function_to_bytes(["4 PB"])
- expect(result).to(eq(4503599627370496))
- end
-
- it "should convert PB to B" do
- result = scope.function_to_bytes(["4 EB"])
- expect(result).to(eq(4611686018427387904))
- end
-
- it "should work without B in unit" do
- result = scope.function_to_bytes(["4 k"])
- expect(result).to(eq(4096))
- end
-
- it "should work without a space before unit" do
- result = scope.function_to_bytes(["4k"])
- expect(result).to(eq(4096))
- end
-
- it "should work without a unit" do
- result = scope.function_to_bytes(["5678"])
- expect(result).to(eq(5678))
- end
-
- it "should convert fractions" do
- result = scope.function_to_bytes(["1.5 kB"])
- expect(result).to(eq(1536))
- end
-
- it "should convert scientific notation" do
- result = scope.function_to_bytes(["1.5e2 B"])
- expect(result).to(eq(150))
- end
-
- it "should do nothing with a positive number" do
- result = scope.function_to_bytes([5678])
- expect(result).to(eq(5678))
- end
-
- it "should should raise a ParseError if input isn't a number" do
- expect { scope.function_to_bytes(["foo"]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should should raise a ParseError if prefix is unknown" do
- expect { scope.function_to_bytes(["5 uB"]) }.to( raise_error(Puppet::ParseError))
- end
-end
diff --git a/spec/functions/type3x_spec.rb b/spec/functions/type3x_spec.rb
deleted file mode 100644
index d21236a6..00000000
--- a/spec/functions/type3x_spec.rb
+++ /dev/null
@@ -1,43 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the type3x function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
- it "should exist" do
- expect(Puppet::Parser::Functions.function("type3x")).to eq("function_type3x")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_type3x([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return string when given a string" do
- result = scope.function_type3x(["aaabbbbcccc"])
- expect(result).to(eq('string'))
- end
-
- it "should return array when given an array" do
- result = scope.function_type3x([["aaabbbbcccc","asdf"]])
- expect(result).to(eq('array'))
- end
-
- it "should return hash when given a hash" do
- result = scope.function_type3x([{"a"=>1,"b"=>2}])
- expect(result).to(eq('hash'))
- end
-
- it "should return integer when given an integer" do
- result = scope.function_type3x(["1"])
- expect(result).to(eq('integer'))
- end
-
- it "should return float when given a float" do
- result = scope.function_type3x(["1.34"])
- expect(result).to(eq('float'))
- end
-
- it "should return boolean when given a boolean" do
- result = scope.function_type3x([true])
- expect(result).to(eq('boolean'))
- end
-end
diff --git a/spec/functions/type_spec.rb b/spec/functions/type_spec.rb
deleted file mode 100755
index b683fcfa..00000000
--- a/spec/functions/type_spec.rb
+++ /dev/null
@@ -1,44 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the type function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
- it "should exist" do
- expect(Puppet::Parser::Functions.function("type")).to eq("function_type")
- end
-
- it "should give a deprecation warning when called" do
- scope.expects(:warning).with("type() DEPRECATED: This function will cease to function on Puppet 4; please use type3x() before upgrading to puppet 4 for backwards-compatibility, or migrate to the new parser's typing system.")
- scope.function_type(["aoeu"])
- end
-
- it "should return string when given a string" do
- result = scope.function_type(["aaabbbbcccc"])
- expect(result).to(eq('string'))
- end
-
- it "should return array when given an array" do
- result = scope.function_type([["aaabbbbcccc","asdf"]])
- expect(result).to(eq('array'))
- end
-
- it "should return hash when given a hash" do
- result = scope.function_type([{"a"=>1,"b"=>2}])
- expect(result).to(eq('hash'))
- end
-
- it "should return integer when given an integer" do
- result = scope.function_type(["1"])
- expect(result).to(eq('integer'))
- end
-
- it "should return float when given a float" do
- result = scope.function_type(["1.34"])
- expect(result).to(eq('float'))
- end
-
- it "should return boolean when given a boolean" do
- result = scope.function_type([true])
- expect(result).to(eq('boolean'))
- end
-end
diff --git a/spec/functions/union_spec.rb b/spec/functions/union_spec.rb
deleted file mode 100755
index 706f4cbc..00000000
--- a/spec/functions/union_spec.rb
+++ /dev/null
@@ -1,19 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the union function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("union")).to eq("function_union")
- end
-
- it "should raise a ParseError if there are fewer than 2 arguments" do
- expect { scope.function_union([]) }.to( raise_error(Puppet::ParseError) )
- end
-
- it "should join two arrays together" do
- result = scope.function_union([["a","b","c"],["b","c","d"]])
- expect(result).to(eq(["a","b","c","d"]))
- end
-end
diff --git a/spec/functions/unique_spec.rb b/spec/functions/unique_spec.rb
deleted file mode 100755
index 7cd3a566..00000000
--- a/spec/functions/unique_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the unique function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("unique")).to eq("function_unique")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_unique([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should remove duplicate elements in a string" do
- result = scope.function_unique(["aabbc"])
- expect(result).to(eq('abc'))
- end
-
- it "should remove duplicate elements in an array" do
- result = scope.function_unique([["a","a","b","b","c"]])
- expect(result).to(eq(['a','b','c']))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new('aabbc')
- result = scope.function_unique([value])
- result.should(eq('abc'))
- end
-end
diff --git a/spec/functions/upcase_spec.rb b/spec/functions/upcase_spec.rb
deleted file mode 100755
index 3cf8b055..00000000
--- a/spec/functions/upcase_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the upcase function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("upcase")).to eq("function_upcase")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_upcase([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should upcase a string" do
- result = scope.function_upcase(["abc"])
- expect(result).to(eq('ABC'))
- end
-
- it "should do nothing if a string is already upcase" do
- result = scope.function_upcase(["ABC"])
- expect(result).to(eq('ABC'))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new('abc')
- result = scope.function_upcase([value])
- result.should(eq('ABC'))
- end
-end
diff --git a/spec/functions/uriescape_spec.rb b/spec/functions/uriescape_spec.rb
deleted file mode 100755
index 2321e5ab..00000000
--- a/spec/functions/uriescape_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the uriescape function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("uriescape")).to eq("function_uriescape")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_uriescape([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should uriescape a string" do
- result = scope.function_uriescape([":/?#[]@!$&'()*+,;= \"{}"])
- expect(result).to(eq(':/?%23[]@!$&\'()*+,;=%20%22%7B%7D'))
- end
-
- it "should do nothing if a string is already safe" do
- result = scope.function_uriescape(["ABCdef"])
- expect(result).to(eq('ABCdef'))
- end
-
- it "should accept objects which extend String" do
- class AlsoString < String
- end
-
- value = AlsoString.new('abc')
- result = scope.function_uriescape([value])
- result.should(eq('abc'))
- end
-end
diff --git a/spec/functions/validate_absolute_path_spec.rb b/spec/functions/validate_absolute_path_spec.rb
deleted file mode 100755
index 36c836bd..00000000
--- a/spec/functions/validate_absolute_path_spec.rb
+++ /dev/null
@@ -1,104 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:validate_absolute_path) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- # The subject of these examples is the method itself.
- subject do
- # This makes sure the function is loaded within each test
- function_name = Puppet::Parser::Functions.function(:validate_absolute_path)
- scope.method(function_name)
- end
-
- describe "Valid Paths" do
- def self.valid_paths
- %w{
- C:/
- C:\\
- C:\\WINDOWS\\System32
- C:/windows/system32
- X:/foo/bar
- X:\\foo\\bar
- /var/tmp
- /var/lib/puppet
- /var/opt/../lib/puppet
- }
- end
-
- context "Without Puppet::Util.absolute_path? (e.g. Puppet <= 2.6)" do
- before :each do
- # The intent here is to mock Puppet to behave like Puppet 2.6 does.
- # Puppet 2.6 does not have the absolute_path? method. This is only a
- # convenience test, stdlib should be run with the Puppet 2.6.x in the
- # $LOAD_PATH in addition to 2.7.x and master.
- Puppet::Util.expects(:respond_to?).with(:absolute_path?).returns(false)
- end
- valid_paths.each do |path|
- it "validate_absolute_path(#{path.inspect}) should not fail" do
- expect { subject.call [path] }.not_to raise_error
- end
- end
- valid_paths do
- it "validate_absolute_path(#{valid_paths.inspect}) should not fail" do
- expect { subject.call [valid_paths] }.not_to raise_error
- end
- end
- end
-
- context "Puppet without mocking" do
- valid_paths.each do |path|
- it "validate_absolute_path(#{path.inspect}) should not fail" do
- expect { subject.call [path] }.not_to raise_error
- end
- end
- valid_paths do
- it "validate_absolute_path(#{valid_paths.inspect}) should not fail" do
- expect { subject.call [valid_paths] }.not_to raise_error
- end
- end
- end
- end
-
- describe 'Invalid paths' do
- context 'Garbage inputs' do
- [
- nil,
- [ nil ],
- [ nil, nil ],
- { 'foo' => 'bar' },
- { },
- '',
- ].each do |path|
- it "validate_absolute_path(#{path.inspect}) should fail" do
- expect { subject.call [path] }.to raise_error Puppet::ParseError
- end
- end
- end
-
- context 'Relative paths' do
- def self.rel_paths
- %w{
- relative1
- .
- ..
- ./foo
- ../foo
- etc/puppetlabs/puppet
- opt/puppet/bin
- }
- end
- rel_paths.each do |path|
- it "validate_absolute_path(#{path.inspect}) should fail" do
- expect { subject.call [path] }.to raise_error Puppet::ParseError
- end
- end
- rel_paths do
- it "validate_absolute_path(#{rel_paths.inspect}) should fail" do
- expect { subject.call [rel_paths] }.to raise_error Puppet::ParseError
- end
- end
- end
- end
-end
-
diff --git a/spec/functions/validate_array_spec.rb b/spec/functions/validate_array_spec.rb
deleted file mode 100755
index 4b31cfde..00000000
--- a/spec/functions/validate_array_spec.rb
+++ /dev/null
@@ -1,38 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:validate_array) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
- describe 'when calling validate_array from puppet' do
-
- %w{ true false }.each do |the_string|
- it "should not compile when #{the_string} is a string" do
- Puppet[:code] = "validate_array('#{the_string}')"
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not an Array/)
- end
-
- it "should not compile when #{the_string} is a bare word" do
- Puppet[:code] = "validate_array(#{the_string})"
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not an Array/)
- end
- end
-
- it "should compile when multiple array arguments are passed" do
- Puppet[:code] = <<-'ENDofPUPPETcode'
- $foo = [ ]
- $bar = [ 'one', 'two' ]
- validate_array($foo, $bar)
- ENDofPUPPETcode
- scope.compiler.compile
- end
-
- it "should not compile when an undef variable is passed" do
- Puppet[:code] = <<-'ENDofPUPPETcode'
- $foo = undef
- validate_array($foo)
- ENDofPUPPETcode
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not an Array/)
- end
- end
-end
diff --git a/spec/functions/validate_augeas_spec.rb b/spec/functions/validate_augeas_spec.rb
deleted file mode 100755
index c695ba2e..00000000
--- a/spec/functions/validate_augeas_spec.rb
+++ /dev/null
@@ -1,103 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:validate_augeas), :if => Puppet.features.augeas? do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- # The subject of these examplres is the method itself.
- subject do
- # This makes sure the function is loaded within each test
- function_name = Puppet::Parser::Functions.function(:validate_augeas)
- scope.method(function_name)
- end
-
- context 'Using Puppet::Parser::Scope.new' do
-
- describe 'Garbage inputs' do
- inputs = [
- [ nil ],
- [ [ nil ] ],
- [ { 'foo' => 'bar' } ],
- [ { } ],
- [ '' ],
- [ "one", "one", "MSG to User", "4th arg" ],
- ]
-
- inputs.each do |input|
- it "validate_augeas(#{input.inspect}) should fail" do
- expect { subject.call [input] }.to raise_error Puppet::ParseError
- end
- end
- end
-
- describe 'Valid inputs' do
- inputs = [
- [ "root:x:0:0:root:/root:/bin/bash\n", 'Passwd.lns' ],
- [ "proc /proc proc nodev,noexec,nosuid 0 0\n", 'Fstab.lns'],
- ]
-
- inputs.each do |input|
- it "validate_augeas(#{input.inspect}) should not fail" do
- expect { subject.call input }.not_to raise_error
- end
- end
- end
-
- describe "Valid inputs which should raise an exception without a message" do
- # The intent here is to make sure valid inputs raise exceptions when they
- # don't specify an error message to display. This is the behvior in
- # 2.2.x and prior.
- inputs = [
- [ "root:x:0:0:root\n", 'Passwd.lns' ],
- [ "127.0.1.1\n", 'Hosts.lns' ],
- ]
-
- inputs.each do |input|
- it "validate_augeas(#{input.inspect}) should fail" do
- expect { subject.call input }.to raise_error /validate_augeas.*?matched less than it should/
- end
- end
- end
-
- describe "Nicer Error Messages" do
- # The intent here is to make sure the function returns the 3rd argument
- # in the exception thrown
- inputs = [
- [ "root:x:0:0:root\n", 'Passwd.lns', [], 'Failed to validate passwd content' ],
- [ "127.0.1.1\n", 'Hosts.lns', [], 'Wrong hosts content' ],
- ]
-
- inputs.each do |input|
- it "validate_augeas(#{input.inspect}) should fail" do
- expect { subject.call input }.to raise_error /#{input[2]}/
- end
- end
- end
-
- describe "Passing simple unit tests" do
- inputs = [
- [ "root:x:0:0:root:/root:/bin/bash\n", 'Passwd.lns', ['$file/foobar']],
- [ "root:x:0:0:root:/root:/bin/bash\n", 'Passwd.lns', ['$file/root/shell[.="/bin/sh"]', 'foobar']],
- ]
-
- inputs.each do |input|
- it "validate_augeas(#{input.inspect}) should fail" do
- expect { subject.call input }.not_to raise_error
- end
- end
- end
-
- describe "Failing simple unit tests" do
- inputs = [
- [ "foobar:x:0:0:root:/root:/bin/bash\n", 'Passwd.lns', ['$file/foobar']],
- [ "root:x:0:0:root:/root:/bin/sh\n", 'Passwd.lns', ['$file/root/shell[.="/bin/sh"]', 'foobar']],
- ]
-
- inputs.each do |input|
- it "validate_augeas(#{input.inspect}) should fail" do
- expect { subject.call input }.to raise_error /testing path/
- end
- end
- end
- end
-end
diff --git a/spec/functions/validate_bool_spec.rb b/spec/functions/validate_bool_spec.rb
deleted file mode 100755
index a352d3b5..00000000
--- a/spec/functions/validate_bool_spec.rb
+++ /dev/null
@@ -1,51 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:validate_bool) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
- describe 'when calling validate_bool from puppet' do
-
- %w{ true false }.each do |the_string|
-
- it "should not compile when #{the_string} is a string" do
- Puppet[:code] = "validate_bool('#{the_string}')"
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not a boolean/)
- end
-
- it "should compile when #{the_string} is a bare word" do
- Puppet[:code] = "validate_bool(#{the_string})"
- scope.compiler.compile
- end
-
- end
-
- it "should not compile when an arbitrary string is passed" do
- Puppet[:code] = 'validate_bool("jeff and dan are awesome")'
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not a boolean/)
- end
-
- it "should not compile when no arguments are passed" do
- Puppet[:code] = 'validate_bool()'
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
-
- it "should compile when multiple boolean arguments are passed" do
- Puppet[:code] = <<-'ENDofPUPPETcode'
- $foo = true
- $bar = false
- validate_bool($foo, $bar, true, false)
- ENDofPUPPETcode
- scope.compiler.compile
- end
-
- it "should compile when multiple boolean arguments are passed" do
- Puppet[:code] = <<-'ENDofPUPPETcode'
- $foo = true
- $bar = false
- validate_bool($foo, $bar, true, false, 'jeff')
- ENDofPUPPETcode
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not a boolean/)
- end
- end
-end
diff --git a/spec/functions/validate_cmd_spec.rb b/spec/functions/validate_cmd_spec.rb
deleted file mode 100755
index 7cb9782d..00000000
--- a/spec/functions/validate_cmd_spec.rb
+++ /dev/null
@@ -1,85 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-TESTEXE = File.exists?('/usr/bin/test') ? '/usr/bin/test' : '/bin/test'
-TOUCHEXE = File.exists?('/usr/bin/touch') ? '/usr/bin/touch' : '/bin/touch'
-
-describe Puppet::Parser::Functions.function(:validate_cmd) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- subject do
- function_name = Puppet::Parser::Functions.function(:validate_cmd)
- scope.method(function_name)
- end
-
- context 'with no % placeholder' do
- describe "with an explicit failure message" do
- it "prints the failure message on error" do
- expect {
- subject.call ['', '/bin/false', 'failure message!']
- }.to raise_error Puppet::ParseError, /failure message!/
- end
- end
-
- describe "on validation failure" do
- it "includes the command error output" do
- expect {
- subject.call ['', "#{TOUCHEXE} /cant/touch/this"]
- }.to raise_error Puppet::ParseError, /(cannot touch|o such file or)/
- end
-
- it "includes the command return value" do
- expect {
- subject.call ['', '/cant/run/this']
- }.to raise_error Puppet::ParseError, /returned 1\b/
- end
- end
-
- describe "when performing actual validation" do
- it "can positively validate file content" do
- expect { subject.call ["non-empty", "#{TESTEXE} -s"] }.to_not raise_error
- end
-
- it "can negatively validate file content" do
- expect {
- subject.call ["", "#{TESTEXE} -s"]
- }.to raise_error Puppet::ParseError, /failed to validate.*test -s/
- end
- end
- end
-
- context 'with % placeholder' do
- describe "with an explicit failure message" do
- it "prints the failure message on error" do
- expect {
- subject.call ['', '/bin/false % -f', 'failure message!']
- }.to raise_error Puppet::ParseError, /failure message!/
- end
- end
- describe "on validation failure" do
- it "includes the command error output" do
- expect {
- subject.call ['', "#{TOUCHEXE} /cant/touch/this"]
- }.to raise_error Puppet::ParseError, /(cannot touch|o such file or)/
- end
-
- it "includes the command return value" do
- expect {
- subject.call ['', '/cant/run/this % -z']
- }.to raise_error Puppet::ParseError, /Execution of '\/cant\/run\/this .+ -z' returned 1/
- end
- end
-
- describe "when performing actual validation" do
- it "can positively validate file content" do
- expect { subject.call ["non-empty", "#{TESTEXE} -s %"] }.to_not raise_error
- end
-
- it "can negatively validate file content" do
- expect {
- subject.call ["", "#{TESTEXE} -s %"]
- }.to raise_error Puppet::ParseError, /failed to validate.*test -s/
- end
- end
- end
-end
diff --git a/spec/functions/validate_hash_spec.rb b/spec/functions/validate_hash_spec.rb
deleted file mode 100755
index a0c35c23..00000000
--- a/spec/functions/validate_hash_spec.rb
+++ /dev/null
@@ -1,43 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:validate_hash) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- describe 'when calling validate_hash from puppet' do
-
- %w{ true false }.each do |the_string|
-
- it "should not compile when #{the_string} is a string" do
- Puppet[:code] = "validate_hash('#{the_string}')"
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not a Hash/)
- end
-
- it "should not compile when #{the_string} is a bare word" do
- Puppet[:code] = "validate_hash(#{the_string})"
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not a Hash/)
- end
-
- end
-
- it "should compile when multiple hash arguments are passed" do
- Puppet[:code] = <<-'ENDofPUPPETcode'
- $foo = {}
- $bar = { 'one' => 'two' }
- validate_hash($foo, $bar)
- ENDofPUPPETcode
- scope.compiler.compile
- end
-
- it "should not compile when an undef variable is passed" do
- Puppet[:code] = <<-'ENDofPUPPETcode'
- $foo = undef
- validate_hash($foo)
- ENDofPUPPETcode
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not a Hash/)
- end
-
- end
-
-end
diff --git a/spec/functions/validate_ipv4_address_spec.rb b/spec/functions/validate_ipv4_address_spec.rb
deleted file mode 100755
index 45401a42..00000000
--- a/spec/functions/validate_ipv4_address_spec.rb
+++ /dev/null
@@ -1,64 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require "spec_helper"
-
-describe Puppet::Parser::Functions.function(:validate_ipv4_address) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- describe "when calling validate_ipv4_address from puppet" do
- describe "when given IPv4 address strings" do
- it "should compile with one argument" do
- Puppet[:code] = "validate_ipv4_address('1.2.3.4')"
- scope.compiler.compile
- end
-
- it "should compile with multiple arguments" do
- Puppet[:code] = "validate_ipv4_address('1.2.3.4', '5.6.7.8')"
- scope.compiler.compile
- end
- end
-
- describe "when given an IPv6 address" do
- it "should not compile" do
- Puppet[:code] = "validate_ipv4_address('3ffe:505')"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /not a valid IPv4 address/)
- end
- end
-
- describe "when given other strings" do
- it "should not compile" do
- Puppet[:code] = "validate_ipv4_address('hello', 'world')"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /not a valid IPv4 address/)
- end
- end
-
- describe "when given numbers" do
- it "should not compile" do
- Puppet[:code] = "validate_ipv4_address(1, 2)"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /is not a valid IPv4 address/)
- end
- end
-
- describe "when given booleans" do
- it "should not compile" do
- Puppet[:code] = "validate_ipv4_address(true, false)"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /is not a string/)
- end
- end
-
- it "should not compile when no arguments are passed" do
- Puppet[:code] = "validate_ipv4_address()"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
- end
-end
diff --git a/spec/functions/validate_ipv6_address_spec.rb b/spec/functions/validate_ipv6_address_spec.rb
deleted file mode 100755
index a839d902..00000000
--- a/spec/functions/validate_ipv6_address_spec.rb
+++ /dev/null
@@ -1,67 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require "spec_helper"
-
-describe Puppet::Parser::Functions.function(:validate_ipv6_address) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- describe "when calling validate_ipv6_address from puppet" do
- describe "when given IPv6 address strings" do
- it "should compile with one argument" do
- Puppet[:code] = "validate_ipv6_address('3ffe:0505:0002::')"
- scope.compiler.compile
- end
-
- it "should compile with multiple arguments" do
- Puppet[:code] = "validate_ipv6_address('3ffe:0505:0002::', '3ffe:0505:0001::')"
- scope.compiler.compile
- end
- end
-
- describe "when given an ipv4 address" do
- it "should not compile" do
- Puppet[:code] = "validate_ipv6_address('1.2.3.4')"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /not a valid IPv6 address/)
- end
- end
-
- describe "when given other strings" do
- it "should not compile" do
- Puppet[:code] = "validate_ipv6_address('hello', 'world')"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /not a valid IPv6 address/)
- end
- end
-
- # 1.8.7 is EOL'd and also absolutely insane about ipv6
- unless RUBY_VERSION == '1.8.7'
- describe "when given numbers" do
- it "should not compile" do
- Puppet[:code] = "validate_ipv6_address(1, 2)"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /not a valid IPv6 address/)
- end
- end
- end
-
- describe "when given booleans" do
- it "should not compile" do
- Puppet[:code] = "validate_ipv6_address(true, false)"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /is not a string/)
- end
- end
-
- it "should not compile when no arguments are passed" do
- Puppet[:code] = "validate_ipv6_address()"
- expect {
- scope.compiler.compile
- }.to raise_error(Puppet::ParseError, /wrong number of arguments/)
- end
- end
-end
diff --git a/spec/functions/validate_re_spec.rb b/spec/functions/validate_re_spec.rb
deleted file mode 100755
index d29988bf..00000000
--- a/spec/functions/validate_re_spec.rb
+++ /dev/null
@@ -1,77 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:validate_re) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- # The subject of these examplres is the method itself.
- subject do
- # This makes sure the function is loaded within each test
- function_name = Puppet::Parser::Functions.function(:validate_re)
- scope.method(function_name)
- end
-
- context 'Using Puppet::Parser::Scope.new' do
-
- describe 'Garbage inputs' do
- inputs = [
- [ nil ],
- [ [ nil ] ],
- [ { 'foo' => 'bar' } ],
- [ { } ],
- [ '' ],
- [ "one", "one", "MSG to User", "4th arg" ],
- ]
-
- inputs.each do |input|
- it "validate_re(#{input.inspect}) should fail" do
- expect { subject.call [input] }.to raise_error Puppet::ParseError
- end
- end
- end
-
- describe 'Valid inputs' do
- inputs = [
- [ '/full/path/to/something', '^/full' ],
- [ '/full/path/to/something', 'full' ],
- [ '/full/path/to/something', ['full', 'absent'] ],
- [ '/full/path/to/something', ['full', 'absent'], 'Message to the user' ],
- ]
-
- inputs.each do |input|
- it "validate_re(#{input.inspect}) should not fail" do
- expect { subject.call input }.not_to raise_error
- end
- end
- end
- describe "Valid inputs which should raise an exception without a message" do
- # The intent here is to make sure valid inputs raise exceptions when they
- # don't specify an error message to display. This is the behvior in
- # 2.2.x and prior.
- inputs = [
- [ "hello", [ "bye", "later", "adios" ] ],
- [ "greetings", "salutations" ],
- ]
-
- inputs.each do |input|
- it "validate_re(#{input.inspect}) should fail" do
- expect { subject.call input }.to raise_error /validate_re.*?does not match/
- end
- end
- end
- describe "Nicer Error Messages" do
- # The intent here is to make sure the function returns the 3rd argument
- # in the exception thrown
- inputs = [
- [ "hello", [ "bye", "later", "adios" ], "MSG to User" ],
- [ "greetings", "salutations", "Error, greetings does not match salutations" ],
- ]
-
- inputs.each do |input|
- it "validate_re(#{input.inspect}) should fail" do
- expect { subject.call input }.to raise_error /#{input[2]}/
- end
- end
- end
- end
-end
diff --git a/spec/functions/validate_slength_spec.rb b/spec/functions/validate_slength_spec.rb
deleted file mode 100755
index e23f61a2..00000000
--- a/spec/functions/validate_slength_spec.rb
+++ /dev/null
@@ -1,67 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe "the validate_slength function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("validate_slength")).to eq("function_validate_slength")
- end
-
- describe "validating the input argument types" do
- it "raises an error if there are less than two arguments" do
- expect { scope.function_validate_slength([]) }.to raise_error Puppet::ParseError, /Wrong number of arguments/
- end
-
- it "raises an error if there are more than three arguments" do
- expect { scope.function_validate_slength(['input', 1, 2, 3]) }.to raise_error Puppet::ParseError, /Wrong number of arguments/
- end
-
- it "raises an error if the first argument is not a string" do
- expect { scope.function_validate_slength([Object.new, 2, 1]) }.to raise_error Puppet::ParseError, /Expected first argument.*got .*Object/
- end
-
- it "raises an error if the second argument cannot be cast to an Integer" do
- expect { scope.function_validate_slength(['input', Object.new]) }.to raise_error Puppet::ParseError, /Expected second argument.*got .*Object/
- end
-
- it "raises an error if the third argument cannot be cast to an Integer" do
- expect { scope.function_validate_slength(['input', 1, Object.new]) }.to raise_error Puppet::ParseError, /Expected third argument.*got .*Object/
- end
-
- it "raises an error if the second argument is smaller than the third argument" do
- expect { scope.function_validate_slength(['input', 1, 2]) }.to raise_error Puppet::ParseError, /Expected second argument to be larger than third argument/
- end
- end
-
- describe "validating the input string length" do
- describe "when the input is a string" do
- it "fails validation if the string is larger than the max length" do
- expect { scope.function_validate_slength(['input', 1]) }.to raise_error Puppet::ParseError, /Expected length .* between 0 and 1, was 5/
- end
-
- it "fails validation if the string is less than the min length" do
- expect { scope.function_validate_slength(['input', 10, 6]) }.to raise_error Puppet::ParseError, /Expected length .* between 6 and 10, was 5/
- end
-
- it "doesn't raise an error if the string is under the max length" do
- scope.function_validate_slength(['input', 10])
- end
-
- it "doesn't raise an error if the string is equal to the max length" do
- scope.function_validate_slength(['input', 5])
- end
-
- it "doesn't raise an error if the string is equal to the min length" do
- scope.function_validate_slength(['input', 10, 5])
- end
- end
-
- describe "when the input is an array" do
- it "fails validation if one of the array elements is not a string" do
- expect { scope.function_validate_slength([["a", "b", Object.new], 2]) }.to raise_error Puppet::ParseError, /Expected element at array position 2 .*String, got .*Object/
- end
- end
- end
-end
diff --git a/spec/functions/validate_string_spec.rb b/spec/functions/validate_string_spec.rb
deleted file mode 100755
index 3b4fb3e1..00000000
--- a/spec/functions/validate_string_spec.rb
+++ /dev/null
@@ -1,60 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-describe Puppet::Parser::Functions.function(:validate_string) do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- describe 'when calling validate_string from puppet' do
-
- %w{ foo bar baz }.each do |the_string|
-
- it "should compile when #{the_string} is a string" do
- Puppet[:code] = "validate_string('#{the_string}')"
- scope.compiler.compile
- end
-
- it "should compile when #{the_string} is a bare word" do
- Puppet[:code] = "validate_string(#{the_string})"
- scope.compiler.compile
- end
-
- end
-
- %w{ true false }.each do |the_string|
- it "should compile when #{the_string} is a string" do
- Puppet[:code] = "validate_string('#{the_string}')"
- scope.compiler.compile
- end
-
- it "should not compile when #{the_string} is a bare word" do
- Puppet[:code] = "validate_string(#{the_string})"
- expect { scope.compiler.compile }.to raise_error(Puppet::ParseError, /is not a string/)
- end
- end
-
- it "should compile when multiple string arguments are passed" do
- Puppet[:code] = <<-'ENDofPUPPETcode'
- $foo = ''
- $bar = 'two'
- validate_string($foo, $bar)
- ENDofPUPPETcode
- scope.compiler.compile
- end
-
- it "should compile when an explicitly undef variable is passed (NOTE THIS MAY NOT BE DESIRABLE)" do
- Puppet[:code] = <<-'ENDofPUPPETcode'
- $foo = undef
- validate_string($foo)
- ENDofPUPPETcode
- scope.compiler.compile
- end
-
- it "should compile when an undefined variable is passed (NOTE THIS MAY NOT BE DESIRABLE)" do
- Puppet[:code] = <<-'ENDofPUPPETcode'
- validate_string($foobarbazishouldnotexist)
- ENDofPUPPETcode
- scope.compiler.compile
- end
- end
-end
diff --git a/spec/functions/values_at_spec.rb b/spec/functions/values_at_spec.rb
deleted file mode 100755
index 86e3c31c..00000000
--- a/spec/functions/values_at_spec.rb
+++ /dev/null
@@ -1,38 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the values_at function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("values_at")).to eq("function_values_at")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_values_at([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if you try to use a range where stop is greater then start" do
- expect { scope.function_values_at([['a','b'],["3-1"]]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return a value at from an array" do
- result = scope.function_values_at([['a','b','c'],"1"])
- expect(result).to(eq(['b']))
- end
-
- it "should return a value at from an array when passed a range" do
- result = scope.function_values_at([['a','b','c'],"0-1"])
- expect(result).to(eq(['a','b']))
- end
-
- it "should return chosen values from an array when passed number of indexes" do
- result = scope.function_values_at([['a','b','c'],["0","2"]])
- expect(result).to(eq(['a','c']))
- end
-
- it "should return chosen values from an array when passed ranges and multiple indexes" do
- result = scope.function_values_at([['a','b','c','d','e','f','g'],["0","2","4-5"]])
- expect(result).to(eq(['a','c','e','f']))
- end
-end
diff --git a/spec/functions/values_spec.rb b/spec/functions/values_spec.rb
deleted file mode 100755
index 08d21b03..00000000
--- a/spec/functions/values_spec.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the values function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("values")).to eq("function_values")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_values([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should return values from a hash" do
- result = scope.function_values([{'a'=>'1','b'=>'2','c'=>'3'}])
- # =~ is the RSpec::Matchers::MatchArray matcher.
- # A.K.A. "array with same elements" (multiset) matching
- expect(result).to match_array(%w{ 1 2 3 })
- end
-
- it "should return a multiset" do
- result = scope.function_values([{'a'=>'1','b'=>'3','c'=>'3'}])
- expect(result).to match_array(%w{ 1 3 3 })
- expect(result).not_to match_array(%w{ 1 3 })
- end
-
- it "should raise a ParseError unless a Hash is provided" do
- expect { scope.function_values([['a','b','c']]) }.to( raise_error(Puppet::ParseError))
- end
-end
diff --git a/spec/functions/zip_spec.rb b/spec/functions/zip_spec.rb
deleted file mode 100755
index f265fcee..00000000
--- a/spec/functions/zip_spec.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the zip function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_zip([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should be able to zip an array" do
- result = scope.function_zip([['1','2','3'],['4','5','6']])
- expect(result).to(eq([["1", "4"], ["2", "5"], ["3", "6"]]))
- result = scope.function_zip([['1','2','3'],['4','5','6'], false])
- result.should(eq([["1", "4"], ["2", "5"], ["3", "6"]]))
- end
-
- it "should be able to zip an array and flatten" do
- result = scope.function_zip([['1','2','3'],['4','5','6'], true])
- result.should(eq(["1", "4", "2", "5", "3", "6"]))
- end
-
- it "should accept objects which extend String for the second argument" do
- class AlsoString < String
- end
-
- value = AlsoString.new('false')
- result = scope.function_zip([['1','2','3'],['4','5','6'],value])
- result.should(eq([["1", "4"], ["2", "5"], ["3", "6"]]))
- end
-end
diff --git a/spec/lib/puppet_spec/compiler.rb b/spec/lib/puppet_spec/compiler.rb
deleted file mode 100755
index 2f0ae4d7..00000000
--- a/spec/lib/puppet_spec/compiler.rb
+++ /dev/null
@@ -1,47 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-module PuppetSpec::Compiler
- def compile_to_catalog(string, node = Puppet::Node.new('foonode'))
- Puppet[:code] = string
- Puppet::Parser::Compiler.compile(node)
- end
-
- def compile_to_ral(manifest)
- catalog = compile_to_catalog(manifest)
- ral = catalog.to_ral
- ral.finalize
- ral
- end
-
- def compile_to_relationship_graph(manifest, prioritizer = Puppet::Graph::SequentialPrioritizer.new)
- ral = compile_to_ral(manifest)
- graph = Puppet::Graph::RelationshipGraph.new(prioritizer)
- graph.populate_from(ral)
- graph
- end
-
- if Puppet.version.to_f >= 3.3
- def apply_compiled_manifest(manifest, prioritizer = Puppet::Graph::SequentialPrioritizer.new)
- transaction = Puppet::Transaction.new(compile_to_ral(manifest),
- Puppet::Transaction::Report.new("apply"),
- prioritizer)
- transaction.evaluate
- transaction.report.finalize_report
-
- transaction
- end
- else
- def apply_compiled_manifest(manifest)
- transaction = Puppet::Transaction.new(compile_to_ral(manifest), Puppet::Transaction::Report.new("apply"))
- transaction.evaluate
- transaction.report.finalize_report
-
- transaction
- end
- end
-
- def order_resources_traversed_in(relationships)
- order_seen = []
- relationships.traverse { |resource| order_seen << resource.ref }
- order_seen
- end
-end
diff --git a/spec/lib/puppet_spec/database.rb b/spec/lib/puppet_spec/database.rb
deleted file mode 100755
index f5c23417..00000000
--- a/spec/lib/puppet_spec/database.rb
+++ /dev/null
@@ -1,30 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-# This just makes some nice things available at global scope, and for setup of
-# tests to use a real fake database, rather than a fake stubs-that-don't-work
-# version of the same. Fun times.
-def sqlite?
- if $sqlite.nil?
- begin
- require 'sqlite3'
- $sqlite = true
- rescue LoadError
- $sqlite = false
- end
- end
- $sqlite
-end
-
-def can_use_scratch_database?
- sqlite? and Puppet.features.rails?
-end
-
-
-# This is expected to be called in your `before :each` block, and will get you
-# ready to roll with a serious database and all. Cleanup is handled
-# automatically for you. Nothing to do there.
-def setup_scratch_database
- Puppet[:dbadapter] = 'sqlite3'
- Puppet[:dblocation] = ':memory:'
- Puppet[:railslog] = PuppetSpec::Files.tmpfile('storeconfigs.log')
- Puppet::Rails.init
-end
diff --git a/spec/lib/puppet_spec/files.rb b/spec/lib/puppet_spec/files.rb
deleted file mode 100755
index 71b38ffe..00000000
--- a/spec/lib/puppet_spec/files.rb
+++ /dev/null
@@ -1,61 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'fileutils'
-require 'tempfile'
-require 'tmpdir'
-require 'pathname'
-
-# A support module for testing files.
-module PuppetSpec::Files
- def self.cleanup
- $global_tempfiles ||= []
- while path = $global_tempfiles.pop do
- begin
- Dir.unstub(:entries)
- FileUtils.rm_rf path, :secure => true
- rescue Errno::ENOENT
- # nothing to do
- end
- end
- end
-
- def make_absolute(path) PuppetSpec::Files.make_absolute(path) end
- def self.make_absolute(path)
- path = File.expand_path(path)
- path[0] = 'c' if Puppet.features.microsoft_windows?
- path
- end
-
- def tmpfile(name, dir = nil) PuppetSpec::Files.tmpfile(name, dir) end
- def self.tmpfile(name, dir = nil)
- # Generate a temporary file, just for the name...
- source = dir ? Tempfile.new(name, dir) : Tempfile.new(name)
- path = source.path
- source.close!
-
- record_tmp(File.expand_path(path))
-
- path
- end
-
- def file_containing(name, contents) PuppetSpec::Files.file_containing(name, contents) end
- def self.file_containing(name, contents)
- file = tmpfile(name)
- File.open(file, 'wb') { |f| f.write(contents) }
- file
- end
-
- def tmpdir(name) PuppetSpec::Files.tmpdir(name) end
- def self.tmpdir(name)
- dir = Dir.mktmpdir(name)
-
- record_tmp(dir)
-
- dir
- end
-
- def self.record_tmp(tmp)
- # ...record it for cleanup,
- $global_tempfiles ||= []
- $global_tempfiles << tmp
- end
-end
diff --git a/spec/lib/puppet_spec/fixtures.rb b/spec/lib/puppet_spec/fixtures.rb
deleted file mode 100755
index 81e9775f..00000000
--- a/spec/lib/puppet_spec/fixtures.rb
+++ /dev/null
@@ -1,29 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-module PuppetSpec::Fixtures
- def fixtures(*rest)
- File.join(PuppetSpec::FIXTURE_DIR, *rest)
- end
- def my_fixture_dir
- callers = caller
- while line = callers.shift do
- next unless found = line.match(%r{/spec/(.*)_spec\.rb:})
- return fixtures(found[1])
- end
- fail "sorry, I couldn't work out your path from the caller stack!"
- end
- def my_fixture(name)
- file = File.join(my_fixture_dir, name)
- unless File.readable? file then
- fail Puppet::DevError, "fixture '#{name}' for #{my_fixture_dir} is not readable"
- end
- return file
- end
- def my_fixtures(glob = '*', flags = 0)
- files = Dir.glob(File.join(my_fixture_dir, glob), flags)
- unless files.length > 0 then
- fail Puppet::DevError, "fixture '#{glob}' for #{my_fixture_dir} had no files!"
- end
- block_given? and files.each do |file| yield file end
- files
- end
-end
diff --git a/spec/lib/puppet_spec/matchers.rb b/spec/lib/puppet_spec/matchers.rb
deleted file mode 100755
index 093d77c8..00000000
--- a/spec/lib/puppet_spec/matchers.rb
+++ /dev/null
@@ -1,121 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'stringio'
-
-########################################################################
-# Backward compatibility for Jenkins outdated environment.
-module RSpec
- module Matchers
- module BlockAliases
- alias_method :to, :should unless method_defined? :to
- alias_method :to_not, :should_not unless method_defined? :to_not
- alias_method :not_to, :should_not unless method_defined? :not_to
- end
- end
-end
-
-
-########################################################################
-# Custom matchers...
-RSpec::Matchers.define :have_matching_element do |expected|
- match do |actual|
- actual.any? { |item| item =~ expected }
- end
-end
-
-
-RSpec::Matchers.define :exit_with do |expected|
- actual = nil
- match do |block|
- begin
- block.call
- rescue SystemExit => e
- actual = e.status
- end
- actual and actual == expected
- end
- failure_message_for_should do |block|
- "expected exit with code #{expected} but " +
- (actual.nil? ? " exit was not called" : "we exited with #{actual} instead")
- end
- failure_message_for_should_not do |block|
- "expected that exit would not be called with #{expected}"
- end
- description do
- "expect exit with #{expected}"
- end
-end
-
-class HavePrintedMatcher
- attr_accessor :expected, :actual
-
- def initialize(expected)
- case expected
- when String, Regexp
- @expected = expected
- else
- @expected = expected.to_s
- end
- end
-
- def matches?(block)
- begin
- $stderr = $stdout = StringIO.new
- $stdout.set_encoding('UTF-8') if $stdout.respond_to?(:set_encoding)
- block.call
- $stdout.rewind
- @actual = $stdout.read
- ensure
- $stdout = STDOUT
- $stderr = STDERR
- end
-
- if @actual then
- case @expected
- when String
- @actual.include? @expected
- when Regexp
- @expected.match @actual
- end
- else
- false
- end
- end
-
- def failure_message_for_should
- if @actual.nil? then
- "expected #{@expected.inspect}, but nothing was printed"
- else
- "expected #{@expected.inspect} to be printed; got:\n#{@actual}"
- end
- end
-
- def failure_message_for_should_not
- "expected #{@expected.inspect} to not be printed; got:\n#{@actual}"
- end
-
- def description
- "expect #{@expected.inspect} to be printed"
- end
-end
-
-def have_printed(what)
- HavePrintedMatcher.new(what)
-end
-
-RSpec::Matchers.define :equal_attributes_of do |expected|
- match do |actual|
- actual.instance_variables.all? do |attr|
- actual.instance_variable_get(attr) == expected.instance_variable_get(attr)
- end
- end
-end
-
-RSpec::Matchers.define :be_one_of do |*expected|
- match do |actual|
- expected.include? actual
- end
-
- failure_message_for_should do |actual|
- "expected #{actual.inspect} to be one of #{expected.map(&:inspect).join(' or ')}"
- end
-end
diff --git a/spec/lib/puppet_spec/modules.rb b/spec/lib/puppet_spec/modules.rb
deleted file mode 100755
index 910c6d94..00000000
--- a/spec/lib/puppet_spec/modules.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-module PuppetSpec::Modules
- class << self
- def create(name, dir, options = {})
- module_dir = File.join(dir, name)
- FileUtils.mkdir_p(module_dir)
-
- environment = options[:environment]
-
- if metadata = options[:metadata]
- metadata[:source] ||= 'github'
- metadata[:author] ||= 'puppetlabs'
- metadata[:version] ||= '9.9.9'
- metadata[:license] ||= 'to kill'
- metadata[:dependencies] ||= []
-
- metadata[:name] = "#{metadata[:author]}/#{name}"
-
- File.open(File.join(module_dir, 'metadata.json'), 'w') do |f|
- f.write(metadata.to_pson)
- end
- end
-
- Puppet::Module.new(name, module_dir, environment)
- end
- end
-end
diff --git a/spec/lib/puppet_spec/pops.rb b/spec/lib/puppet_spec/pops.rb
deleted file mode 100755
index e056a52b..00000000
--- a/spec/lib/puppet_spec/pops.rb
+++ /dev/null
@@ -1,17 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-module PuppetSpec::Pops
- extend RSpec::Matchers::DSL
-
- # Checks if an Acceptor has a specific issue in its list of diagnostics
- matcher :have_issue do |expected|
- match do |actual|
- actual.diagnostics.index { |i| i.issue == expected } != nil
- end
- failure_message_for_should do |actual|
- "expected Acceptor[#{actual.diagnostics.collect { |i| i.issue.issue_code }.join(',')}] to contain issue #{expected.issue_code}"
- end
- failure_message_for_should_not do |actual|
- "expected Acceptor[#{actual.diagnostics.collect { |i| i.issue.issue_code }.join(',')}] to not contain issue #{expected.issue_code}"
- end
- end
-end
diff --git a/spec/lib/puppet_spec/scope.rb b/spec/lib/puppet_spec/scope.rb
deleted file mode 100755
index 3847ede1..00000000
--- a/spec/lib/puppet_spec/scope.rb
+++ /dev/null
@@ -1,15 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-module PuppetSpec::Scope
- # Initialize a new scope suitable for testing.
- #
- def create_test_scope_for_node(node_name)
- node = Puppet::Node.new(node_name)
- compiler = Puppet::Parser::Compiler.new(node)
- scope = Puppet::Parser::Scope.new(compiler)
- scope.source = Puppet::Resource::Type.new(:node, node_name)
- scope.parent = compiler.topscope
- scope
- end
-
-end \ No newline at end of file
diff --git a/spec/lib/puppet_spec/settings.rb b/spec/lib/puppet_spec/settings.rb
deleted file mode 100755
index 8ddcb975..00000000
--- a/spec/lib/puppet_spec/settings.rb
+++ /dev/null
@@ -1,16 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-module PuppetSpec::Settings
-
- # It would probably be preferable to refactor defaults.rb such that the real definitions of
- # these settings were available as a variable, which was then accessible for use during tests.
- # However, I'm not doing that yet because I don't want to introduce any additional moving parts
- # to this already very large changeset.
- # Would be nice to clean this up later. --cprice 2012-03-20
- TEST_APP_DEFAULT_DEFINITIONS = {
- :name => { :default => "test", :desc => "name" },
- :logdir => { :type => :directory, :default => "test", :desc => "logdir" },
- :confdir => { :type => :directory, :default => "test", :desc => "confdir" },
- :vardir => { :type => :directory, :default => "test", :desc => "vardir" },
- :rundir => { :type => :directory, :default => "test", :desc => "rundir" },
- }
-end
diff --git a/spec/lib/puppet_spec/verbose.rb b/spec/lib/puppet_spec/verbose.rb
deleted file mode 100755
index b2683df0..00000000
--- a/spec/lib/puppet_spec/verbose.rb
+++ /dev/null
@@ -1,10 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-# Support code for running stuff with warnings disabled.
-module Kernel
- def with_verbose_disabled
- verbose, $VERBOSE = $VERBOSE, nil
- result = yield
- $VERBOSE = verbose
- return result
- end
-end
diff --git a/spec/monkey_patches/alias_should_to_must.rb b/spec/monkey_patches/alias_should_to_must.rb
deleted file mode 100755
index 505e2409..00000000
--- a/spec/monkey_patches/alias_should_to_must.rb
+++ /dev/null
@@ -1,9 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'rspec'
-
-class Object
- # This is necessary because the RAL has a 'should'
- # method.
- alias :must :should
- alias :must_not :should_not
-end
diff --git a/spec/monkey_patches/publicize_methods.rb b/spec/monkey_patches/publicize_methods.rb
deleted file mode 100755
index 3ae59f97..00000000
--- a/spec/monkey_patches/publicize_methods.rb
+++ /dev/null
@@ -1,11 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-# Some monkey-patching to allow us to test private methods.
-class Class
- def publicize_methods(*methods)
- saved_private_instance_methods = methods.empty? ? self.private_instance_methods : methods
-
- self.class_eval { public(*saved_private_instance_methods) }
- yield
- self.class_eval { private(*saved_private_instance_methods) }
- end
-end
diff --git a/spec/spec.opts b/spec/spec.opts
deleted file mode 100644
index 91cd6427..00000000
--- a/spec/spec.opts
+++ /dev/null
@@ -1,6 +0,0 @@
---format
-s
---colour
---loadby
-mtime
---backtrace
diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb
deleted file mode 100755
index b490ca3c..00000000
--- a/spec/spec_helper.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-dir = File.expand_path(File.dirname(__FILE__))
-$LOAD_PATH.unshift File.join(dir, 'lib')
-
-# So everyone else doesn't have to include this base constant.
-module PuppetSpec
- FIXTURE_DIR = File.join(dir = File.expand_path(File.dirname(__FILE__)), "fixtures") unless defined?(FIXTURE_DIR)
-end
-
-require 'puppet'
-require 'rspec-puppet'
-require 'puppetlabs_spec_helper/module_spec_helper'
-require 'puppet_spec/verbose'
-require 'puppet_spec/files'
-require 'puppet_spec/settings'
-require 'puppet_spec/fixtures'
-require 'puppet_spec/matchers'
-require 'puppet_spec/database'
-require 'monkey_patches/alias_should_to_must'
-require 'mocha/setup'
-
-
-
-RSpec.configure do |config|
- config.before :each do
- # Ensure that we don't accidentally cache facts and environment between
- # test cases. This requires each example group to explicitly load the
- # facts being exercised with something like
- # Facter.collection.loader.load(:ipaddress)
- Facter::Util::Loader.any_instance.stubs(:load_all)
- Facter.clear
- Facter.clear_messages
- end
-end
diff --git a/spec/spec_helper_acceptance.rb b/spec/spec_helper_acceptance.rb
deleted file mode 100755
index 3203ce9f..00000000
--- a/spec/spec_helper_acceptance.rb
+++ /dev/null
@@ -1,50 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'beaker-rspec'
-
-UNSUPPORTED_PLATFORMS = []
-
-unless ENV['RS_PROVISION'] == 'no' or ENV['BEAKER_provision'] == 'no'
- foss_opts = {
- :default_action => 'gem_install',
- :version => (ENV['PUPPET_VERSION'] ? ENV['PUPPET_VERSION'] : '3.7.2'),
- }
-
- if default.is_pe?; then install_pe; else install_puppet( foss_opts ); end
-
- hosts.each do |host|
- if host['platform'] !~ /windows/i
- if host.is_pe?
- on host, 'mkdir -p /etc/puppetlabs/facter/facts.d'
- else
- on host, "/bin/touch #{host['puppetpath']}/hiera.yaml"
- on host, "mkdir -p #{host['distmoduledir']}"
- on host, 'mkdir -p /etc/facter/facts.d'
- end
- end
- end
-end
-
-RSpec.configure do |c|
- # Project root
- proj_root = File.expand_path(File.join(File.dirname(__FILE__), '..'))
-
- # Readable test descriptions
- c.formatter = :documentation
-
- # Configure all nodes in nodeset
- c.before :suite do
- if ENV['FUTURE_PARSER'] == 'true'
- default[:default_apply_opts] ||= {}
- default[:default_apply_opts].merge!({:parser => 'future'})
- end
-
- copy_root_module_to(default, :source => proj_root, :module_name => 'stdlib')
- end
-end
-
-def is_future_parser_enabled?
- if default[:default_apply_opts]
- return default[:default_apply_opts][:parser] == 'future'
- end
- return false
-end
diff --git a/spec/unit/facter/facter_dot_d_spec.rb b/spec/unit/facter/facter_dot_d_spec.rb
deleted file mode 100755
index 0afadb25..00000000
--- a/spec/unit/facter/facter_dot_d_spec.rb
+++ /dev/null
@@ -1,32 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-require 'facter/facter_dot_d'
-
-describe Facter::Util::DotD do
-
- context 'returns a simple fact' do
- before :each do
- Facter.stubs(:version).returns('1.6.1')
- subject.stubs(:entries).returns(['/etc/facter/facts.d/fake_fact.txt'])
- File.stubs(:readlines).with('/etc/facter/facts.d/fake_fact.txt').returns(['fake_fact=fake fact'])
- subject.create
- end
-
- it 'should return successfully' do
- expect(Facter.fact(:fake_fact).value).to eq('fake fact')
- end
- end
-
- context 'returns a fact with equals signs' do
- before :each do
- Facter.stubs(:version).returns('1.6.1')
- subject.stubs(:entries).returns(['/etc/facter/facts.d/foo.txt'])
- File.stubs(:readlines).with('/etc/facter/facts.d/foo.txt').returns(['foo=1+1=2'])
- subject.create
- end
-
- it 'should return successfully' do
- expect(Facter.fact(:foo).value).to eq('1+1=2')
- end
- end
-end
diff --git a/spec/unit/facter/pe_version_spec.rb b/spec/unit/facter/pe_version_spec.rb
deleted file mode 100755
index 4d0349e6..00000000
--- a/spec/unit/facter/pe_version_spec.rb
+++ /dev/null
@@ -1,76 +0,0 @@
-#!/usr/bin/env rspec
-
-require 'spec_helper'
-
-describe "PE Version specs" do
- before :each do
- # Explicitly load the pe_version.rb file which contains generated facts
- # that cannot be automatically loaded. Puppet 2.x implements
- # Facter.collection.load while Facter 1.x markes Facter.collection.load as
- # a private method.
- if Facter.collection.respond_to? :load
- Facter.collection.load(:pe_version)
- else
- Facter.collection.loader.load(:pe_version)
- end
- end
-
- context "If PE is installed" do
- %w{ 2.6.1 2.10.300 }.each do |version|
- puppetversion = "2.7.19 (Puppet Enterprise #{version})"
- context "puppetversion => #{puppetversion}" do
- before :each do
- Facter.fact(:puppetversion).stubs(:value).returns(puppetversion)
- end
-
- (major,minor,patch) = version.split(".")
-
- it "Should return true" do
- expect(Facter.fact(:is_pe).value).to eq(true)
- end
-
- it "Should have a version of #{version}" do
- expect(Facter.fact(:pe_version).value).to eq(version)
- end
-
- it "Should have a major version of #{major}" do
- expect(Facter.fact(:pe_major_version).value).to eq(major)
- end
-
- it "Should have a minor version of #{minor}" do
- expect(Facter.fact(:pe_minor_version).value).to eq(minor)
- end
-
- it "Should have a patch version of #{patch}" do
- expect(Facter.fact(:pe_patch_version).value).to eq(patch)
- end
- end
- end
- end
-
- context "When PE is not installed" do
- before :each do
- Facter.fact(:puppetversion).stubs(:value).returns("2.7.19")
- end
-
- it "is_pe is false" do
- expect(Facter.fact(:is_pe).value).to eq(false)
- end
-
- it "pe_version is nil" do
- expect(Facter.fact(:pe_version).value).to be_nil
- end
-
- it "pe_major_version is nil" do
- expect(Facter.fact(:pe_major_version).value).to be_nil
- end
-
- it "pe_minor_version is nil" do
- expect(Facter.fact(:pe_minor_version).value).to be_nil
- end
-
- it "Should have a patch version" do
- expect(Facter.fact(:pe_patch_version).value).to be_nil
- end
- end
-end
diff --git a/spec/unit/facter/root_home_spec.rb b/spec/unit/facter/root_home_spec.rb
deleted file mode 100755
index 98fe1419..00000000
--- a/spec/unit/facter/root_home_spec.rb
+++ /dev/null
@@ -1,52 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-require 'facter/root_home'
-
-describe Facter::Util::RootHome do
- context "solaris" do
- let(:root_ent) { "root:x:0:0:Super-User:/:/sbin/sh" }
- let(:expected_root_home) { "/" }
-
- it "should return /" do
- Facter::Util::Resolution.expects(:exec).with("getent passwd root").returns(root_ent)
- expect(Facter::Util::RootHome.get_root_home).to eq(expected_root_home)
- end
- end
- context "linux" do
- let(:root_ent) { "root:x:0:0:root:/root:/bin/bash" }
- let(:expected_root_home) { "/root" }
-
- it "should return /root" do
- Facter::Util::Resolution.expects(:exec).with("getent passwd root").returns(root_ent)
- expect(Facter::Util::RootHome.get_root_home).to eq(expected_root_home)
- end
- end
- context "windows" do
- before :each do
- Facter::Util::Resolution.expects(:exec).with("getent passwd root").returns(nil)
- end
- it "should be nil on windows" do
- expect(Facter::Util::RootHome.get_root_home).to be_nil
- end
- end
-end
-
-describe 'root_home', :type => :fact do
- before { Facter.clear }
- after { Facter.clear }
-
- context "macosx" do
- before do
- Facter.fact(:kernel).stubs(:value).returns("Darwin")
- Facter.fact(:osfamily).stubs(:value).returns("Darwin")
- end
- let(:expected_root_home) { "/var/root" }
- sample_dscacheutil = File.read(fixtures('dscacheutil','root'))
-
- it "should return /var/root" do
- Facter::Util::Resolution.stubs(:exec).with("dscacheutil -q user -a name root").returns(sample_dscacheutil)
- expect(Facter.fact(:root_home).value).to eq(expected_root_home)
- end
- end
-
-end
diff --git a/spec/unit/facter/util/puppet_settings_spec.rb b/spec/unit/facter/util/puppet_settings_spec.rb
deleted file mode 100755
index c06137d7..00000000
--- a/spec/unit/facter/util/puppet_settings_spec.rb
+++ /dev/null
@@ -1,36 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-require 'facter/util/puppet_settings'
-
-describe Facter::Util::PuppetSettings do
-
- describe "#with_puppet" do
- context "Without Puppet loaded" do
- before(:each) do
- Module.expects(:const_get).with("Puppet").raises(NameError)
- end
-
- it 'should be nil' do
- expect(subject.with_puppet { Puppet[:vardir] }).to be_nil
- end
- it 'should not yield to the block' do
- Puppet.expects(:[]).never
- expect(subject.with_puppet { Puppet[:vardir] }).to be_nil
- end
- end
- context "With Puppet loaded" do
- module Puppet; end
- let(:vardir) { "/var/lib/puppet" }
-
- before :each do
- Puppet.expects(:[]).with(:vardir).returns vardir
- end
- it 'should yield to the block' do
- subject.with_puppet { Puppet[:vardir] }
- end
- it 'should return the nodes vardir' do
- expect(subject.with_puppet { Puppet[:vardir] }).to eq vardir
- end
- end
- end
-end
diff --git a/spec/unit/puppet/functions/type_of_spec.rb b/spec/unit/puppet/functions/type_of_spec.rb
deleted file mode 100644
index 8afb6246..00000000
--- a/spec/unit/puppet/functions/type_of_spec.rb
+++ /dev/null
@@ -1,33 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-
-require 'spec_helper'
-
-if ENV["FUTURE_PARSER"] == 'yes' or Puppet.version >= "4"
- require 'puppet/pops'
- require 'puppet/loaders'
-
- describe 'the type_of function' do
- before(:all) do
- loaders = Puppet::Pops::Loaders.new(Puppet::Node::Environment.create(:testing, [File.join(fixtures, "modules")]))
- Puppet.push_context({:loaders => loaders}, "test-examples")
- end
-
- after(:all) do
- Puppet::Pops::Loaders.clear
- Puppet::pop_context()
- end
-
- let(:func) do
- # Load the function from the environment modulepath's modules (ie, fixtures)
- Puppet.lookup(:loaders).private_environment_loader.load(:function, 'type_of')
- end
-
- it 'gives the type of a string' do
- expect(func.call({}, 'hello world')).to be_kind_of(Puppet::Pops::Types::PStringType)
- end
-
- it 'gives the type of an integer' do
- expect(func.call({}, 5)).to be_kind_of(Puppet::Pops::Types::PIntegerType)
- end
- end
-end
diff --git a/spec/unit/puppet/parser/functions/basename_spec.rb b/spec/unit/puppet/parser/functions/basename_spec.rb
deleted file mode 100755
index 8a2d0dc3..00000000
--- a/spec/unit/puppet/parser/functions/basename_spec.rb
+++ /dev/null
@@ -1,46 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the basename function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- Puppet::Parser::Functions.function("basename").should == "function_basename"
- end
-
- it "should raise a ParseError if there is less than 1 argument" do
- lambda { scope.function_basename([]) }.should( raise_error(Puppet::ParseError))
- end
-
- it "should raise a ParseError if there are more than 2 arguments" do
- lambda { scope.function_basename(['a', 'b', 'c']) }.should( raise_error(Puppet::ParseError))
- end
-
- it "should return basename for an absolute path" do
- result = scope.function_basename(['/path/to/a/file.ext'])
- result.should(eq('file.ext'))
- end
-
- it "should return basename for a relative path" do
- result = scope.function_basename(['path/to/a/file.ext'])
- result.should(eq('file.ext'))
- end
-
- it "should strip extention when extension specified (absolute path)" do
- result = scope.function_basename(['/path/to/a/file.ext', '.ext'])
- result.should(eq('file'))
- end
-
- it "should strip extention when extension specified (relative path)" do
- result = scope.function_basename(['path/to/a/file.ext', '.ext'])
- result.should(eq('file'))
- end
-
- it "should complain about non-string first argument" do
- lambda { scope.function_basename([[]]) }.should( raise_error(Puppet::ParseError))
- end
-
- it "should complain about non-string second argument" do
- lambda { scope.function_basename(['/path/to/a/file.ext', []]) }.should( raise_error(Puppet::ParseError))
- end
-end
diff --git a/spec/unit/puppet/parser/functions/bool2str_spec.rb b/spec/unit/puppet/parser/functions/bool2str_spec.rb
deleted file mode 100755
index b8788918..00000000
--- a/spec/unit/puppet/parser/functions/bool2str_spec.rb
+++ /dev/null
@@ -1,46 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the bool2str function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("bool2str")).to eq("function_bool2str")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_bool2str([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should convert true to 'true'" do
- result = scope.function_bool2str([true])
- expect(result).to(eq('true'))
- end
-
- it "should convert true to a string" do
- result = scope.function_bool2str([true])
- expect(result.class).to(eq(String))
- end
-
- it "should convert false to 'false'" do
- result = scope.function_bool2str([false])
- expect(result).to(eq('false'))
- end
-
- it "should convert false to a string" do
- result = scope.function_bool2str([false])
- expect(result.class).to(eq(String))
- end
-
- it "should not accept a string" do
- expect { scope.function_bool2str(["false"]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should not accept a nil value" do
- expect { scope.function_bool2str([nil]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should not accept an undef" do
- expect { scope.function_bool2str([:undef]) }.to( raise_error(Puppet::ParseError))
- end
-end
diff --git a/spec/unit/puppet/parser/functions/camelcase_spec.rb b/spec/unit/puppet/parser/functions/camelcase_spec.rb
deleted file mode 100755
index 70382adb..00000000
--- a/spec/unit/puppet/parser/functions/camelcase_spec.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the camelcase function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- expect(Puppet::Parser::Functions.function("camelcase")).to eq("function_camelcase")
- end
-
- it "should raise a ParseError if there is less than 1 arguments" do
- expect { scope.function_camelcase([]) }.to( raise_error(Puppet::ParseError))
- end
-
- it "should capitalize the beginning of a normal string" do
- result = scope.function_camelcase(["abc"])
- expect(result).to(eq("Abc"))
- end
-
- it "should camelcase an underscore-delimited string" do
- result = scope.function_camelcase(["aa_bb_cc"])
- expect(result).to(eq("AaBbCc"))
- end
-end
diff --git a/spec/unit/puppet/parser/functions/str2saltedsha1_spec.rb b/spec/unit/puppet/parser/functions/str2saltedsha1_spec.rb
deleted file mode 100644
index 753cb24a..00000000
--- a/spec/unit/puppet/parser/functions/str2saltedsha1_spec.rb
+++ /dev/null
@@ -1,45 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-
-describe "the str2saltedsha1 function" do
- let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
-
- it "should exist" do
- Puppet::Parser::Functions.function("str2saltedsha1").should == "function_str2saltedsha1"
- end
-
- it "should raise a ParseError if there is less than 1 argument" do
- expect { scope.function_str2saltedsha1([]) }.should( raise_error(Puppet::ParseError) )
- end
-
- it "should raise a ParseError if there is more than 1 argument" do
- expect { scope.function_str2saltedsha1(['foo', 'bar', 'baz']) }.should( raise_error(Puppet::ParseError) )
- end
-
- it "should return a salted-sha1 password hash 136 characters in length" do
- result = scope.function_str2saltedsha1(["password"])
- result.length.should(eq(136))
- end
-
- it "should raise an error if you pass a non-string password" do
- expect { scope.function_str2saltedsha1([1234]) }.should( raise_error(Puppet::ParseError) )
- end
-
- it "should generate a valid password" do
- # Allow the function to generate a password based on the string 'password'
- password_hash = scope.function_str2saltedsha1(["password"])
-
- # Separate the Salt and Password from the Password Hash
- salt = password_hash[0..7]
- password = password_hash[8..-1]
-
- # Convert the Salt and Password from Hex to Binary Data
- str_salt = Array(salt.lines).pack('H*')
- str_password = Array(password.lines).pack('H*')
-
- # Combine the Binary Salt with 'password' and compare the end result
- saltedpass = Digest::SHA1.digest(str_salt + 'password')
- result = (str_salt + saltedpass).unpack('H*')[0]
- result.should == password_hash
- end
-end
diff --git a/spec/unit/puppet/provider/file_line/ruby_spec.rb b/spec/unit/puppet/provider/file_line/ruby_spec.rb
deleted file mode 100755
index d2a129c3..00000000
--- a/spec/unit/puppet/provider/file_line/ruby_spec.rb
+++ /dev/null
@@ -1,225 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-require 'tempfile'
-provider_class = Puppet::Type.type(:file_line).provider(:ruby)
-describe provider_class do
- context "when adding" do
- let :tmpfile do
- tmp = Tempfile.new('tmp')
- path = tmp.path
- tmp.close!
- path
- end
- let :resource do
- Puppet::Type::File_line.new(
- {:name => 'foo', :path => tmpfile, :line => 'foo'}
- )
- end
- let :provider do
- provider_class.new(resource)
- end
-
- it 'should detect if the line exists in the file' do
- File.open(tmpfile, 'w') do |fh|
- fh.write('foo')
- end
- expect(provider.exists?).to be_truthy
- end
- it 'should detect if the line does not exist in the file' do
- File.open(tmpfile, 'w') do |fh|
- fh.write('foo1')
- end
- expect(provider.exists?).to be_nil
- end
- it 'should append to an existing file when creating' do
- provider.create
- expect(File.read(tmpfile).chomp).to eq('foo')
- end
- end
-
- context "when matching" do
- before :each do
- # TODO: these should be ported over to use the PuppetLabs spec_helper
- # file fixtures once the following pull request has been merged:
- # https://github.com/puppetlabs/puppetlabs-stdlib/pull/73/files
- tmp = Tempfile.new('tmp')
- @tmpfile = tmp.path
- tmp.close!
- @resource = Puppet::Type::File_line.new(
- {
- :name => 'foo',
- :path => @tmpfile,
- :line => 'foo = bar',
- :match => '^foo\s*=.*$',
- }
- )
- @provider = provider_class.new(@resource)
- end
-
- describe 'using match' do
- it 'should raise an error if more than one line matches, and should not have modified the file' do
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo=blah\nfoo2\nfoo=baz")
- end
- expect(@provider.exists?).to be_nil
- expect { @provider.create }.to raise_error(Puppet::Error, /More than one line.*matches/)
- expect(File.read(@tmpfile)).to eql("foo1\nfoo=blah\nfoo2\nfoo=baz")
- end
-
- it 'should replace all lines that matches' do
- @resource = Puppet::Type::File_line.new(
- {
- :name => 'foo',
- :path => @tmpfile,
- :line => 'foo = bar',
- :match => '^foo\s*=.*$',
- :multiple => true
- }
- )
- @provider = provider_class.new(@resource)
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo=blah\nfoo2\nfoo=baz")
- end
- expect(@provider.exists?).to be_nil
- @provider.create
- expect(File.read(@tmpfile).chomp).to eql("foo1\nfoo = bar\nfoo2\nfoo = bar")
- end
-
- it 'should raise an error with invalid values' do
- expect {
- @resource = Puppet::Type::File_line.new(
- {
- :name => 'foo',
- :path => @tmpfile,
- :line => 'foo = bar',
- :match => '^foo\s*=.*$',
- :multiple => 'asgadga'
- }
- )
- }.to raise_error(Puppet::Error, /Invalid value "asgadga"\. Valid values are true, false\./)
- end
-
- it 'should replace a line that matches' do
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo=blah\nfoo2")
- end
- expect(@provider.exists?).to be_nil
- @provider.create
- expect(File.read(@tmpfile).chomp).to eql("foo1\nfoo = bar\nfoo2")
- end
- it 'should add a new line if no lines match' do
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo2")
- end
- expect(@provider.exists?).to be_nil
- @provider.create
- expect(File.read(@tmpfile)).to eql("foo1\nfoo2\nfoo = bar\n")
- end
- it 'should do nothing if the exact line already exists' do
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo = bar\nfoo2")
- end
- expect(@provider.exists?).to be_truthy
- @provider.create
- expect(File.read(@tmpfile).chomp).to eql("foo1\nfoo = bar\nfoo2")
- end
- end
-
- describe 'using after' do
- let :resource do
- Puppet::Type::File_line.new(
- {
- :name => 'foo',
- :path => @tmpfile,
- :line => 'inserted = line',
- :after => '^foo1',
- }
- )
- end
-
- let :provider do
- provider_class.new(resource)
- end
-
- context 'with one line matching the after expression' do
- before :each do
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo = blah\nfoo2\nfoo = baz")
- end
- end
-
- it 'inserts the specified line after the line matching the "after" expression' do
- provider.create
- expect(File.read(@tmpfile).chomp).to eql("foo1\ninserted = line\nfoo = blah\nfoo2\nfoo = baz")
- end
- end
-
- context 'with two lines matching the after expression' do
- before :each do
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo = blah\nfoo2\nfoo1\nfoo = baz")
- end
- end
-
- it 'errors out stating "One or no line must match the pattern"' do
- expect { provider.create }.to raise_error(Puppet::Error, /One or no line must match the pattern/)
- end
- end
-
- context 'with no lines matching the after expression' do
- let :content do
- "foo3\nfoo = blah\nfoo2\nfoo = baz\n"
- end
-
- before :each do
- File.open(@tmpfile, 'w') do |fh|
- fh.write(content)
- end
- end
-
- it 'appends the specified line to the file' do
- provider.create
- expect(File.read(@tmpfile)).to eq(content << resource[:line] << "\n")
- end
- end
- end
- end
-
- context "when removing" do
- before :each do
- # TODO: these should be ported over to use the PuppetLabs spec_helper
- # file fixtures once the following pull request has been merged:
- # https://github.com/puppetlabs/puppetlabs-stdlib/pull/73/files
- tmp = Tempfile.new('tmp')
- @tmpfile = tmp.path
- tmp.close!
- @resource = Puppet::Type::File_line.new(
- {:name => 'foo', :path => @tmpfile, :line => 'foo', :ensure => 'absent' }
- )
- @provider = provider_class.new(@resource)
- end
- it 'should remove the line if it exists' do
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo\nfoo2")
- end
- @provider.destroy
- expect(File.read(@tmpfile)).to eql("foo1\nfoo2")
- end
-
- it 'should remove the line without touching the last new line' do
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo\nfoo2\n")
- end
- @provider.destroy
- expect(File.read(@tmpfile)).to eql("foo1\nfoo2\n")
- end
-
- it 'should remove any occurence of the line' do
- File.open(@tmpfile, 'w') do |fh|
- fh.write("foo1\nfoo\nfoo2\nfoo\nfoo")
- end
- @provider.destroy
- expect(File.read(@tmpfile)).to eql("foo1\nfoo2\n")
- end
- end
-end
diff --git a/spec/unit/puppet/type/anchor_spec.rb b/spec/unit/puppet/type/anchor_spec.rb
deleted file mode 100755
index c738a272..00000000
--- a/spec/unit/puppet/type/anchor_spec.rb
+++ /dev/null
@@ -1,11 +0,0 @@
-#!/usr/bin/env ruby
-
-require 'spec_helper'
-
-anchor = Puppet::Type.type(:anchor).new(:name => "ntp::begin")
-
-describe anchor do
- it "should stringify normally" do
- expect(anchor.to_s).to eq("Anchor[ntp::begin]")
- end
-end
diff --git a/spec/unit/puppet/type/file_line_spec.rb b/spec/unit/puppet/type/file_line_spec.rb
deleted file mode 100755
index 410d0bfe..00000000
--- a/spec/unit/puppet/type/file_line_spec.rb
+++ /dev/null
@@ -1,70 +0,0 @@
-#! /usr/bin/env ruby -S rspec
-require 'spec_helper'
-require 'tempfile'
-describe Puppet::Type.type(:file_line) do
- let :file_line do
- Puppet::Type.type(:file_line).new(:name => 'foo', :line => 'line', :path => '/tmp/path')
- end
- it 'should accept a line and path' do
- file_line[:line] = 'my_line'
- expect(file_line[:line]).to eq('my_line')
- file_line[:path] = '/my/path'
- expect(file_line[:path]).to eq('/my/path')
- end
- it 'should accept a match regex' do
- file_line[:match] = '^foo.*$'
- expect(file_line[:match]).to eq('^foo.*$')
- end
- it 'should accept a match regex that does not match the specified line' do
- expect {
- Puppet::Type.type(:file_line).new(
- :name => 'foo',
- :path => '/my/path',
- :line => 'foo=bar',
- :match => '^bar=blah$'
- )}.not_to raise_error
- end
- it 'should accept a match regex that does match the specified line' do
- expect {
- Puppet::Type.type(:file_line).new(
- :name => 'foo',
- :path => '/my/path',
- :line => 'foo=bar',
- :match => '^\s*foo=.*$'
- )}.not_to raise_error
- end
- it 'should accept posix filenames' do
- file_line[:path] = '/tmp/path'
- expect(file_line[:path]).to eq('/tmp/path')
- end
- it 'should not accept unqualified path' do
- expect { file_line[:path] = 'file' }.to raise_error(Puppet::Error, /File paths must be fully qualified/)
- end
- it 'should require that a line is specified' do
- expect { Puppet::Type.type(:file_line).new(:name => 'foo', :path => '/tmp/file') }.to raise_error(Puppet::Error, /Both line and path are required attributes/)
- end
- it 'should require that a file is specified' do
- expect { Puppet::Type.type(:file_line).new(:name => 'foo', :line => 'path') }.to raise_error(Puppet::Error, /Both line and path are required attributes/)
- end
- it 'should default to ensure => present' do
- expect(file_line[:ensure]).to eq :present
- end
-
- it "should autorequire the file it manages" do
- catalog = Puppet::Resource::Catalog.new
- file = Puppet::Type.type(:file).new(:name => "/tmp/path")
- catalog.add_resource file
- catalog.add_resource file_line
-
- relationship = file_line.autorequire.find do |rel|
- (rel.source.to_s == "File[/tmp/path]") and (rel.target.to_s == file_line.to_s)
- end
- expect(relationship).to be_a Puppet::Relationship
- end
-
- it "should not autorequire the file it manages if it is not managed" do
- catalog = Puppet::Resource::Catalog.new
- catalog.add_resource file_line
- expect(file_line.autorequire).to be_empty
- end
-end