puppet 4.7.1-x64-mingw32 → 4.8.0-x64-mingw32
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of puppet might be problematic. Click here for more details.
- data/Gemfile +0 -3
- data/MAINTAINERS +76 -0
- data/README.md +0 -6
- data/Rakefile +2 -2
- data/lib/puppet/agent.rb +3 -3
- data/lib/puppet/application/apply.rb +1 -1
- data/lib/puppet/configurer.rb +2 -2
- data/lib/puppet/data_providers.rb +1 -0
- data/lib/puppet/data_providers/data_adapter.rb +1 -0
- data/lib/puppet/data_providers/data_function_support.rb +1 -0
- data/lib/puppet/data_providers/function_env_data_provider.rb +1 -0
- data/lib/puppet/data_providers/function_module_data_provider.rb +1 -0
- data/lib/puppet/data_providers/hiera_config.rb +1 -0
- data/lib/puppet/data_providers/hiera_env_data_provider.rb +1 -0
- data/lib/puppet/data_providers/hiera_interpolate.rb +1 -0
- data/lib/puppet/data_providers/hiera_module_data_provider.rb +1 -0
- data/lib/puppet/data_providers/hiera_support.rb +1 -2
- data/lib/puppet/data_providers/json_data_provider_factory.rb +2 -0
- data/lib/puppet/data_providers/yaml_data_provider_factory.rb +2 -0
- data/lib/puppet/defaults.rb +20 -1
- data/lib/puppet/environments.rb +5 -2
- data/lib/puppet/face/catalog.rb +1 -1
- data/lib/puppet/face/epp.rb +57 -11
- data/lib/puppet/face/module/install.rb +6 -6
- data/lib/puppet/functions.rb +23 -24
- data/lib/puppet/functions/alert.rb +14 -0
- data/lib/puppet/functions/binary_file.rb +25 -0
- data/lib/puppet/functions/break.rb +22 -0
- data/lib/puppet/functions/contain.rb +33 -0
- data/lib/puppet/functions/crit.rb +14 -0
- data/lib/puppet/functions/debug.rb +14 -0
- data/lib/puppet/functions/emerg.rb +14 -0
- data/lib/puppet/functions/epp.rb +1 -1
- data/lib/puppet/functions/err.rb +14 -0
- data/lib/puppet/functions/find_file.rb +31 -0
- data/lib/puppet/functions/include.rb +21 -0
- data/lib/puppet/functions/info.rb +14 -0
- data/lib/puppet/functions/new.rb +1 -1
- data/lib/puppet/functions/next.rb +23 -0
- data/lib/puppet/functions/notice.rb +14 -0
- data/lib/puppet/functions/regsubst.rb +12 -16
- data/lib/puppet/functions/require.rb +37 -0
- data/lib/puppet/functions/return.rb +22 -0
- data/lib/puppet/functions/strftime.rb +35 -0
- data/lib/puppet/functions/warning.rb +14 -0
- data/lib/puppet/generate/models/type/type.rb +4 -0
- data/lib/puppet/generate/templates/type/pcore.erb +2 -1
- data/lib/puppet/indirector/face.rb +6 -1
- data/lib/puppet/network/http/error.rb +2 -2
- data/lib/puppet/network/http/handler.rb +2 -2
- data/lib/puppet/node/environment.rb +11 -0
- data/lib/puppet/parser/ast.rb +5 -0
- data/lib/puppet/parser/ast/pops_bridge.rb +17 -4
- data/lib/puppet/parser/compiler.rb +29 -1
- data/lib/puppet/parser/functions.rb +6 -0
- data/lib/puppet/parser/functions/assert_type.rb +1 -1
- data/lib/puppet/parser/functions/binary_file.rb +24 -0
- data/lib/puppet/parser/functions/break.rb +39 -0
- data/lib/puppet/parser/functions/contain.rb +7 -15
- data/lib/puppet/parser/functions/defined.rb +2 -2
- data/lib/puppet/parser/functions/dig.rb +1 -1
- data/lib/puppet/parser/functions/each.rb +1 -1
- data/lib/puppet/parser/functions/epp.rb +2 -2
- data/lib/puppet/parser/functions/filter.rb +1 -1
- data/lib/puppet/parser/functions/find_file.rb +28 -0
- data/lib/puppet/parser/functions/hiera.rb +4 -4
- data/lib/puppet/parser/functions/hiera_array.rb +1 -1
- data/lib/puppet/parser/functions/hiera_hash.rb +1 -1
- data/lib/puppet/parser/functions/hiera_include.rb +1 -1
- data/lib/puppet/parser/functions/include.rb +4 -8
- data/lib/puppet/parser/functions/inline_epp.rb +1 -1
- data/lib/puppet/parser/functions/lest.rb +1 -1
- data/lib/puppet/parser/functions/lookup.rb +4 -2
- data/lib/puppet/parser/functions/map.rb +1 -1
- data/lib/puppet/parser/functions/match.rb +1 -1
- data/lib/puppet/parser/functions/new.rb +414 -18
- data/lib/puppet/parser/functions/next.rb +38 -0
- data/lib/puppet/parser/functions/reduce.rb +1 -1
- data/lib/puppet/parser/functions/regsubst.rb +4 -2
- data/lib/puppet/parser/functions/require.rb +4 -27
- data/lib/puppet/parser/functions/return.rb +71 -0
- data/lib/puppet/parser/functions/reverse_each.rb +1 -1
- data/lib/puppet/parser/functions/scanf.rb +13 -8
- data/lib/puppet/parser/functions/slice.rb +1 -1
- data/lib/puppet/parser/functions/split.rb +1 -1
- data/lib/puppet/parser/functions/step.rb +1 -1
- data/lib/puppet/parser/functions/strftime.rb +185 -0
- data/lib/puppet/parser/functions/then.rb +1 -1
- data/lib/puppet/parser/functions/type.rb +1 -1
- data/lib/puppet/parser/functions/with.rb +3 -3
- data/lib/puppet/parser/resource.rb +8 -5
- data/lib/puppet/parser/scope.rb +1 -1
- data/lib/puppet/plugins/configuration.rb +8 -0
- data/lib/puppet/plugins/data_providers.rb +1 -0
- data/lib/puppet/plugins/data_providers/data_provider.rb +7 -28
- data/lib/puppet/plugins/data_providers/registry.rb +1 -0
- data/lib/puppet/pops.rb +4 -0
- data/lib/puppet/pops/evaluator/access_operator.rb +36 -5
- data/lib/puppet/pops/evaluator/closure.rb +81 -12
- data/lib/puppet/pops/evaluator/compare_operator.rb +24 -1
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +29 -5
- data/lib/puppet/pops/evaluator/json_strict_literal_evaluator.rb +1 -1
- data/lib/puppet/pops/evaluator/runtime3_converter.rb +53 -62
- data/lib/puppet/pops/evaluator/runtime3_support.rb +15 -6
- data/lib/puppet/pops/functions/dispatch.rb +9 -2
- data/lib/puppet/pops/functions/dispatcher.rb +3 -1
- data/lib/puppet/pops/functions/function.rb +19 -2
- data/lib/puppet/pops/issues.rb +9 -0
- data/lib/puppet/pops/label_provider.rb +2 -2
- data/lib/puppet/pops/loader/loader.rb +17 -0
- data/lib/puppet/pops/loader/static_loader.rb +0 -41
- data/lib/puppet/pops/lookup.rb +12 -0
- data/lib/puppet/pops/lookup/context.rb +86 -0
- data/lib/puppet/pops/lookup/explainer.rb +46 -6
- data/lib/puppet/pops/lookup/invocation.rb +19 -0
- data/lib/puppet/pops/lookup/sub_lookup.rb +1 -1
- data/lib/puppet/pops/model/factory.rb +20 -8
- data/lib/puppet/pops/model/model_label_provider.rb +3 -0
- data/lib/puppet/pops/model/model_meta.rb +2 -0
- data/lib/puppet/pops/model/model_tree_dumper.rb +14 -0
- data/lib/puppet/pops/parser/egrammar.ra +11 -6
- data/lib/puppet/pops/parser/eparser.rb +1112 -1086
- data/lib/puppet/pops/parser/heredoc_support.rb +1 -2
- data/lib/puppet/pops/pcore.rb +1 -0
- data/lib/puppet/pops/puppet_stack.rb +3 -3
- data/lib/puppet/pops/resource/param.rb +5 -1
- data/lib/puppet/pops/resource/resource_type_impl.rb +8 -4
- data/lib/puppet/pops/resource/resource_type_set.pcore +1 -0
- data/lib/puppet/pops/serialization/abstract_reader.rb +19 -2
- data/lib/puppet/pops/serialization/abstract_writer.rb +16 -3
- data/lib/puppet/pops/serialization/deserializer.rb +5 -1
- data/lib/puppet/pops/serialization/extension.rb +2 -0
- data/lib/puppet/pops/serialization/json.rb +76 -26
- data/lib/puppet/pops/serialization/serializer.rb +5 -1
- data/lib/puppet/pops/serialization/time_factory.rb +2 -1
- data/lib/puppet/pops/time/timespan.rb +718 -0
- data/lib/puppet/pops/time/timestamp.rb +148 -0
- data/lib/puppet/pops/types/p_binary_type.rb +220 -0
- data/lib/puppet/pops/types/p_object_type.rb +12 -6
- data/lib/puppet/pops/types/p_sensitive_type.rb +5 -1
- data/lib/puppet/pops/types/p_timespan_type.rb +141 -0
- data/lib/puppet/pops/types/p_timestamp_type.rb +69 -0
- data/lib/puppet/pops/types/string_converter.rb +62 -0
- data/lib/puppet/pops/types/type_asserter.rb +1 -1
- data/lib/puppet/pops/types/type_calculator.rb +17 -3
- data/lib/puppet/pops/types/type_factory.rb +35 -1
- data/lib/puppet/pops/types/type_formatter.rb +64 -11
- data/lib/puppet/pops/types/type_mismatch_describer.rb +110 -61
- data/lib/puppet/pops/types/type_parser.rb +18 -4
- data/lib/puppet/pops/types/types.rb +98 -63
- data/lib/puppet/pops/validation.rb +9 -1
- data/lib/puppet/pops/validation/checker4_0.rb +7 -0
- data/lib/puppet/property.rb +1 -1
- data/lib/puppet/provider.rb +3 -6
- data/lib/puppet/provider/mcx/mcxcontent.rb +1 -1
- data/lib/puppet/provider/mount/parsed.rb +18 -4
- data/lib/puppet/provider/nameservice/directoryservice.rb +15 -7
- data/lib/puppet/provider/package/gem.rb +6 -1
- data/lib/puppet/provider/package/pip.rb +0 -1
- data/lib/puppet/provider/package/pkg.rb +5 -1
- data/lib/puppet/provider/package/pkgng.rb +1 -1
- data/lib/puppet/provider/package/yum.rb +10 -0
- data/lib/puppet/provider/service/launchd.rb +1 -0
- data/lib/puppet/provider/user/directoryservice.rb +6 -6
- data/lib/puppet/provider/yumrepo/inifile.rb +1 -1
- data/lib/puppet/provider/zpool/zpool.rb +1 -1
- data/lib/puppet/resource.rb +54 -12
- data/lib/puppet/resource/capability_finder.rb +15 -9
- data/lib/puppet/resource/catalog.rb +25 -6
- data/lib/puppet/resource/type.rb +3 -1
- data/lib/puppet/settings.rb +1 -1
- data/lib/puppet/settings/environment_conf.rb +12 -4
- data/lib/puppet/syntax_checkers/base64.rb +41 -0
- data/lib/puppet/syntax_checkers/json.rb +0 -2
- data/lib/puppet/transaction.rb +6 -0
- data/lib/puppet/transaction/additional_resource_generator.rb +5 -0
- data/lib/puppet/transaction/report.rb +7 -2
- data/lib/puppet/type.rb +2 -1
- data/lib/puppet/type/file/checksum.rb +1 -0
- data/lib/puppet/type/file/content.rb +4 -4
- data/lib/puppet/type/mount.rb +44 -0
- data/lib/puppet/type/ssh_authorized_key.rb +1 -1
- data/lib/puppet/type/tidy.rb +3 -0
- data/lib/puppet/type/user.rb +12 -6
- data/lib/puppet/util/log.rb +25 -0
- data/lib/puppet/util/plist.rb +8 -3
- data/lib/puppet/version.rb +1 -1
- data/lib/puppet_x.rb +7 -1
- data/spec/integration/application/apply_spec.rb +118 -0
- data/spec/integration/parser/compiler_spec.rb +28 -0
- data/spec/integration/parser/pcore_resource_spec.rb +40 -3
- data/spec/integration/provider/mount_spec.rb +2 -1
- data/spec/integration/util/windows/principal_spec.rb +2 -2
- data/spec/integration/util/windows/registry_spec.rb +4 -4
- data/spec/lib/puppet_spec/compiler.rb +5 -1
- data/spec/lib/puppet_spec/unindent.rb +5 -0
- data/spec/shared_contexts/types_setup.rb +6 -0
- data/spec/shared_examples/rhel_package_provider.rb +16 -0
- data/spec/spec_helper.rb +1 -0
- data/spec/unit/agent_spec.rb +11 -0
- data/spec/unit/application/lookup_spec.rb +94 -3
- data/spec/unit/capability_spec.rb +22 -0
- data/spec/unit/configurer_spec.rb +8 -0
- data/spec/unit/face/epp_face_spec.rb +22 -3
- data/spec/unit/functions/assert_type_spec.rb +3 -3
- data/spec/unit/functions/binary_file_spec.rb +46 -0
- data/spec/unit/functions/break_spec.rb +89 -0
- data/spec/unit/{parser/functions → functions}/contain_spec.rb +68 -3
- data/spec/unit/functions/find_file_spec.rb +69 -0
- data/spec/unit/functions/include_spec.rb +175 -0
- data/spec/unit/functions/logging_spec.rb +54 -0
- data/spec/unit/functions/lookup_spec.rb +3 -3
- data/spec/unit/functions/new_spec.rb +105 -5
- data/spec/unit/functions/next_spec.rb +93 -0
- data/spec/unit/functions/require_spec.rb +83 -0
- data/spec/unit/functions/return_spec.rb +105 -0
- data/spec/unit/{parser/functions → functions}/shared.rb +14 -11
- data/spec/unit/functions/strftime_spec.rb +152 -0
- data/spec/unit/functions4_spec.rb +22 -0
- data/spec/unit/indirector/face_spec.rb +10 -2
- data/spec/unit/network/http/error_spec.rb +1 -2
- data/spec/unit/network/http/handler_spec.rb +6 -5
- data/spec/unit/parser/functions/hiera_array_spec.rb +1 -1
- data/spec/unit/parser/functions/hiera_hash_spec.rb +1 -1
- data/spec/unit/parser/functions/hiera_include_spec.rb +1 -1
- data/spec/unit/parser/functions/hiera_spec.rb +1 -1
- data/spec/unit/parser/functions/lookup_spec.rb +1 -1
- data/spec/unit/parser/functions/regsubst_spec.rb +1 -1
- data/spec/unit/parser/functions/split_spec.rb +1 -1
- data/spec/unit/pops/evaluator/access_ops_spec.rb +81 -1
- data/spec/unit/pops/evaluator/arithmetic_ops_spec.rb +170 -0
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +29 -4
- data/spec/unit/pops/evaluator/runtime3_converter_spec.rb +112 -4
- data/spec/unit/pops/loaders/dependency_loader_spec.rb +12 -0
- data/spec/unit/pops/loaders/static_loader_spec.rb +0 -26
- data/spec/unit/pops/lookup/context_spec.rb +149 -0
- data/spec/unit/pops/parser/parse_functions_spec.rb +19 -0
- data/spec/unit/pops/parser/parse_lambda_spec.rb +19 -0
- data/spec/unit/pops/puppet_stack_spec.rb +1 -1
- data/spec/unit/pops/resource/resource_type_impl_spec.rb +74 -0
- data/spec/unit/pops/serialization/packer_spec.rb +34 -14
- data/spec/unit/pops/serialization/serialization_spec.rb +67 -5
- data/spec/unit/pops/time/timespan_spec.rb +121 -0
- data/spec/unit/pops/types/p_binary_type_spec.rb +243 -0
- data/spec/unit/pops/types/p_object_type_spec.rb +7 -7
- data/spec/unit/pops/types/p_sensitive_type_spec.rb +1 -1
- data/spec/unit/pops/types/p_timespan_type_spec.rb +273 -0
- data/spec/unit/pops/types/p_timestamp_type_spec.rb +311 -0
- data/spec/unit/pops/types/p_type_set_type_spec.rb +13 -13
- data/spec/unit/pops/types/ruby_generator_spec.rb +12 -12
- data/spec/unit/pops/types/string_converter_spec.rb +89 -0
- data/spec/unit/pops/types/type_asserter_spec.rb +3 -3
- data/spec/unit/pops/types/type_calculator_spec.rb +113 -5
- data/spec/unit/pops/types/type_formatter_spec.rb +40 -0
- data/spec/unit/pops/types/type_mismatch_describer_spec.rb +49 -38
- data/spec/unit/pops/types/type_parser_spec.rb +87 -4
- data/spec/unit/pops/types/types_spec.rb +1 -1
- data/spec/unit/pops/validator/validator_spec.rb +23 -0
- data/spec/unit/provider/mount/parsed_spec.rb +47 -29
- data/spec/unit/provider/package/pkg_spec.rb +109 -99
- data/spec/unit/provider/ssh_authorized_key/parsed_spec.rb +1 -0
- data/spec/unit/provider/user/aix_spec.rb +1 -1
- data/spec/unit/provider/user/directoryservice_spec.rb +101 -30
- data/spec/unit/resource/capability_finder_spec.rb +29 -7
- data/spec/unit/resource/catalog_spec.rb +127 -0
- data/spec/unit/ssl/certificate_request_spec.rb +1 -1
- data/spec/unit/transaction/additional_resource_generator_spec.rb +30 -0
- data/spec/unit/transaction/persistence_spec.rb +1 -6
- data/spec/unit/transaction/report_spec.rb +23 -0
- data/spec/unit/transaction_spec.rb +38 -0
- data/spec/unit/type/mount_spec.rb +5 -0
- data/spec/unit/util/plist_spec.rb +14 -2
- metadata +71 -12
- data/spec/integration/parser/functions/require_spec.rb +0 -43
- data/spec/unit/parser/functions/include_spec.rb +0 -55
- data/spec/unit/parser/functions/require_spec.rb +0 -68
@@ -391,4 +391,26 @@ test { one: hostname => "ahost", export => Cap[two] }
|
|
391
391
|
end
|
392
392
|
end
|
393
393
|
end
|
394
|
+
|
395
|
+
context 'and aliased resources' do
|
396
|
+
let(:drive) { Puppet.features.microsoft_windows? ? 'C:' : '' }
|
397
|
+
let(:code) { <<-PUPPET }
|
398
|
+
$dir='#{drive}/tmp/test'
|
399
|
+
$same_dir='#{drive}/tmp/test/'
|
400
|
+
|
401
|
+
file {$dir:
|
402
|
+
ensure => directory
|
403
|
+
}
|
404
|
+
|
405
|
+
if !defined(File["${same_dir}"]) {
|
406
|
+
file { $same_dir:
|
407
|
+
ensure => directory
|
408
|
+
}
|
409
|
+
}
|
410
|
+
PUPPET
|
411
|
+
|
412
|
+
it 'fails if a resource is defined and then redefined using name that results in the same alias' do
|
413
|
+
expect { compile_to_ral(code) }.to raise_error(/resource \["File", "#{drive}\/tmp\/test"\] already declared/)
|
414
|
+
end
|
415
|
+
end
|
394
416
|
end
|
@@ -424,6 +424,14 @@ describe Puppet::Configurer do
|
|
424
424
|
end
|
425
425
|
end
|
426
426
|
|
427
|
+
describe "when initialized with a transaction_uuid" do
|
428
|
+
it "stores it" do
|
429
|
+
SecureRandom.expects(:uuid).never
|
430
|
+
configurer = Puppet::Configurer.new(Puppet::Configurer::DownloaderFactory.new, 'foo')
|
431
|
+
expect(configurer.instance_variable_get(:@transaction_uuid) == 'foo')
|
432
|
+
end
|
433
|
+
end
|
434
|
+
|
427
435
|
describe "when sending a report" do
|
428
436
|
include PuppetSpec::Files
|
429
437
|
|
@@ -102,9 +102,6 @@ describe Puppet::Face[:epp, :current] do
|
|
102
102
|
end
|
103
103
|
end
|
104
104
|
|
105
|
-
context "render" do
|
106
|
-
|
107
|
-
end
|
108
105
|
|
109
106
|
context "dump" do
|
110
107
|
it "prints the AST of a template given with the -e option" do
|
@@ -232,6 +229,28 @@ describe Puppet::Face[:epp, :current] do
|
|
232
229
|
).to eq("goodbye mr Y")
|
233
230
|
end
|
234
231
|
|
232
|
+
it "sets $facts" do
|
233
|
+
expect(eppface.render({ :e => 'facts is hash: <%= $facts =~ Hash %>' })).to eql("facts is hash: true")
|
234
|
+
end
|
235
|
+
|
236
|
+
it "sets $trusted" do
|
237
|
+
expect(eppface.render({ :e => 'trusted is hash: <%= $trusted =~ Hash %>' })).to eql("trusted is hash: true")
|
238
|
+
end
|
239
|
+
|
240
|
+
it "facts can be added to" do
|
241
|
+
expect(eppface.render({
|
242
|
+
:facts => {'the_crux' => 'biscuit'},
|
243
|
+
:e => '<%= $facts[the_crux] %>',
|
244
|
+
})).to eql("biscuit")
|
245
|
+
end
|
246
|
+
|
247
|
+
it "facts can be overridden" do
|
248
|
+
expect(eppface.render({
|
249
|
+
:facts => {'operatingsystem' => 'Merwin'},
|
250
|
+
:e => '<%= $facts[operatingsystem] %>',
|
251
|
+
})).to eql("Merwin")
|
252
|
+
end
|
253
|
+
|
235
254
|
context "in an environment with templates" do
|
236
255
|
let(:dir) do
|
237
256
|
dir_containing('environments', { 'production' => { 'modules' => {
|
@@ -22,7 +22,7 @@ describe 'the assert_type function' do
|
|
22
22
|
it 'asserts non compliant type by raising an error' do
|
23
23
|
expect do
|
24
24
|
func.call({}, type(Integer), 'hello world')
|
25
|
-
end.to raise_error(Puppet::Pops::Types::TypeAssertionError, /
|
25
|
+
end.to raise_error(Puppet::Pops::Types::TypeAssertionError, /expects an Integer value, got String/)
|
26
26
|
end
|
27
27
|
|
28
28
|
it 'checks that first argument is a type' do
|
@@ -84,7 +84,7 @@ describe 'the assert_type function' do
|
|
84
84
|
assert_type(UnprivilegedPort, 345)
|
85
85
|
notice('ok')
|
86
86
|
CODE
|
87
|
-
expect { eval_and_collect_notices(code) }.to raise_error(Puppet::Error, /
|
87
|
+
expect { eval_and_collect_notices(code) }.to raise_error(Puppet::Error, /expects an UnprivilegedPort = Integer\[1024, 65537\] value, got Integer\[345, 345\]/)
|
88
88
|
end
|
89
89
|
|
90
90
|
it 'will use infer_set to report detailed information about complex mismatches' do
|
@@ -92,6 +92,6 @@ describe 'the assert_type function' do
|
|
92
92
|
assert_type(Struct[{a=>Integer,b=>Boolean}], {a=>hej,x=>s})
|
93
93
|
CODE
|
94
94
|
expect { eval_and_collect_notices(code) }.to raise_error(Puppet::Error,
|
95
|
-
/entry 'a'
|
95
|
+
/entry 'a' expects an Integer value, got String.*expects a value for key 'b'.*unrecognized key 'x'/m)
|
96
96
|
end
|
97
97
|
end
|
@@ -0,0 +1,46 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
require 'puppet_spec/compiler'
|
3
|
+
require 'matchers/resource'
|
4
|
+
require 'puppet_spec/files'
|
5
|
+
|
6
|
+
describe 'the binary_file function' do
|
7
|
+
include PuppetSpec::Compiler
|
8
|
+
include Matchers::Resource
|
9
|
+
include PuppetSpec::Files
|
10
|
+
|
11
|
+
def with_file_content(content)
|
12
|
+
path = tmpfile('find-file-function')
|
13
|
+
file = File.new(path, 'wb')
|
14
|
+
file.sync = true
|
15
|
+
file.print content
|
16
|
+
yield path
|
17
|
+
end
|
18
|
+
|
19
|
+
it 'reads an existing absolute file' do
|
20
|
+
with_file_content('one') do |one|
|
21
|
+
# Note that Binary to String produced Base64 encoded version of 'one' which is 'b23l'
|
22
|
+
expect(compile_to_catalog("notify { String(binary_file('#{one}')):}")).to have_resource("Notify[b25l]")
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
it 'errors on non existing files' do
|
27
|
+
expect do
|
28
|
+
with_file_content('one') do |one|
|
29
|
+
compile_to_catalog("notify { binary_file('#{one}/nope'):}")
|
30
|
+
end
|
31
|
+
end.to raise_error(/The given file '.*' does not exist/)
|
32
|
+
end
|
33
|
+
|
34
|
+
it 'reads an existing file in a module' do
|
35
|
+
with_file_content('binary_data') do |name|
|
36
|
+
mod = mock 'module'
|
37
|
+
mod.stubs(:file).with('myfile').returns(name)
|
38
|
+
Puppet[:code] = "notify { String(binary_file('mymod/myfile')):}"
|
39
|
+
node = Puppet::Node.new('localhost')
|
40
|
+
compiler = Puppet::Parser::Compiler.new(node)
|
41
|
+
compiler.environment.stubs(:module).with('mymod').returns(mod)
|
42
|
+
# Note that the Binary to string produces Base64 encoded version of 'binary_data' which is 'YmluYXJ5X2RhdGE='
|
43
|
+
expect(compiler.compile().filter { |r| r.virtual? }).to have_resource("Notify[YmluYXJ5X2RhdGE=]")
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
@@ -0,0 +1,89 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
require 'puppet_spec/compiler'
|
4
|
+
require 'matchers/resource'
|
5
|
+
|
6
|
+
describe 'the break function' do
|
7
|
+
include PuppetSpec::Compiler
|
8
|
+
include Matchers::Resource
|
9
|
+
|
10
|
+
context do
|
11
|
+
it 'breaks iteration as if at end of input' do
|
12
|
+
expect(compile_to_catalog(<<-CODE)).to have_resource('Notify[[1, 2]]')
|
13
|
+
function please_break() {
|
14
|
+
[1,2,3].map |$x| { if $x == 3 { break() } $x }
|
15
|
+
}
|
16
|
+
notify { String(please_break()): }
|
17
|
+
CODE
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
it 'does not provide early exit from a class' do
|
22
|
+
# A break would semantically mean that the class should not be included - as if the
|
23
|
+
# iteration over class names should stop. That is too magic and should
|
24
|
+
# be done differently by the user.
|
25
|
+
#
|
26
|
+
expect do
|
27
|
+
compile_to_catalog(<<-CODE)
|
28
|
+
class does_break {
|
29
|
+
notice 'a'
|
30
|
+
if 1 == 1 { break() } # avoid making next line statically unreachable
|
31
|
+
notice 'b'
|
32
|
+
}
|
33
|
+
include(does_break)
|
34
|
+
CODE
|
35
|
+
end.to raise_error(/break\(\) from context where this is illegal at unknown:3 on node.*/)
|
36
|
+
end
|
37
|
+
|
38
|
+
it 'does not provide early exit from a define' do
|
39
|
+
# A break would semantically mean that the resource should not be created - as if the
|
40
|
+
# iteration over resource titles should stop. That is too magic and should
|
41
|
+
# be done differently by the user.
|
42
|
+
#
|
43
|
+
expect do
|
44
|
+
compile_to_catalog(<<-CODE)
|
45
|
+
define does_break {
|
46
|
+
notice 'a'
|
47
|
+
if 1 == 1 { break() } # avoid making next line statically unreachable
|
48
|
+
notice 'b'
|
49
|
+
}
|
50
|
+
does_break { 'no_you_cannot': }
|
51
|
+
CODE
|
52
|
+
end.to raise_error(/break\(\) from context where this is illegal at unknown:3 on node.*/)
|
53
|
+
end
|
54
|
+
|
55
|
+
it 'can be called when nested in a function to make that function behave as a break' do
|
56
|
+
# This allows functions like break_when(...) to be implemented by calling break() conditionally
|
57
|
+
#
|
58
|
+
expect(eval_and_collect_notices(<<-CODE)).to eql(['[100]'])
|
59
|
+
function nested_break($x) {
|
60
|
+
if $x == 2 { break() } else { $x * 100 }
|
61
|
+
}
|
62
|
+
function example() {
|
63
|
+
[1,2,3].map |$x| { nested_break($x) }
|
64
|
+
}
|
65
|
+
notice example()
|
66
|
+
CODE
|
67
|
+
end
|
68
|
+
|
69
|
+
it 'can not be called nested from top scope' do
|
70
|
+
expect do
|
71
|
+
compile_to_catalog(<<-CODE)
|
72
|
+
# line 1
|
73
|
+
# line 2
|
74
|
+
$result = with(1) |$x| { with($x) |$x| {break() }}
|
75
|
+
notice $result
|
76
|
+
CODE
|
77
|
+
end.to raise_error(/break\(\) from context where this is illegal at unknown:3 on node.*/)
|
78
|
+
end
|
79
|
+
|
80
|
+
it 'can not be called from top scope' do
|
81
|
+
expect do
|
82
|
+
compile_to_catalog(<<-CODE)
|
83
|
+
# line 1
|
84
|
+
# line 2
|
85
|
+
break()
|
86
|
+
CODE
|
87
|
+
end.to raise_error(/break\(\) from context where this is illegal at unknown:3 on node.*/)
|
88
|
+
end
|
89
|
+
end
|
@@ -5,7 +5,7 @@ require 'puppet/parser/functions'
|
|
5
5
|
require 'matchers/containment_matchers'
|
6
6
|
require 'matchers/resource'
|
7
7
|
require 'matchers/include_in_order'
|
8
|
-
require 'unit/
|
8
|
+
require 'unit/functions/shared'
|
9
9
|
|
10
10
|
|
11
11
|
describe 'The "contain" function' do
|
@@ -227,7 +227,72 @@ describe 'The "contain" function' do
|
|
227
227
|
end
|
228
228
|
end
|
229
229
|
|
230
|
-
|
231
|
-
|
230
|
+
it 'produces an array with a single class references given a single argument' do
|
231
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
232
|
+
class a {
|
233
|
+
notify { "a": }
|
234
|
+
}
|
235
|
+
|
236
|
+
class container {
|
237
|
+
$x = contain(a)
|
238
|
+
Array[Type[Class], 1, 1].assert_type($x)
|
239
|
+
notify { 'feedback': message => "$x" }
|
240
|
+
}
|
241
|
+
|
242
|
+
include container
|
243
|
+
MANIFEST
|
244
|
+
|
245
|
+
feedback = catalog.resource("Notify", "feedback")
|
246
|
+
expect(feedback[:message]).to eql("[Class[a]]")
|
247
|
+
end
|
248
|
+
|
249
|
+
it 'produces an array with class references given multiple arguments' do
|
250
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
251
|
+
class a {
|
252
|
+
notify { "a": }
|
253
|
+
}
|
254
|
+
|
255
|
+
class b {
|
256
|
+
notify { "b": }
|
257
|
+
}
|
258
|
+
|
259
|
+
class container {
|
260
|
+
$x = contain(a, b)
|
261
|
+
Array[Type[Class], 2, 2].assert_type($x)
|
262
|
+
notify { 'feedback': message => "$x" }
|
263
|
+
}
|
232
264
|
|
265
|
+
include container
|
266
|
+
MANIFEST
|
267
|
+
|
268
|
+
feedback = catalog.resource("Notify", "feedback")
|
269
|
+
expect(feedback[:message]).to eql("[Class[a], Class[b]]")
|
270
|
+
end
|
271
|
+
|
272
|
+
it 'allows the result to be used in a relationship operation' do
|
273
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
274
|
+
class a {
|
275
|
+
notify { "a": }
|
276
|
+
}
|
277
|
+
|
278
|
+
class b {
|
279
|
+
notify { "b": }
|
280
|
+
}
|
281
|
+
|
282
|
+
notify { 'c': }
|
283
|
+
|
284
|
+
class container {
|
285
|
+
contain(a, b) -> Notify[c]
|
286
|
+
}
|
287
|
+
|
288
|
+
include container
|
289
|
+
MANIFEST
|
290
|
+
|
291
|
+
# Assert relationships are formed
|
292
|
+
expect(catalog.resource("Class", "a")[:before][0]).to eql('Notify[c]')
|
293
|
+
expect(catalog.resource("Class", "b")[:before][0]).to eql('Notify[c]')
|
294
|
+
end
|
295
|
+
|
296
|
+
it_should_behave_like 'all functions transforming relative to absolute names', :contain
|
297
|
+
it_should_behave_like 'an inclusion function, regardless of the type of class reference,', :contain
|
233
298
|
end
|
@@ -0,0 +1,69 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
require 'puppet_spec/compiler'
|
3
|
+
require 'matchers/resource'
|
4
|
+
require 'puppet_spec/files'
|
5
|
+
|
6
|
+
describe 'the find_file function' do
|
7
|
+
include PuppetSpec::Compiler
|
8
|
+
include Matchers::Resource
|
9
|
+
include PuppetSpec::Files
|
10
|
+
|
11
|
+
def with_file_content(content)
|
12
|
+
path = tmpfile('find-file-function')
|
13
|
+
file = File.new(path, 'wb')
|
14
|
+
file.sync = true
|
15
|
+
file.print content
|
16
|
+
yield path
|
17
|
+
end
|
18
|
+
|
19
|
+
it 'finds an existing absolute file when given arguments individually' do
|
20
|
+
with_file_content('one') do |one|
|
21
|
+
with_file_content('two') do |two|
|
22
|
+
expect(compile_to_catalog("notify { find_file('#{one}', '#{two}'):}")).to have_resource("Notify[#{one}]")
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
it 'skips non existing files' do
|
28
|
+
with_file_content('one') do |one|
|
29
|
+
with_file_content('two') do |two|
|
30
|
+
expect(compile_to_catalog("notify { find_file('#{one}/nope', '#{two}'):}")).to have_resource("Notify[#{two}]")
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
it 'accepts arguments given as an array' do
|
36
|
+
with_file_content('one') do |one|
|
37
|
+
with_file_content('two') do |two|
|
38
|
+
expect(compile_to_catalog("notify { find_file(['#{one}', '#{two}']):}")).to have_resource("Notify[#{one}]")
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
it 'finds an existing file in a module' do
|
44
|
+
with_file_content('file content') do |name|
|
45
|
+
mod = mock 'module'
|
46
|
+
mod.stubs(:file).with('myfile').returns(name)
|
47
|
+
Puppet[:code] = "notify { find_file('mymod/myfile'):}"
|
48
|
+
node = Puppet::Node.new('localhost')
|
49
|
+
compiler = Puppet::Parser::Compiler.new(node)
|
50
|
+
compiler.environment.stubs(:module).with('mymod').returns(mod)
|
51
|
+
|
52
|
+
expect(compiler.compile().filter { |r| r.virtual? }).to have_resource("Notify[#{name}]")
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
it 'returns undef when none of the paths were found' do
|
57
|
+
mod = mock 'module'
|
58
|
+
mod.stubs(:file).with('myfile').returns(nil)
|
59
|
+
Puppet[:code] = "notify { String(type(find_file('mymod/myfile', 'nomod/nofile'))):}"
|
60
|
+
node = Puppet::Node.new('localhost')
|
61
|
+
compiler = Puppet::Parser::Compiler.new(node)
|
62
|
+
# For a module that does not have the file
|
63
|
+
compiler.environment.stubs(:module).with('mymod').returns(mod)
|
64
|
+
# For a module that does not exist
|
65
|
+
compiler.environment.stubs(:module).with('nomod').returns(nil)
|
66
|
+
|
67
|
+
expect(compiler.compile().filter { |r| r.virtual? }).to have_resource("Notify[Undef]")
|
68
|
+
end
|
69
|
+
end
|
@@ -0,0 +1,175 @@
|
|
1
|
+
#! /usr/bin/env ruby
|
2
|
+
require 'spec_helper'
|
3
|
+
require 'puppet_spec/compiler'
|
4
|
+
require 'puppet/parser/functions'
|
5
|
+
require 'matchers/containment_matchers'
|
6
|
+
require 'matchers/resource'
|
7
|
+
require 'matchers/include_in_order'
|
8
|
+
require 'unit/functions/shared'
|
9
|
+
|
10
|
+
|
11
|
+
describe 'The "include" function' do
|
12
|
+
include PuppetSpec::Compiler
|
13
|
+
include ContainmentMatchers
|
14
|
+
include Matchers::Resource
|
15
|
+
|
16
|
+
before(:each) do
|
17
|
+
compiler = Puppet::Parser::Compiler.new(Puppet::Node.new("foo"))
|
18
|
+
@scope = Puppet::Parser::Scope.new(compiler)
|
19
|
+
end
|
20
|
+
|
21
|
+
it "includes a class" do
|
22
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
23
|
+
class included {
|
24
|
+
notify { "included": }
|
25
|
+
}
|
26
|
+
|
27
|
+
include included
|
28
|
+
MANIFEST
|
29
|
+
|
30
|
+
expect(catalog.classes).to include("included")
|
31
|
+
end
|
32
|
+
|
33
|
+
it "includes a class when using a fully qualified anchored name" do
|
34
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
35
|
+
class included {
|
36
|
+
notify { "included": }
|
37
|
+
}
|
38
|
+
|
39
|
+
include ::included
|
40
|
+
MANIFEST
|
41
|
+
|
42
|
+
expect(catalog.classes).to include("included")
|
43
|
+
end
|
44
|
+
|
45
|
+
it "includes multiple classes" do
|
46
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
47
|
+
class included {
|
48
|
+
notify { "included": }
|
49
|
+
}
|
50
|
+
class included_too {
|
51
|
+
notify { "included_too": }
|
52
|
+
}
|
53
|
+
|
54
|
+
include included, included_too
|
55
|
+
MANIFEST
|
56
|
+
|
57
|
+
expect(catalog.classes).to include("included")
|
58
|
+
expect(catalog.classes).to include("included_too")
|
59
|
+
end
|
60
|
+
|
61
|
+
it "includes multiple classes given as an array" do
|
62
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
63
|
+
class included {
|
64
|
+
notify { "included": }
|
65
|
+
}
|
66
|
+
class included_too {
|
67
|
+
notify { "included_too": }
|
68
|
+
}
|
69
|
+
|
70
|
+
include [included, included_too]
|
71
|
+
MANIFEST
|
72
|
+
|
73
|
+
expect(catalog.classes).to include("included")
|
74
|
+
expect(catalog.classes).to include("included_too")
|
75
|
+
end
|
76
|
+
|
77
|
+
it "flattens nested arrays" do
|
78
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
79
|
+
class included {
|
80
|
+
notify { "included": }
|
81
|
+
}
|
82
|
+
class included_too {
|
83
|
+
notify { "included_too": }
|
84
|
+
}
|
85
|
+
|
86
|
+
include [[[included], [[[included_too]]]]]
|
87
|
+
MANIFEST
|
88
|
+
|
89
|
+
expect(catalog.classes).to include("included")
|
90
|
+
expect(catalog.classes).to include("included_too")
|
91
|
+
end
|
92
|
+
|
93
|
+
it "raises an error if class does not exist" do
|
94
|
+
expect {
|
95
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
96
|
+
include the_god_in_your_religion
|
97
|
+
MANIFEST
|
98
|
+
}.to raise_error(Puppet::Error)
|
99
|
+
end
|
100
|
+
|
101
|
+
it "does not contained the included class in the current class" do
|
102
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
103
|
+
class not_contained {
|
104
|
+
notify { "not_contained": }
|
105
|
+
}
|
106
|
+
|
107
|
+
class container {
|
108
|
+
include not_contained
|
109
|
+
}
|
110
|
+
|
111
|
+
include container
|
112
|
+
MANIFEST
|
113
|
+
|
114
|
+
expect(catalog).to_not contain_class("not_contained").in("container")
|
115
|
+
end
|
116
|
+
|
117
|
+
|
118
|
+
it 'produces an array with a single class references given a single argument' do
|
119
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
120
|
+
class a {
|
121
|
+
notify { "a": }
|
122
|
+
}
|
123
|
+
|
124
|
+
$x = include(a)
|
125
|
+
Array[Type[Class], 1, 1].assert_type($x)
|
126
|
+
notify { 'feedback': message => "$x" }
|
127
|
+
MANIFEST
|
128
|
+
|
129
|
+
feedback = catalog.resource("Notify", "feedback")
|
130
|
+
expect(feedback[:message]).to eql("[Class[a]]")
|
131
|
+
end
|
132
|
+
|
133
|
+
it 'produces an array with class references given multiple arguments' do
|
134
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
135
|
+
class a {
|
136
|
+
notify { "a": }
|
137
|
+
}
|
138
|
+
|
139
|
+
class b {
|
140
|
+
notify { "b": }
|
141
|
+
}
|
142
|
+
|
143
|
+
$x = include(a, b)
|
144
|
+
Array[Type[Class], 2, 2].assert_type($x)
|
145
|
+
notify { 'feedback': message => "$x" }
|
146
|
+
MANIFEST
|
147
|
+
|
148
|
+
feedback = catalog.resource("Notify", "feedback")
|
149
|
+
expect(feedback[:message]).to eql("[Class[a], Class[b]]")
|
150
|
+
end
|
151
|
+
|
152
|
+
it 'allows the result to be used in a relationship operation' do
|
153
|
+
catalog = compile_to_catalog(<<-MANIFEST)
|
154
|
+
class a {
|
155
|
+
notify { "a": }
|
156
|
+
}
|
157
|
+
|
158
|
+
class b {
|
159
|
+
notify { "b": }
|
160
|
+
}
|
161
|
+
|
162
|
+
notify { 'c': }
|
163
|
+
|
164
|
+
include(a, b) -> Notify[c]
|
165
|
+
MANIFEST
|
166
|
+
|
167
|
+
# Assert relationships are formed
|
168
|
+
expect(catalog.resource("Class", "a")[:before][0]).to eql('Notify[c]')
|
169
|
+
expect(catalog.resource("Class", "b")[:before][0]).to eql('Notify[c]')
|
170
|
+
end
|
171
|
+
|
172
|
+
it_should_behave_like 'all functions transforming relative to absolute names', :include
|
173
|
+
it_should_behave_like 'an inclusion function, regardless of the type of class reference,', :include
|
174
|
+
|
175
|
+
end
|