puppet 3.6.2-x86-mingw32 → 3.7.0-x86-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.
- checksums.yaml +4 -4
- data/CONTRIBUTING.md +2 -3
- data/Gemfile +14 -10
- data/README.md +1 -1
- data/ext/build_defaults.yaml +16 -1
- data/ext/debian/control +3 -2
- data/ext/debian/puppet-common.dirs +1 -0
- data/ext/debian/puppet-common.postinst +8 -8
- data/ext/debian/puppet-common.postrm +2 -1
- data/ext/project_data.yaml +16 -12
- data/ext/rack/example-passenger-vhost.conf +2 -2
- data/ext/redhat/puppet.spec.erb +6 -3
- data/ext/windows/service/daemon.rb +47 -41
- data/install.rb +1 -1
- data/lib/puppet.rb +34 -24
- data/lib/puppet/application.rb +34 -1
- data/lib/puppet/application/agent.rb +9 -8
- data/lib/puppet/application/apply.rb +14 -5
- data/lib/puppet/application/doc.rb +4 -11
- data/lib/puppet/application/master.rb +19 -17
- data/lib/puppet/application/queue.rb +1 -1
- data/lib/puppet/application/resource.rb +0 -1
- data/lib/puppet/configurer.rb +39 -2
- data/lib/puppet/configurer/downloader.rb +5 -10
- data/lib/puppet/configurer/downloader_factory.rb +34 -0
- data/lib/puppet/configurer/plugin_handler.rb +11 -17
- data/lib/puppet/defaults.rb +244 -119
- data/lib/puppet/environments.rb +8 -0
- data/lib/puppet/external/nagios/base.rb +1 -1
- data/lib/puppet/external/pson/pure/generator.rb +1 -8
- data/lib/puppet/face/ca.rb +7 -0
- data/lib/puppet/face/file/download.rb +5 -2
- data/lib/puppet/face/file/store.rb +1 -1
- data/lib/puppet/face/instrumentation_data.rb +2 -1
- data/lib/puppet/face/instrumentation_listener.rb +2 -1
- data/lib/puppet/face/instrumentation_probe.rb +2 -1
- data/lib/puppet/face/module/build.rb +2 -2
- data/lib/puppet/face/module/generate.rb +20 -12
- data/lib/puppet/face/module/install.rb +4 -3
- data/lib/puppet/face/module/uninstall.rb +7 -0
- data/lib/puppet/face/module/upgrade.rb +11 -3
- data/lib/puppet/face/node/clean.rb +1 -1
- data/lib/puppet/face/parser.rb +99 -7
- data/lib/puppet/feature/base.rb +18 -12
- data/lib/puppet/feature/cfacter.rb +14 -0
- data/lib/puppet/feature/pe_license.rb +4 -0
- data/lib/puppet/file_bucket/dipper.rb +19 -12
- data/lib/puppet/file_bucket/file.rb +73 -10
- data/lib/puppet/file_serving/configuration/parser.rb +3 -3
- data/lib/puppet/file_system.rb +1 -1
- data/lib/puppet/file_system/file19.rb +41 -0
- data/lib/puppet/file_system/file19windows.rb +0 -1
- data/lib/puppet/file_system/uniquefile.rb +190 -0
- data/lib/puppet/forge.rb +34 -7
- data/lib/puppet/forge/errors.rb +5 -6
- data/lib/puppet/forge/repository.rb +14 -2
- data/lib/puppet/functions.rb +19 -12
- data/lib/puppet/functions/assert_type.rb +27 -10
- data/lib/puppet/functions/each.rb +111 -0
- data/lib/puppet/functions/epp.rb +54 -0
- data/lib/puppet/functions/filter.rb +113 -0
- data/lib/puppet/functions/inline_epp.rb +88 -0
- data/lib/puppet/functions/map.rb +97 -0
- data/lib/puppet/functions/match.rb +102 -0
- data/lib/puppet/functions/reduce.rb +94 -0
- data/lib/puppet/functions/slice.rb +126 -0
- data/lib/puppet/functions/with.rb +23 -0
- data/lib/puppet/indirector/catalog/compiler.rb +4 -4
- data/lib/puppet/indirector/data_binding/hiera.rb +2 -45
- data/lib/puppet/indirector/facts/couch.rb +3 -1
- data/lib/puppet/indirector/facts/facter.rb +52 -65
- data/lib/puppet/indirector/file_bucket_file/file.rb +6 -3
- data/lib/puppet/indirector/hiera.rb +48 -0
- data/lib/puppet/indirector/indirection.rb +1 -1
- data/lib/puppet/indirector/request.rb +9 -3
- data/lib/puppet/indirector/resource/ral.rb +1 -1
- data/lib/puppet/indirector/rest.rb +7 -3
- data/lib/puppet/loaders.rb +0 -1
- data/lib/puppet/module.rb +2 -1
- data/lib/puppet/module_tool.rb +2 -0
- data/lib/puppet/module_tool/applications/application.rb +4 -5
- data/lib/puppet/module_tool/applications/builder.rb +64 -5
- data/lib/puppet/module_tool/applications/uninstaller.rb +3 -2
- data/lib/puppet/module_tool/applications/unpacker.rb +14 -0
- data/lib/puppet/module_tool/applications/upgrader.rb +23 -13
- data/lib/puppet/module_tool/dependency.rb +12 -0
- data/lib/puppet/module_tool/errors/shared.rb +1 -1
- data/lib/puppet/module_tool/errors/upgrader.rb +20 -0
- data/lib/puppet/module_tool/installed_modules.rb +6 -1
- data/lib/puppet/module_tool/metadata.rb +53 -3
- data/lib/puppet/module_tool/modulefile.rb +1 -1
- data/lib/puppet/module_tool/skeleton/templates/generator/Gemfile +7 -0
- data/lib/puppet/module_tool/skeleton/templates/generator/manifests/init.pp.erb +1 -1
- data/lib/puppet/module_tool/skeleton/templates/generator/spec/spec_helper.rb +1 -17
- data/lib/puppet/module_tool/tar/mini.rb +20 -2
- data/lib/puppet/network/http.rb +5 -0
- data/lib/puppet/network/http/api/v1.rb +2 -2
- data/lib/puppet/network/http/api/v2/environments.rb +15 -1
- data/lib/puppet/network/http/connection.rb +54 -68
- data/lib/puppet/network/http/factory.rb +44 -0
- data/lib/puppet/network/http/handler.rb +12 -6
- data/lib/puppet/network/http/nocache_pool.rb +21 -0
- data/lib/puppet/network/http/pool.rb +120 -0
- data/lib/puppet/network/http/rack/rest.rb +3 -1
- data/lib/puppet/network/http/session.rb +17 -0
- data/lib/puppet/network/http/site.rb +39 -0
- data/lib/puppet/network/http/webrick/rest.rb +3 -1
- data/lib/puppet/network/http_pool.rb +3 -4
- data/lib/puppet/node.rb +19 -6
- data/lib/puppet/node/environment.rb +34 -8
- data/lib/puppet/parser/ast/collection.rb +4 -0
- data/lib/puppet/parser/ast/collexpr.rb +1 -1
- data/lib/puppet/parser/ast/node.rb +5 -0
- data/lib/puppet/parser/ast/pops_bridge.rb +49 -6
- data/lib/puppet/parser/compiler.rb +66 -38
- data/lib/puppet/parser/e4_parser_adapter.rb +2 -2
- data/lib/puppet/parser/files.rb +76 -33
- data/lib/puppet/parser/functions.rb +1 -7
- data/lib/puppet/parser/functions/assert_type.rb +31 -0
- data/lib/puppet/parser/functions/contain.rb +15 -5
- data/lib/puppet/parser/functions/create_resources.rb +5 -1
- data/lib/puppet/parser/functions/digest.rb +5 -0
- data/lib/puppet/parser/functions/each.rb +46 -107
- data/lib/puppet/parser/functions/epp.rb +13 -9
- data/lib/puppet/parser/functions/file.rb +20 -12
- data/lib/puppet/parser/functions/filter.rb +32 -88
- data/lib/puppet/parser/functions/include.rb +12 -24
- data/lib/puppet/parser/functions/inline_epp.rb +9 -12
- data/lib/puppet/parser/functions/lookup.rb +1 -1
- data/lib/puppet/parser/functions/map.rb +30 -83
- data/lib/puppet/parser/functions/match.rb +28 -0
- data/lib/puppet/parser/functions/reduce.rb +69 -98
- data/lib/puppet/parser/functions/require.rb +13 -5
- data/lib/puppet/parser/functions/search.rb +6 -1
- data/lib/puppet/parser/functions/slice.rb +35 -103
- data/lib/puppet/parser/functions/template.rb +12 -5
- data/lib/puppet/parser/functions/with.rb +21 -0
- data/lib/puppet/parser/lexer.rb +1 -1
- data/lib/puppet/parser/parser_factory.rb +21 -33
- data/lib/puppet/parser/resource.rb +2 -3
- data/lib/puppet/parser/scope.rb +85 -15
- data/lib/puppet/pops.rb +9 -11
- data/lib/puppet/pops/adapters.rb +2 -1
- data/lib/puppet/pops/binder/bindings_checker.rb +4 -4
- data/lib/puppet/pops/binder/bindings_factory.rb +6 -6
- data/lib/puppet/pops/binder/bindings_label_provider.rb +1 -1
- data/lib/puppet/pops/binder/bindings_loader.rb +2 -2
- data/lib/puppet/pops/binder/bindings_model.rb +58 -191
- data/lib/puppet/pops/binder/bindings_model_dumper.rb +1 -1
- data/lib/puppet/pops/binder/bindings_model_meta.rb +215 -0
- data/lib/puppet/pops/binder/injector.rb +9 -9
- data/lib/puppet/pops/binder/key_factory.rb +2 -2
- data/lib/puppet/pops/binder/lookup.rb +14 -6
- data/lib/puppet/pops/binder/producers.rb +9 -12
- data/lib/puppet/pops/evaluator/access_operator.rb +35 -29
- data/lib/puppet/pops/evaluator/callable_mismatch_describer.rb +175 -0
- data/lib/puppet/pops/evaluator/callable_signature.rb +1 -2
- data/lib/puppet/pops/evaluator/closure.rb +151 -35
- data/lib/puppet/pops/evaluator/compare_operator.rb +26 -22
- data/lib/puppet/pops/evaluator/epp_evaluator.rb +16 -15
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +277 -229
- data/lib/puppet/pops/evaluator/relationship_operator.rb +3 -2
- data/lib/puppet/pops/evaluator/runtime3_support.rb +86 -53
- data/lib/puppet/pops/functions/dispatch.rb +9 -4
- data/lib/puppet/pops/functions/dispatcher.rb +2 -169
- data/lib/puppet/pops/issue_reporter.rb +14 -6
- data/lib/puppet/pops/issues.rb +96 -21
- data/lib/puppet/pops/loader/base_loader.rb +3 -3
- data/lib/puppet/pops/loader/loader.rb +1 -1
- data/lib/puppet/pops/loader/loader_paths.rb +2 -21
- data/lib/puppet/pops/loader/ruby_function_instantiator.rb +1 -1
- data/lib/puppet/pops/loader/static_loader.rb +12 -2
- data/lib/puppet/pops/model/ast_transformer.rb +4 -24
- data/lib/puppet/pops/model/factory.rb +72 -10
- data/lib/puppet/pops/model/model.rb +82 -574
- data/lib/puppet/pops/model/model_label_provider.rb +4 -2
- data/lib/puppet/pops/model/model_meta.rb +576 -0
- data/lib/puppet/pops/model/model_tree_dumper.rb +27 -5
- data/lib/puppet/pops/parser/egrammar.ra +209 -221
- data/lib/puppet/pops/parser/eparser.rb +1459 -1431
- data/lib/puppet/pops/parser/evaluating_parser.rb +15 -75
- data/lib/puppet/pops/parser/lexer2.rb +14 -10
- data/lib/puppet/pops/parser/lexer_support.rb +6 -0
- data/lib/puppet/pops/parser/locator.rb +1 -1
- data/lib/puppet/pops/parser/parser_support.rb +31 -49
- data/lib/puppet/pops/patterns.rb +10 -10
- data/lib/puppet/pops/semantic_error.rb +1 -1
- data/lib/puppet/pops/types/class_loader.rb +24 -13
- data/lib/puppet/pops/types/type_calculator.rb +188 -87
- data/lib/puppet/pops/types/type_factory.rb +79 -53
- data/lib/puppet/pops/types/type_parser.rb +22 -16
- data/lib/puppet/pops/types/types.rb +283 -392
- data/lib/puppet/pops/types/types_meta.rb +223 -0
- data/lib/puppet/pops/utils.rb +16 -14
- data/lib/puppet/pops/validation/checker4_0.rb +264 -18
- data/lib/puppet/pops/validation/validator_factory_4_0.rb +0 -1
- data/lib/puppet/pops/visitor.rb +0 -103
- data/lib/puppet/provider/exec.rb +10 -1
- data/lib/puppet/provider/file/windows.rb +3 -4
- data/lib/puppet/provider/group/windows_adsi.rb +10 -10
- data/lib/puppet/provider/nameservice/directoryservice.rb +3 -4
- data/lib/puppet/provider/package/apt.rb +5 -1
- data/lib/puppet/provider/package/gem.rb +7 -3
- data/lib/puppet/provider/package/openbsd.rb +84 -7
- data/lib/puppet/provider/package/pacman.rb +29 -4
- data/lib/puppet/provider/package/rpm.rb +5 -7
- data/lib/puppet/provider/package/sun.rb +5 -1
- data/lib/puppet/provider/package/windows.rb +6 -1
- data/lib/puppet/provider/package/windows/exe_package.rb +1 -1
- data/lib/puppet/provider/package/windows/msi_package.rb +1 -1
- data/lib/puppet/provider/package/windows/package.rb +13 -1
- data/lib/puppet/provider/package/yum.rb +7 -3
- data/lib/puppet/provider/package/zypper.rb +5 -1
- data/lib/puppet/provider/parsedfile.rb +17 -1
- data/lib/puppet/provider/scheduled_task/win32_taskscheduler.rb +6 -12
- data/lib/puppet/provider/service/freebsd.rb +12 -12
- data/lib/puppet/provider/service/init.rb +5 -0
- data/lib/puppet/provider/service/launchd.rb +0 -3
- data/lib/puppet/provider/service/openbsd.rb +8 -7
- data/lib/puppet/provider/ssh_authorized_key/parsed.rb +2 -2
- data/lib/puppet/provider/sshkey/parsed.rb +5 -0
- data/lib/puppet/provider/user/user_role_add.rb +5 -4
- data/lib/puppet/provider/user/windows_adsi.rb +8 -8
- data/lib/puppet/provider/zone/solaris.rb +1 -1
- data/lib/puppet/reference/metaparameter.rb +8 -6
- data/lib/puppet/reports/store.rb +4 -9
- data/lib/puppet/resource.rb +75 -11
- data/lib/puppet/resource/catalog.rb +9 -7
- data/lib/puppet/resource/type.rb +27 -0
- data/lib/puppet/settings.rb +61 -41
- data/lib/puppet/settings/base_setting.rb +9 -3
- data/lib/puppet/settings/environment_conf.rb +32 -4
- data/lib/puppet/settings/file_setting.rb +9 -1
- data/lib/puppet/settings/priority_setting.rb +5 -5
- data/lib/puppet/ssl.rb +1 -0
- data/lib/puppet/ssl/certificate_authority.rb +15 -6
- data/lib/puppet/ssl/certificate_authority/autosign_command.rb +2 -1
- data/lib/puppet/ssl/host.rb +3 -2
- data/lib/puppet/ssl/inventory.rb +11 -6
- data/lib/puppet/ssl/validator/default_validator.rb +1 -0
- data/lib/puppet/ssl/validator/no_validator.rb +3 -0
- data/lib/puppet/transaction.rb +29 -0
- data/lib/puppet/transaction/resource_harness.rb +16 -3
- data/lib/puppet/type.rb +71 -49
- data/lib/puppet/type/exec.rb +36 -8
- data/lib/puppet/type/file.rb +56 -16
- data/lib/puppet/type/file/content.rb +3 -3
- data/lib/puppet/type/file/mode.rb +12 -3
- data/lib/puppet/type/file/source.rb +4 -1
- data/lib/puppet/type/group.rb +1 -1
- data/lib/puppet/type/mount.rb +1 -3
- data/lib/puppet/type/resources.rb +59 -35
- data/lib/puppet/type/ssh_authorized_key.rb +54 -16
- data/lib/puppet/type/sshkey.rb +1 -1
- data/lib/puppet/type/user.rb +17 -11
- data/lib/puppet/type/yumrepo.rb +59 -8
- data/lib/puppet/type/zone.rb +3 -6
- data/lib/puppet/util.rb +64 -55
- data/lib/puppet/util/autoload.rb +2 -2
- data/lib/puppet/util/colors.rb +61 -19
- data/lib/puppet/util/command_line.rb +21 -4
- data/lib/puppet/util/execution.rb +41 -29
- data/lib/puppet/util/feature.rb +15 -4
- data/lib/puppet/util/filetype.rb +6 -2
- data/lib/puppet/util/http_proxy.rb +29 -2
- data/lib/puppet/util/lockfile.rb +1 -1
- data/lib/puppet/util/log/destinations.rb +7 -3
- data/lib/puppet/util/logging.rb +44 -14
- data/lib/puppet/util/pidlock.rb +11 -5
- data/lib/puppet/util/posix.rb +21 -31
- data/lib/puppet/util/profiler.rb +17 -9
- data/lib/puppet/util/profiler/aggregate.rb +85 -0
- data/lib/puppet/util/profiler/around_profiler.rb +67 -0
- data/lib/puppet/util/profiler/logging.rb +12 -11
- data/lib/puppet/util/profiler/wall_clock.rb +7 -6
- data/lib/puppet/util/rdoc.rb +8 -1
- data/lib/puppet/util/rdoc/parser/puppet_parser_core.rb +1 -1
- data/lib/puppet/util/suidmanager.rb +1 -8
- data/lib/puppet/util/windows.rb +14 -3
- data/lib/puppet/util/windows/access_control_list.rb +4 -4
- data/lib/puppet/util/{adsi.rb → windows/adsi.rb} +99 -37
- data/lib/puppet/util/windows/api_types.rb +255 -0
- data/lib/puppet/util/windows/com.rb +224 -0
- data/lib/puppet/util/windows/error.rb +72 -5
- data/lib/puppet/util/windows/file.rb +254 -132
- data/lib/puppet/util/windows/process.rb +293 -177
- data/lib/puppet/util/windows/registry.rb +12 -2
- data/lib/puppet/util/windows/root_certs.rb +16 -9
- data/lib/puppet/util/windows/security.rb +501 -232
- data/lib/puppet/util/windows/sid.rb +80 -36
- data/lib/puppet/util/windows/string.rb +2 -0
- data/lib/puppet/util/windows/taskscheduler.rb +1241 -0
- data/lib/puppet/util/windows/user.rb +241 -57
- data/lib/puppet/vendor.rb +3 -1
- data/lib/puppet/vendor/load_pathspec.rb +1 -0
- data/lib/puppet/vendor/load_rgen.rb +1 -0
- data/lib/puppet/vendor/pathspec/CHANGELOG.md +2 -0
- data/lib/puppet/vendor/pathspec/LICENSE +201 -0
- data/lib/puppet/vendor/pathspec/PUPPET_README.md +6 -0
- data/lib/puppet/vendor/pathspec/README.md +53 -0
- data/lib/puppet/vendor/pathspec/lib/pathspec.rb +121 -0
- data/lib/puppet/vendor/pathspec/lib/pathspec/gitignorespec.rb +275 -0
- data/lib/puppet/vendor/pathspec/lib/pathspec/regexspec.rb +17 -0
- data/lib/puppet/vendor/pathspec/lib/pathspec/spec.rb +14 -0
- data/lib/puppet/vendor/require_vendored.rb +2 -0
- data/lib/puppet/vendor/rgen/CHANGELOG +197 -0
- data/lib/puppet/vendor/rgen/MIT-LICENSE +20 -0
- data/lib/puppet/vendor/rgen/PUPPET_README.md +6 -0
- data/lib/puppet/vendor/rgen/README.rdoc +78 -0
- data/lib/puppet/vendor/rgen/Rakefile +41 -0
- data/lib/puppet/vendor/rgen/TODO +41 -0
- data/lib/puppet/vendor/rgen/anounce.txt +61 -0
- data/lib/puppet/vendor/rgen/design_rationale.txt +71 -0
- data/lib/puppet/vendor/rgen/lib/ea_support/ea_support.rb +54 -0
- data/lib/puppet/vendor/rgen/lib/ea_support/id_store.rb +32 -0
- data/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_metamodel.rb +562 -0
- data/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_metamodel_ext.rb +45 -0
- data/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_metamodel_generator.rb +43 -0
- data/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_to_uml13.rb +103 -0
- data/lib/puppet/vendor/rgen/lib/ea_support/uml13_to_uml13_ea.rb +89 -0
- data/lib/puppet/vendor/rgen/lib/metamodels/uml13_metamodel.rb +559 -0
- data/lib/puppet/vendor/rgen/lib/metamodels/uml13_metamodel_ext.rb +26 -0
- data/lib/puppet/vendor/rgen/lib/mmgen/metamodel_generator.rb +20 -0
- data/lib/puppet/vendor/rgen/lib/mmgen/mm_ext/ecore_mmgen_ext.rb +91 -0
- data/lib/puppet/vendor/rgen/lib/mmgen/mmgen.rb +28 -0
- data/lib/puppet/vendor/rgen/lib/mmgen/templates/annotations.tpl +37 -0
- data/lib/puppet/vendor/rgen/lib/mmgen/templates/metamodel_generator.tpl +172 -0
- data/lib/puppet/vendor/rgen/lib/rgen/array_extensions.rb +45 -0
- data/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore.rb +218 -0
- data/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_builder_methods.rb +81 -0
- data/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_ext.rb +69 -0
- data/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_interface.rb +47 -0
- data/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_to_ruby.rb +167 -0
- data/lib/puppet/vendor/rgen/lib/rgen/ecore/ruby_to_ecore.rb +91 -0
- data/lib/puppet/vendor/rgen/lib/rgen/environment.rb +129 -0
- data/lib/puppet/vendor/rgen/lib/rgen/fragment/dump_file_cache.rb +63 -0
- data/lib/puppet/vendor/rgen/lib/rgen/fragment/fragmented_model.rb +140 -0
- data/lib/puppet/vendor/rgen/lib/rgen/fragment/model_fragment.rb +289 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/abstract_instantiator.rb +66 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/abstract_xml_instantiator.rb +66 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/default_xml_instantiator.rb +117 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/ecore_xml_instantiator.rb +169 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/json_instantiator.rb +126 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/json_parser.rb +331 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/json_parser.y +94 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/nodebased_xml_instantiator.rb +137 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/qualified_name_resolver.rb +97 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/reference_resolver.rb +128 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/resolution_helper.rb +47 -0
- data/lib/puppet/vendor/rgen/lib/rgen/instantiator/xmi11_instantiator.rb +168 -0
- data/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder.rb +224 -0
- data/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/builder_extensions.rb +556 -0
- data/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/builder_runtime.rb +174 -0
- data/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/constant_order_helper.rb +89 -0
- data/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/data_types.rb +77 -0
- data/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/intermediate/annotation.rb +30 -0
- data/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/intermediate/feature.rb +168 -0
- data/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/mm_multiple.rb +23 -0
- data/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/module_extension.rb +42 -0
- data/lib/puppet/vendor/rgen/lib/rgen/model_builder.rb +32 -0
- data/lib/puppet/vendor/rgen/lib/rgen/model_builder/builder_context.rb +334 -0
- data/lib/puppet/vendor/rgen/lib/rgen/model_builder/model_serializer.rb +225 -0
- data/lib/puppet/vendor/rgen/lib/rgen/model_builder/reference_resolver.rb +156 -0
- data/lib/puppet/vendor/rgen/lib/rgen/serializer/json_serializer.rb +121 -0
- data/lib/puppet/vendor/rgen/lib/rgen/serializer/opposite_reference_filter.rb +18 -0
- data/lib/puppet/vendor/rgen/lib/rgen/serializer/qualified_name_provider.rb +47 -0
- data/lib/puppet/vendor/rgen/lib/rgen/serializer/xmi11_serializer.rb +116 -0
- data/lib/puppet/vendor/rgen/lib/rgen/serializer/xmi20_serializer.rb +71 -0
- data/lib/puppet/vendor/rgen/lib/rgen/serializer/xml_serializer.rb +98 -0
- data/lib/puppet/vendor/rgen/lib/rgen/template_language.rb +297 -0
- data/lib/puppet/vendor/rgen/lib/rgen/template_language/directory_template_container.rb +83 -0
- data/lib/puppet/vendor/rgen/lib/rgen/template_language/output_handler.rb +87 -0
- data/lib/puppet/vendor/rgen/lib/rgen/template_language/template_container.rb +234 -0
- data/lib/puppet/vendor/rgen/lib/rgen/template_language/template_helper.rb +26 -0
- data/lib/puppet/vendor/rgen/lib/rgen/transformer.rb +475 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/auto_class_creator.rb +61 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/cached_glob.rb +67 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/file_cache_map.rb +124 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/file_change_detector.rb +84 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/method_delegation.rb +114 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/model_comparator.rb +68 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/model_comparator_base.rb +142 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/model_dumper.rb +29 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/name_helper.rb +42 -0
- data/lib/puppet/vendor/rgen/lib/rgen/util/pattern_matcher.rb +329 -0
- data/lib/puppet/vendor/rgen/lib/transformers/ecore_to_uml13.rb +79 -0
- data/lib/puppet/vendor/rgen/lib/transformers/uml13_to_ecore.rb +127 -0
- data/lib/puppet/vendor/rgen/test/array_extensions_test.rb +64 -0
- data/lib/puppet/vendor/rgen/test/ea_instantiator_test.rb +35 -0
- data/lib/puppet/vendor/rgen/test/ea_serializer_test.rb +23 -0
- data/lib/puppet/vendor/rgen/test/ecore_self_test.rb +54 -0
- data/lib/puppet/vendor/rgen/test/environment_test.rb +90 -0
- data/lib/puppet/vendor/rgen/test/json_test.rb +171 -0
- data/lib/puppet/vendor/rgen/test/metamodel_builder_test.rb +1482 -0
- data/lib/puppet/vendor/rgen/test/metamodel_from_ecore_test.rb +57 -0
- data/lib/puppet/vendor/rgen/test/metamodel_order_test.rb +131 -0
- data/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test.rb +98 -0
- data/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/TestModel.rb +70 -0
- data/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/houseMetamodel.ecore +42 -0
- data/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/houseMetamodel_from_ecore.rb +44 -0
- data/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/using_builtin_types.ecore +9 -0
- data/lib/puppet/vendor/rgen/test/method_delegation_test.rb +178 -0
- data/lib/puppet/vendor/rgen/test/model_builder/builder_context_test.rb +59 -0
- data/lib/puppet/vendor/rgen/test/model_builder/builder_test.rb +242 -0
- data/lib/puppet/vendor/rgen/test/model_builder/ecore_original.rb +163 -0
- data/lib/puppet/vendor/rgen/test/model_builder/ecore_original_regenerated.rb +163 -0
- data/lib/puppet/vendor/rgen/test/model_builder/reference_resolver_test.rb +156 -0
- data/lib/puppet/vendor/rgen/test/model_builder/serializer_test.rb +94 -0
- data/lib/puppet/vendor/rgen/test/model_builder/statemachine_metamodel.rb +42 -0
- data/lib/puppet/vendor/rgen/test/model_builder/test_model/statemachine1.rb +23 -0
- data/lib/puppet/vendor/rgen/test/model_builder_test.rb +6 -0
- data/lib/puppet/vendor/rgen/test/model_fragment_test.rb +30 -0
- data/lib/puppet/vendor/rgen/test/output_handler_test.rb +58 -0
- data/lib/puppet/vendor/rgen/test/qualified_name_provider_test.rb +48 -0
- data/lib/puppet/vendor/rgen/test/qualified_name_resolver_test.rb +102 -0
- data/lib/puppet/vendor/rgen/test/reference_resolver_test.rb +117 -0
- data/lib/puppet/vendor/rgen/test/rgen_test.rb +26 -0
- data/lib/puppet/vendor/rgen/test/template_language_test.rb +163 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/expected_result1.txt +29 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/expected_result2.txt +9 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/expected_result3.txt +4 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/indentStringTestDefaultIndent.out +1 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/indentStringTestTabIndent.out +1 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/callback_indent_test/a.tpl +12 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/callback_indent_test/b.tpl +5 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/code/array.tpl +11 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/content/author.tpl +7 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/content/chapter.tpl +5 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/define_local_test/local.tpl +8 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/define_local_test/test.tpl +8 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/evaluate_test/test.tpl +7 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/indent_string_test.tpl +12 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/index/c/cmod.tpl +1 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/index/chapter.tpl +3 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/no_backslash_r_test.tpl +5 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/no_indent.tpl +3 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/sub1/no_indent.tpl +3 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/test.tpl +24 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/test2.tpl +13 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/test3.tpl +10 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/null_context_test.tpl +17 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/root.tpl +31 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/template_resolution_test/sub1.tpl +9 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/template_resolution_test/sub1/sub1.tpl +3 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/templates/template_resolution_test/test.tpl +4 -0
- data/lib/puppet/vendor/rgen/test/template_language_test/testout.txt +29 -0
- data/lib/puppet/vendor/rgen/test/testmodel/class_model_checker.rb +119 -0
- data/lib/puppet/vendor/rgen/test/testmodel/ea_testmodel.eap +0 -0
- data/lib/puppet/vendor/rgen/test/testmodel/ea_testmodel.xml +1029 -0
- data/lib/puppet/vendor/rgen/test/testmodel/ea_testmodel_partial.xml +317 -0
- data/lib/puppet/vendor/rgen/test/testmodel/ecore_model_checker.rb +101 -0
- data/lib/puppet/vendor/rgen/test/testmodel/manual_testmodel.xml +22 -0
- data/lib/puppet/vendor/rgen/test/testmodel/object_model_checker.rb +67 -0
- data/lib/puppet/vendor/rgen/test/transformer_test.rb +254 -0
- data/lib/puppet/vendor/rgen/test/util/file_cache_map_test.rb +99 -0
- data/lib/puppet/vendor/rgen/test/util/pattern_matcher_test.rb +97 -0
- data/lib/puppet/vendor/rgen/test/util_test.rb +5 -0
- data/lib/puppet/vendor/rgen/test/xml_instantiator_test.rb +160 -0
- data/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_ecore_model_checker.rb +94 -0
- data/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_xmi_ecore_instantiator.rb +53 -0
- data/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_xmi_metamodel.rb +49 -0
- data/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_xmi_to_ecore.rb +75 -0
- data/lib/puppet/vendor/safe_yaml/PUPPET_README.md +6 -0
- data/lib/puppet/vendor/semantic/PUPPET_README.md +6 -0
- data/lib/puppet/version.rb +1 -1
- data/spec/fixtures/integration/node/environment/sitedir2/00_a.pp +2 -0
- data/spec/fixtures/integration/node/environment/sitedir2/02_folder/01_b.pp +6 -0
- data/spec/fixtures/integration/node/environment/sitedir2/03_c.pp +1 -0
- data/spec/fixtures/integration/node/environment/sitedir2/04_include.pp +2 -0
- data/spec/fixtures/releases/jamtur01-apache/manifests/vhost.pp +1 -1
- data/spec/fixtures/unit/indirector/hiera/global.yaml +10 -0
- data/spec/fixtures/unit/indirector/hiera/invalid.yaml +1 -0
- data/spec/fixtures/unit/parser/functions/create_resources/foo/manifests/init.pp +3 -0
- data/spec/fixtures/unit/parser/functions/create_resources/foo/manifests/wrongdefine.pp +3 -0
- data/spec/fixtures/unit/parser/lexer/argumentdefaults.pp +2 -2
- data/spec/fixtures/unit/parser/lexer/casestatement.pp +14 -14
- data/spec/fixtures/unit/parser/lexer/classheirarchy.pp +3 -3
- data/spec/fixtures/unit/parser/lexer/classincludes.pp +3 -3
- data/spec/fixtures/unit/parser/lexer/classpathtest.pp +1 -1
- data/spec/fixtures/unit/parser/lexer/collection_override.pp +1 -1
- data/spec/fixtures/unit/parser/lexer/componentrequire.pp +2 -2
- data/spec/fixtures/unit/parser/lexer/deepclassheirarchy.pp +5 -5
- data/spec/fixtures/unit/parser/lexer/defineoverrides.pp +2 -2
- data/spec/fixtures/unit/parser/lexer/filecreate.pp +2 -2
- data/spec/fixtures/unit/parser/lexer/ifexpression.pp +1 -1
- data/spec/fixtures/unit/parser/lexer/implicititeration.pp +4 -4
- data/spec/fixtures/unit/parser/lexer/multipleinstances.pp +3 -3
- data/spec/fixtures/unit/parser/lexer/multisubs.pp +2 -2
- data/spec/fixtures/unit/parser/lexer/namevartest.pp +2 -2
- data/spec/fixtures/unit/parser/lexer/simpledefaults.pp +1 -1
- data/spec/fixtures/unit/pops/parser/lexer/argumentdefaults.pp +1 -1
- data/spec/fixtures/unit/pops/parser/lexer/casestatement.pp +14 -14
- data/spec/fixtures/unit/pops/parser/lexer/classheirarchy.pp +3 -3
- data/spec/fixtures/unit/pops/parser/lexer/classincludes.pp +3 -3
- data/spec/fixtures/unit/pops/parser/lexer/classpathtest.pp +1 -1
- data/spec/fixtures/unit/pops/parser/lexer/collection_override.pp +1 -1
- data/spec/fixtures/unit/pops/parser/lexer/componentrequire.pp +2 -2
- data/spec/fixtures/unit/pops/parser/lexer/deepclassheirarchy.pp +5 -5
- data/spec/fixtures/unit/pops/parser/lexer/defineoverrides.pp +2 -2
- data/spec/fixtures/unit/pops/parser/lexer/filecreate.pp +2 -2
- data/spec/fixtures/unit/pops/parser/lexer/ifexpression.pp +1 -1
- data/spec/fixtures/unit/pops/parser/lexer/implicititeration.pp +4 -4
- data/spec/fixtures/unit/pops/parser/lexer/multipleinstances.pp +3 -3
- data/spec/fixtures/unit/pops/parser/lexer/multisubs.pp +2 -2
- data/spec/fixtures/unit/pops/parser/lexer/namevartest.pp +2 -2
- data/spec/fixtures/unit/pops/parser/lexer/simpledefaults.pp +1 -1
- data/spec/fixtures/unit/provider/package/gem/gem-list-single-package +4 -0
- data/spec/fixtures/unit/type/user/authorized_keys +1 -1
- data/spec/integration/agent/logging_spec.rb +4 -0
- data/spec/integration/application/doc_spec.rb +4 -3
- data/spec/integration/configurer_spec.rb +0 -14
- data/spec/integration/defaults_spec.rb +26 -0
- data/spec/integration/environments/default_manifest_spec.rb +274 -0
- data/spec/integration/faces/documentation_spec.rb +0 -4
- data/spec/integration/file_bucket/file_spec.rb +21 -0
- data/spec/integration/indirector/catalog/compiler_spec.rb +0 -2
- data/spec/integration/indirector/catalog/queue_spec.rb +0 -2
- data/spec/integration/indirector/facts/facter_spec.rb +1 -1
- data/spec/integration/indirector/file_content/file_server_spec.rb +2 -2
- data/spec/integration/node/environment_spec.rb +24 -8
- data/spec/integration/parser/catalog_spec.rb +10 -10
- data/spec/integration/parser/class_spec.rb +37 -0
- data/spec/integration/parser/collector_spec.rb +234 -75
- data/spec/integration/parser/compiler_spec.rb +385 -401
- data/spec/integration/parser/conditionals_spec.rb +117 -0
- data/spec/integration/parser/future_compiler_spec.rb +359 -8
- data/spec/integration/parser/node_spec.rb +185 -0
- data/spec/integration/parser/resource_expressions_spec.rb +286 -0
- data/spec/integration/parser/ruby_manifest_spec.rb +0 -4
- data/spec/integration/parser/scope_spec.rb +94 -151
- data/spec/integration/provider/cron/crontab_spec.rb +137 -148
- data/spec/integration/ssl/certificate_authority_spec.rb +26 -0
- data/spec/integration/ssl/certificate_request_spec.rb +0 -6
- data/spec/integration/ssl/certificate_revocation_list_spec.rb +0 -2
- data/spec/integration/ssl/host_spec.rb +0 -2
- data/spec/integration/transaction_spec.rb +16 -0
- data/spec/integration/type/file_spec.rb +14 -13
- data/spec/integration/type/nagios_spec.rb +6 -15
- data/spec/integration/type/sshkey_spec.rb +22 -0
- data/spec/integration/type/tidy_spec.rb +3 -0
- data/spec/integration/type/user_spec.rb +8 -3
- data/spec/integration/util/autoload_spec.rb +6 -6
- data/spec/integration/util/rdoc/parser_spec.rb +7 -0
- data/spec/integration/util/windows/process_spec.rb +12 -0
- data/spec/integration/util/windows/security_spec.rb +36 -35
- data/spec/integration/util/windows/user_spec.rb +75 -9
- data/spec/integration/util_spec.rb +2 -2
- data/spec/lib/matchers/resource.rb +1 -0
- data/spec/lib/puppet_spec/compiler.rb +15 -2
- data/spec/lib/puppet_spec/files.rb +10 -0
- data/spec/lib/puppet_spec/language.rb +74 -0
- data/spec/lib/puppet_spec/matchers.rb +59 -32
- data/spec/lib/puppet_spec/module_tool/stub_source.rb +3 -0
- data/spec/shared_behaviours/hiera_indirections.rb +99 -0
- data/spec/shared_behaviours/iterative_functions.rb +69 -0
- data/spec/unit/application/apply_spec.rb +4 -2
- data/spec/unit/application/doc_spec.rb +17 -13
- data/spec/unit/application/master_spec.rb +35 -27
- data/spec/unit/application/resource_spec.rb +0 -5
- data/spec/unit/configurer/downloader_factory_spec.rb +96 -0
- data/spec/unit/configurer/downloader_spec.rb +3 -24
- data/spec/unit/configurer/plugin_handler_spec.rb +22 -22
- data/spec/unit/configurer_spec.rb +0 -4
- data/spec/unit/defaults_spec.rb +30 -0
- data/spec/unit/face/config_spec.rb +2 -1
- data/spec/unit/face/module/build_spec.rb +2 -2
- data/spec/unit/face/module/install_spec.rb +8 -8
- data/spec/unit/face/parser_spec.rb +71 -33
- data/spec/unit/file_bucket/file_spec.rb +2 -2
- data/spec/unit/file_system/uniquefile_spec.rb +184 -0
- data/spec/unit/forge/errors_spec.rb +4 -6
- data/spec/unit/forge/module_release_spec.rb +178 -89
- data/spec/unit/forge/repository_spec.rb +110 -2
- data/spec/unit/forge_spec.rb +39 -3
- data/spec/unit/functions/assert_type_spec.rb +22 -3
- data/spec/unit/{parser/methods → functions}/each_spec.rb +21 -1
- data/spec/unit/{parser/functions → functions}/epp_spec.rb +61 -9
- data/spec/unit/{parser/methods → functions}/filter_spec.rb +34 -38
- data/spec/unit/{parser/functions → functions}/inline_epp_spec.rb +18 -3
- data/spec/unit/functions/map_spec.rb +169 -0
- data/spec/unit/functions/match_spec.rb +57 -0
- data/spec/unit/{parser/methods → functions}/reduce_spec.rb +23 -5
- data/spec/unit/{parser/methods → functions}/slice_spec.rb +34 -21
- data/spec/unit/functions/with_spec.rb +35 -0
- data/spec/unit/functions4_spec.rb +7 -8
- data/spec/unit/indirector/catalog/compiler_spec.rb +0 -2
- data/spec/unit/indirector/catalog/static_compiler_spec.rb +11 -0
- data/spec/unit/indirector/data_binding/hiera_spec.rb +1 -96
- data/spec/unit/indirector/facts/facter_spec.rb +69 -102
- data/spec/unit/indirector/hiera_spec.rb +17 -0
- data/spec/unit/indirector/request_spec.rb +2 -4
- data/spec/unit/indirector/resource/ral_spec.rb +5 -0
- data/spec/unit/indirector/resource_type/parser_spec.rb +17 -12
- data/spec/unit/indirector/rest_spec.rb +36 -6
- data/spec/unit/interface/face_collection_spec.rb +2 -2
- data/spec/unit/module_tool/applications/builder_spec.rb +364 -14
- data/spec/unit/module_tool/applications/uninstaller_spec.rb +22 -0
- data/spec/unit/module_tool/applications/unpacker_spec.rb +40 -0
- data/spec/unit/module_tool/applications/upgrader_spec.rb +22 -0
- data/spec/unit/module_tool/installed_modules_spec.rb +49 -0
- data/spec/unit/module_tool/metadata_spec.rb +72 -4
- data/spec/unit/module_tool/tar/mini_spec.rb +2 -1
- data/spec/unit/network/authentication_spec.rb +4 -0
- data/spec/unit/network/http/api/v2/environments_spec.rb +24 -3
- data/spec/unit/network/http/connection_spec.rb +127 -92
- data/spec/unit/network/http/factory_spec.rb +82 -0
- data/spec/unit/network/http/handler_spec.rb +23 -13
- data/spec/unit/network/http/nocache_pool_spec.rb +43 -0
- data/spec/unit/network/http/pool_spec.rb +269 -0
- data/spec/unit/network/http/rack/rest_spec.rb +1 -1
- data/spec/unit/network/http/session_spec.rb +43 -0
- data/spec/unit/network/http/site_spec.rb +90 -0
- data/spec/unit/network/http/webrick_spec.rb +1 -1
- data/spec/unit/network/http_pool_spec.rb +9 -6
- data/spec/unit/network/http_spec.rb +10 -0
- data/spec/unit/node/environment_spec.rb +54 -0
- data/spec/unit/node_spec.rb +3 -5
- data/spec/unit/parser/compiler_spec.rb +9 -2
- data/spec/unit/parser/files_spec.rb +19 -0
- data/spec/unit/parser/functions/contain_spec.rb +51 -0
- data/spec/unit/parser/functions/create_resources_spec.rb +8 -1
- data/spec/unit/parser/functions/digest_spec.rb +31 -0
- data/spec/unit/parser/functions/file_spec.rb +48 -5
- data/spec/unit/parser/functions/include_spec.rb +15 -1
- data/spec/unit/parser/functions/realize_spec.rb +43 -35
- data/spec/unit/parser/functions/require_spec.rb +19 -5
- data/spec/unit/parser/functions/search_spec.rb +5 -0
- data/spec/unit/parser/functions/shared.rb +82 -0
- data/spec/unit/parser/functions_spec.rb +1 -1
- data/spec/unit/parser/lexer_spec.rb +10 -1
- data/spec/unit/parser/type_loader_spec.rb +0 -1
- data/spec/unit/pops/benchmark_spec.rb +1 -1
- data/spec/unit/pops/binder/bindings_composer_spec.rb +24 -22
- data/spec/unit/pops/binder/injector_spec.rb +8 -6
- data/spec/unit/pops/evaluator/access_ops_spec.rb +3 -3
- data/spec/unit/pops/evaluator/comparison_ops_spec.rb +7 -4
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +250 -30
- data/spec/unit/pops/evaluator/logical_ops_spec.rb +2 -2
- data/spec/unit/pops/evaluator/variables_spec.rb +0 -105
- data/spec/unit/pops/issues_spec.rb +170 -0
- data/spec/unit/pops/loaders/dependency_loader_spec.rb +17 -0
- data/spec/unit/pops/loaders/loader_paths_spec.rb +4 -15
- data/spec/unit/pops/loaders/loaders_spec.rb +31 -11
- data/spec/unit/pops/loaders/module_loaders_spec.rb +0 -29
- data/spec/unit/pops/loaders/static_loader_spec.rb +6 -0
- data/spec/unit/pops/parser/epp_parser_spec.rb +38 -9
- data/spec/unit/pops/parser/evaluating_parser_spec.rb +0 -1
- data/spec/unit/pops/parser/lexer2_spec.rb +21 -4
- data/spec/unit/pops/parser/parse_basic_expressions_spec.rb +5 -0
- data/spec/unit/pops/parser/parse_calls_spec.rb +6 -3
- data/spec/unit/pops/parser/parse_conditionals_spec.rb +12 -5
- data/spec/unit/pops/parser/parse_containers_spec.rb +62 -7
- data/spec/unit/pops/parser/parse_resource_spec.rb +155 -73
- data/spec/unit/pops/parser/parser_spec.rb +16 -0
- data/spec/unit/pops/parser/parsing_typed_parameters_spec.rb +72 -0
- data/spec/unit/pops/transformer/transform_calls_spec.rb +1 -1
- data/spec/unit/pops/types/type_calculator_spec.rb +254 -57
- data/spec/unit/pops/types/type_factory_spec.rb +8 -3
- data/spec/unit/pops/types/type_parser_spec.rb +26 -5
- data/spec/unit/pops/validator/validator_spec.rb +143 -27
- data/spec/unit/provider/exec/posix_spec.rb +22 -14
- data/spec/unit/provider/exec/shell_spec.rb +2 -2
- data/spec/unit/provider/file/windows_spec.rb +7 -7
- data/spec/unit/provider/group/windows_adsi_spec.rb +17 -17
- data/spec/unit/provider/package/gem_spec.rb +10 -0
- data/spec/unit/provider/package/openbsd_spec.rb +66 -9
- data/spec/unit/provider/package/pacman_spec.rb +90 -71
- data/spec/unit/provider/package/windows/package_spec.rb +21 -6
- data/spec/unit/provider/package/yum_spec.rb +1 -0
- data/spec/unit/provider/parsedfile_spec.rb +1 -1
- data/spec/unit/provider/scheduled_task/win32_taskscheduler_spec.rb +9 -9
- data/spec/unit/provider/service/openbsd_spec.rb +26 -2
- data/spec/unit/provider/service/upstart_spec.rb +12 -1
- data/spec/unit/provider/ssh_authorized_key/parsed_spec.rb +6 -0
- data/spec/unit/provider/user/user_role_add_spec.rb +23 -1
- data/spec/unit/provider/user/windows_adsi_spec.rb +17 -17
- data/spec/unit/reports/store_spec.rb +0 -16
- data/spec/unit/resource/catalog_spec.rb +0 -5
- data/spec/unit/resource_spec.rb +2 -2
- data/spec/unit/settings/autosign_setting_spec.rb +2 -2
- data/spec/unit/settings/environment_conf_spec.rb +77 -10
- data/spec/unit/settings/file_setting_spec.rb +5 -4
- data/spec/unit/settings/priority_setting_spec.rb +4 -4
- data/spec/unit/settings_spec.rb +41 -3
- data/spec/unit/ssl/certificate_authority_spec.rb +25 -2
- data/spec/unit/ssl/inventory_spec.rb +13 -0
- data/spec/unit/ssl/validator_spec.rb +0 -1
- data/spec/unit/transaction/resource_harness_spec.rb +64 -0
- data/spec/unit/transaction_spec.rb +98 -47
- data/spec/unit/type/cron_spec.rb +3 -3
- data/spec/unit/type/exec_spec.rb +9 -0
- data/spec/unit/type/file/content_spec.rb +54 -71
- data/spec/unit/type/file/mode_spec.rb +26 -1
- data/spec/unit/type/file/source_spec.rb +26 -4
- data/spec/unit/type/file_spec.rb +3 -3
- data/spec/unit/type/nagios_spec.rb +12 -3
- data/spec/unit/type/resources_spec.rb +64 -30
- data/spec/unit/type/user_spec.rb +1 -1
- data/spec/unit/type/yumrepo_spec.rb +136 -0
- data/spec/unit/type/zone_spec.rb +44 -1
- data/spec/unit/type_spec.rb +20 -0
- data/spec/unit/util/colors_spec.rb +14 -8
- data/spec/unit/util/command_line_spec.rb +11 -7
- data/spec/unit/util/execution_spec.rb +35 -42
- data/spec/unit/util/feature_spec.rb +12 -0
- data/spec/unit/util/http_proxy_spec.rb +43 -1
- data/spec/unit/util/log/destinations_spec.rb +45 -1
- data/spec/unit/util/logging_spec.rb +38 -0
- data/spec/unit/util/pidlock_spec.rb +37 -1
- data/spec/unit/util/profiler/aggregate_spec.rb +59 -0
- data/spec/unit/util/profiler/around_profiler_spec.rb +61 -0
- data/spec/unit/util/profiler/logging_spec.rb +18 -29
- data/spec/unit/util/profiler/wall_clock_spec.rb +1 -1
- data/spec/unit/util/profiler_spec.rb +55 -0
- data/spec/unit/util/queue_spec.rb +0 -1
- data/spec/unit/util/rdoc/parser_spec.rb +14 -6
- data/spec/unit/util/tagging_spec.rb +1 -1
- data/spec/unit/util/windows/access_control_entry_spec.rb +1 -1
- data/spec/unit/util/{adsi_spec.rb → windows/adsi_spec.rb} +111 -108
- data/spec/unit/util/windows/api_types_spec.rb +28 -0
- data/spec/unit/util/windows/registry_spec.rb +7 -6
- data/spec/unit/util/windows/sid_spec.rb +3 -6
- data/spec/unit/util/windows/string_spec.rb +4 -0
- data/spec/unit/util/zaml_spec.rb +5 -1
- data/tasks/benchmark.rake +40 -5
- data/tasks/parser.rake +16 -2
- data/tasks/yard.rake +1 -1
- metadata +308 -150
- data/lib/puppet/file_system/tempfile.rb +0 -20
- data/lib/puppet/parser/e_parser_adapter.rb +0 -119
- data/lib/puppet/parser/functions/collect.rb +0 -15
- data/lib/puppet/parser/functions/select.rb +0 -15
- data/lib/puppet/pops/loader/ruby_legacy_function_instantiator.rb +0 -109
- data/lib/puppet/pops/parser/lexer.rb +0 -753
- data/lib/puppet/pops/parser/makefile +0 -6
- data/lib/puppet/pops/validation/checker3_1.rb +0 -558
- data/lib/puppet/pops/validation/validator_factory_3_1.rb +0 -31
- data/lib/puppet/util/profiler/none.rb +0 -8
- data/spec/unit/face/certificate_request_spec.rb +0 -7
- data/spec/unit/face/certificate_revocation_list_spec.rb +0 -7
- data/spec/unit/face/key_spec.rb +0 -7
- data/spec/unit/face/report_spec.rb +0 -7
- data/spec/unit/face/resource_spec.rb +0 -7
- data/spec/unit/face/resource_type_spec.rb +0 -7
- data/spec/unit/file_system/tempfile_spec.rb +0 -48
- data/spec/unit/parser/eparser_adapter_spec.rb +0 -407
- data/spec/unit/parser/methods/map_spec.rb +0 -184
- data/spec/unit/parser/methods/shared.rb +0 -45
- data/spec/unit/pops/parser/lexer_spec.rb +0 -840
- data/spec/unit/pops/transformer/transform_resource_spec.rb +0 -185
- data/spec/unit/util/profiler/none_spec.rb +0 -12
@@ -101,14 +101,16 @@ describe 'Injector' do
|
|
101
101
|
|
102
102
|
let(:bindings) { factory.named_bindings('test') }
|
103
103
|
let(:scope) { null_scope()}
|
104
|
-
let(:duck_type) { type_factory.ruby(InjectorSpecModule::TestDuck) }
|
105
|
-
|
106
104
|
let(:binder) { Puppet::Pops::Binder::Binder }
|
107
105
|
|
108
106
|
let(:lbinder) do
|
109
107
|
binder.new(layered_bindings)
|
110
108
|
end
|
111
109
|
|
110
|
+
def duck_type
|
111
|
+
# create distinct instances
|
112
|
+
type_factory.ruby(InjectorSpecModule::TestDuck)
|
113
|
+
end
|
112
114
|
|
113
115
|
let(:layered_bindings) { factory.layered_bindings(test_layer_with_bindings(bindings.model)) }
|
114
116
|
|
@@ -528,7 +530,7 @@ describe 'Injector' do
|
|
528
530
|
|
529
531
|
expect {
|
530
532
|
the_ducks = injector(lbinder).lookup(scope, hash_of_duck, "donalds_nephews")
|
531
|
-
}.to_not raise_error
|
533
|
+
}.to_not raise_error
|
532
534
|
end
|
533
535
|
|
534
536
|
it "should produce detailed type error message" do
|
@@ -592,11 +594,11 @@ describe 'Injector' do
|
|
592
594
|
it "should fail attempts to append, perform uniq or flatten on type incompatible multibind hash" do
|
593
595
|
hash_of_integer = type_factory.hash_of(type_factory.integer())
|
594
596
|
ids = ["ducks1", "ducks2", "ducks3"]
|
595
|
-
mb = bindings.multibind(ids[0]).type(hash_of_integer).name('broken_family0')
|
597
|
+
mb = bindings.multibind(ids[0]).type(hash_of_integer.copy).name('broken_family0')
|
596
598
|
mb.producer_options(:conflict_resolution => :append)
|
597
|
-
mb = bindings.multibind(ids[1]).type(hash_of_integer).name('broken_family1')
|
599
|
+
mb = bindings.multibind(ids[1]).type(hash_of_integer.copy).name('broken_family1')
|
598
600
|
mb.producer_options(:flatten => :true)
|
599
|
-
mb = bindings.multibind(ids[2]).type(hash_of_integer).name('broken_family2')
|
601
|
+
mb = bindings.multibind(ids[2]).type(hash_of_integer.copy).name('broken_family2')
|
600
602
|
mb.producer_options(:uniq => :true)
|
601
603
|
|
602
604
|
injector = injector(binder.new(factory.layered_bindings(test_layer_with_bindings(bindings.model))))
|
@@ -236,7 +236,7 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl/AccessOperator' do
|
|
236
236
|
|
237
237
|
it "Tuple parameterization gives an error if parameter is not a type" do
|
238
238
|
expr = fqr('Tuple')['String']
|
239
|
-
expect { evaluate(expr)}.to raise_error(/Tuple-Type, Cannot use String where
|
239
|
+
expect { evaluate(expr)}.to raise_error(/Tuple-Type, Cannot use String where Any-Type is expected/)
|
240
240
|
end
|
241
241
|
|
242
242
|
it 'produces a varargs Tuple when the last two arguments specify size constraint' do
|
@@ -415,12 +415,12 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl/AccessOperator' do
|
|
415
415
|
# Ruby Type
|
416
416
|
#
|
417
417
|
it 'creates a Ruby Type instance when applied to a Ruby Type' do
|
418
|
-
type_expr = fqr('
|
418
|
+
type_expr = fqr('Runtime')['ruby','String']
|
419
419
|
tf = Puppet::Pops::Types::TypeFactory
|
420
420
|
expect(evaluate(type_expr)).to eql(tf.ruby_type('String'))
|
421
421
|
|
422
422
|
# arguments are flattened
|
423
|
-
type_expr = fqr('
|
423
|
+
type_expr = fqr('Runtime')[['ruby', 'String']]
|
424
424
|
expect(evaluate(type_expr)).to eql(tf.ruby_type('String'))
|
425
425
|
end
|
426
426
|
|
@@ -88,10 +88,13 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
88
88
|
end
|
89
89
|
|
90
90
|
context "of booleans" do
|
91
|
-
it "true == true == true"
|
92
|
-
it "false == false == true"
|
93
|
-
it "true == false != true"
|
94
|
-
it "false == '' == false"
|
91
|
+
it "true == true == true" do; evaluate(literal(true) == literal(true)).should == true ; end;
|
92
|
+
it "false == false == true" do; evaluate(literal(false) == literal(false)).should == true ; end;
|
93
|
+
it "true == false != true" do; evaluate(literal(true) == literal(false)).should == false ; end;
|
94
|
+
it "false == '' == false" do; evaluate(literal(false) == literal('')).should == false ; end;
|
95
|
+
it "undef == '' == false" do; evaluate(literal(:undef) == literal('')).should == false ; end;
|
96
|
+
it "undef == undef == true" do; evaluate(literal(:undef) == literal(:undef)).should == true ; end;
|
97
|
+
it "nil == undef == true" do; evaluate(literal(nil) == literal(:undef)).should == true ; end;
|
95
98
|
end
|
96
99
|
|
97
100
|
context "of collections" do
|
@@ -2,6 +2,7 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
require 'puppet/pops'
|
4
4
|
require 'puppet/pops/evaluator/evaluator_impl'
|
5
|
+
require 'puppet/loaders'
|
5
6
|
require 'puppet_spec/pops'
|
6
7
|
require 'puppet_spec/scope'
|
7
8
|
require 'puppet/parser/e4_parser_adapter'
|
@@ -16,18 +17,29 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
16
17
|
before(:each) do
|
17
18
|
Puppet[:strict_variables] = true
|
18
19
|
|
19
|
-
# These must be set since the
|
20
|
-
#
|
20
|
+
# These must be set since the 3x logic switches some behaviors on these even if the tests explicitly
|
21
|
+
# use the 4x parser and evaluator.
|
21
22
|
#
|
22
23
|
Puppet[:parser] = 'future'
|
23
|
-
|
24
|
+
|
24
25
|
# Puppetx cannot be loaded until the correct parser has been set (injector is turned off otherwise)
|
25
26
|
require 'puppetx'
|
27
|
+
|
28
|
+
# Tests needs a known configuration of node/scope/compiler since it parses and evaluates
|
29
|
+
# snippets as the compiler will evaluate them, butwithout the overhead of compiling a complete
|
30
|
+
# catalog for each tested expression.
|
31
|
+
#
|
32
|
+
@parser = Puppet::Pops::Parser::EvaluatingParser.new
|
33
|
+
@node = Puppet::Node.new('node.example.com')
|
34
|
+
@node.environment = Puppet::Node::Environment.create(:testing, [])
|
35
|
+
@compiler = Puppet::Parser::Compiler.new(@node)
|
36
|
+
@scope = Puppet::Parser::Scope.new(@compiler)
|
37
|
+
@scope.source = Puppet::Resource::Type.new(:node, 'node.example.com')
|
38
|
+
@scope.parent = @compiler.topscope
|
26
39
|
end
|
27
40
|
|
28
|
-
let(:parser) {
|
29
|
-
let(:
|
30
|
-
let(:scope) { s = create_test_scope_for_node(node); s }
|
41
|
+
let(:parser) { @parser }
|
42
|
+
let(:scope) { @scope }
|
31
43
|
types = Puppet::Pops::Types::TypeFactory
|
32
44
|
|
33
45
|
context "When evaluator evaluates literals" do
|
@@ -206,7 +218,7 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
206
218
|
"'a' !~ 'b.*'" => true,
|
207
219
|
'$x = a; a =~ "$x.*"' => true,
|
208
220
|
"a =~ Pattern['a.*']" => true,
|
209
|
-
"a =~ Regexp['a.*']" =>
|
221
|
+
"a =~ Regexp['a.*']" => false, # String is not subtype of Regexp. PUP-957
|
210
222
|
"$x = /a.*/ a =~ $x" => true,
|
211
223
|
"$x = Pattern['a.*'] a =~ $x" => true,
|
212
224
|
"1 =~ Integer" => true,
|
@@ -240,6 +252,7 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
240
252
|
"/ana/ in bananas" => true,
|
241
253
|
"/xxx/ in bananas" => false,
|
242
254
|
"ANA in bananas" => false, # ANA is a type, not a String
|
255
|
+
"String[1] in bananas" => false, # Philosophically true though :-)
|
243
256
|
"'ANA' in bananas" => true,
|
244
257
|
"ana in 'BANANAS'" => true,
|
245
258
|
"/ana/ in 'BANANAS'" => false,
|
@@ -278,7 +291,20 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
278
291
|
end
|
279
292
|
|
280
293
|
{
|
281
|
-
|
294
|
+
"if /(ana)/ in bananas {$1}" => 'ana',
|
295
|
+
"if /(xyz)/ in bananas {$1} else {$1}" => nil,
|
296
|
+
"$a = bananas =~ /(ana)/; $b = /(xyz)/ in bananas; $1" => 'ana',
|
297
|
+
"$a = xyz =~ /(xyz)/; $b = /(ana)/ in bananas; $1" => 'ana',
|
298
|
+
"if /p/ in [pineapple, bananas] {$0}" => 'p',
|
299
|
+
"if /b/ in [pineapple, bananas] {$0}" => 'b',
|
300
|
+
}.each do |source, result|
|
301
|
+
it "sets match variables for a regexp search using in such that '#{source}' produces '#{result}'" do
|
302
|
+
parser.evaluate_string(scope, source, __FILE__).should == result
|
303
|
+
end
|
304
|
+
end
|
305
|
+
|
306
|
+
{
|
307
|
+
'Any' => ['Data', 'Scalar', 'Numeric', 'Integer', 'Float', 'Boolean', 'String', 'Pattern', 'Collection',
|
282
308
|
'Array', 'Hash', 'CatalogEntry', 'Resource', 'Class', 'Undef', 'File', 'NotYetKnownResourceType'],
|
283
309
|
|
284
310
|
# Note, Data > Collection is false (so not included)
|
@@ -364,11 +390,21 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
364
390
|
context "on strings requiring boxing to Numeric" do
|
365
391
|
{
|
366
392
|
"'2' + '2'" => 4,
|
393
|
+
"'-2' + '2'" => 0,
|
394
|
+
"'- 2' + '2'" => 0,
|
395
|
+
'"-\t 2" + "2"' => 0,
|
396
|
+
"'+2' + '2'" => 4,
|
397
|
+
"'+ 2' + '2'" => 4,
|
367
398
|
"'2.2' + '2.2'" => 4.4,
|
399
|
+
"'-2.2' + '2.2'" => 0.0,
|
368
400
|
"'0xF7' + '010'" => 0xFF,
|
369
401
|
"'0xF7' + '0x8'" => 0xFF,
|
370
402
|
"'0367' + '010'" => 0xFF,
|
371
403
|
"'012.3' + '010'" => 20.3,
|
404
|
+
"'-0x2' + '0x4'" => 2,
|
405
|
+
"'+0x2' + '0x4'" => 6,
|
406
|
+
"'-02' + '04'" => 2,
|
407
|
+
"'+02' + '04'" => 6,
|
372
408
|
}.each do |source, result|
|
373
409
|
it "should parse and evaluate the expression '#{source}' to #{result}" do
|
374
410
|
parser.evaluate_string(scope, source, __FILE__).should == result
|
@@ -380,6 +416,10 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
380
416
|
"'0xWTF' + '010'" => :error,
|
381
417
|
"'0x12.3' + '010'" => :error,
|
382
418
|
"'0x12.3' + '010'" => :error,
|
419
|
+
'"-\n 2" + "2"' => :error,
|
420
|
+
'"-\v 2" + "2"' => :error,
|
421
|
+
'"-2\n" + "2"' => :error,
|
422
|
+
'"-2\n " + "2"' => :error,
|
383
423
|
}.each do |source, result|
|
384
424
|
it "should parse and raise error for '#{source}'" do
|
385
425
|
expect { parser.evaluate_string(scope, source, __FILE__) }.to raise_error(Puppet::ParseError)
|
@@ -395,8 +435,6 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
395
435
|
"$a = 5; $a" => 5,
|
396
436
|
"$a = 5; $b = 6; $a" => 5,
|
397
437
|
"$a = $b = 5; $a == $b" => true,
|
398
|
-
"$a = [1,2,3]; [x].map |$x| { $a += x; $a }" => [[1,2,3,'x']],
|
399
|
-
"$a = [a,x,c]; [x].map |$x| { $a -= x; $a }" => [['a','c']],
|
400
438
|
}.each do |source, result|
|
401
439
|
it "should parse and evaluate the expression '#{source}' to #{result}" do
|
402
440
|
parser.evaluate_string(scope, source, __FILE__).should == result
|
@@ -404,13 +442,11 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
404
442
|
end
|
405
443
|
|
406
444
|
{
|
407
|
-
"[a,b,c] = [1,2,3]
|
408
|
-
"[a,b,c] = {b=>2,c=>3,a=>1}
|
409
|
-
"$a = [1,2,3]; [x].collect |$x| { [a] += x; $a }" => :error,
|
410
|
-
"$a = [a,x,c]; [x].collect |$x| { [a] -= x; $a }" => :error,
|
445
|
+
"[a,b,c] = [1,2,3]" => /attempt to assign to 'an Array Expression'/,
|
446
|
+
"[a,b,c] = {b=>2,c=>3,a=>1}" => /attempt to assign to 'an Array Expression'/,
|
411
447
|
}.each do |source, result|
|
412
|
-
it "should parse and evaluate the expression '#{source}' to #{result}" do
|
413
|
-
expect { parser.evaluate_string(scope, source, __FILE__)}.to raise_error(Puppet::ParseError)
|
448
|
+
it "should parse and evaluate the expression '#{source}' to error with #{result}" do
|
449
|
+
expect { parser.evaluate_string(scope, source, __FILE__)}.to raise_error(Puppet::ParseError, result)
|
414
450
|
end
|
415
451
|
end
|
416
452
|
end
|
@@ -458,6 +494,9 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
458
494
|
"case Integer {
|
459
495
|
Integer : { no }
|
460
496
|
Type[Integer] : { yes } }" => 'yes',
|
497
|
+
# supports unfold
|
498
|
+
"case ringo {
|
499
|
+
*[paul, john, ringo, george] : { 'beatle' } }" => 'beatle',
|
461
500
|
|
462
501
|
}.each do |source, result|
|
463
502
|
it "should parse and evaluate the expression '#{source}' to #{result}" do
|
@@ -467,16 +506,42 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
467
506
|
|
468
507
|
{
|
469
508
|
"2 ? { 1 => no, 2 => yes}" => 'yes',
|
470
|
-
"3 ? { 1 => no, 2 => no}" => nil,
|
471
509
|
"3 ? { 1 => no, 2 => no, default => yes }" => 'yes',
|
472
|
-
"3 ? { 1 => no, default => yes, 3 => no }" => '
|
510
|
+
"3 ? { 1 => no, default => yes, 3 => no }" => 'no',
|
511
|
+
"3 ? { 1 => no, 3 => no, default => yes }" => 'no',
|
512
|
+
"4 ? { 1 => no, default => yes, 3 => no }" => 'yes',
|
513
|
+
"4 ? { 1 => no, 3 => no, default => yes }" => 'yes',
|
473
514
|
"'banana' ? { /.*(ana).*/ => $1 }" => 'ana',
|
474
515
|
"[2] ? { Array[String] => yes, Array => yes}" => 'yes',
|
516
|
+
"ringo ? *[paul, john, ringo, george] => 'beatle'" => 'beatle',
|
475
517
|
}.each do |source, result|
|
476
518
|
it "should parse and evaluate the expression '#{source}' to #{result}" do
|
477
519
|
parser.evaluate_string(scope, source, __FILE__).should == result
|
478
520
|
end
|
479
521
|
end
|
522
|
+
|
523
|
+
it 'fails if a selector does not match' do
|
524
|
+
expect{parser.evaluate_string(scope, "2 ? 3 => 4")}.to raise_error(/No matching entry for selector parameter with value '2'/)
|
525
|
+
end
|
526
|
+
end
|
527
|
+
|
528
|
+
context "When evaluator evaluated unfold" do
|
529
|
+
{
|
530
|
+
"*[1,2,3]" => [1,2,3],
|
531
|
+
"*1" => [1],
|
532
|
+
"*'a'" => ['a']
|
533
|
+
}.each do |source, result|
|
534
|
+
it "should parse and evaluate the expression '#{source}' to #{result}" do
|
535
|
+
parser.evaluate_string(scope, source, __FILE__).should == result
|
536
|
+
end
|
537
|
+
end
|
538
|
+
|
539
|
+
it "should parse and evaluate the expression '*{a=>10, b=>20} to [['a',10],['b',20]]" do
|
540
|
+
result = parser.evaluate_string(scope, '*{a=>10, b=>20}', __FILE__)
|
541
|
+
expect(result).to include(['a', 10])
|
542
|
+
expect(result).to include(['b', 20])
|
543
|
+
end
|
544
|
+
|
480
545
|
end
|
481
546
|
|
482
547
|
context "When evaluator performs [] operations" do
|
@@ -501,6 +566,8 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
501
566
|
"[1,2,3,4][-5,-3]" => [1,2],
|
502
567
|
"[1,2,3,4][-6,-3]" => [1,2],
|
503
568
|
"[1,2,3,4][2,-3]" => [],
|
569
|
+
"[1,*[2,3],4]" => [1,2,3,4],
|
570
|
+
"[1,*[2,3],4][1]" => 2,
|
504
571
|
}.each do |source, result|
|
505
572
|
it "should parse and evaluate the expression '#{source}' to #{result}" do
|
506
573
|
parser.evaluate_string(scope, source, __FILE__).should == result
|
@@ -651,24 +718,82 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
651
718
|
adapted_parser = Puppet::Parser::E4ParserAdapter.new
|
652
719
|
adapted_parser.file = __FILE__
|
653
720
|
ast = adapted_parser.parse(source)
|
654
|
-
|
655
|
-
|
721
|
+
Puppet.override({:global_scope => scope}, "test") do
|
722
|
+
scope.known_resource_types.import_ast(ast, '')
|
723
|
+
ast.code.safeevaluate(scope).should == 'chocolate'
|
724
|
+
end
|
656
725
|
end
|
657
726
|
|
658
727
|
# Resource default and override expressions and resource parameter access with []
|
659
728
|
{
|
729
|
+
# Properties
|
660
730
|
"notify { id: message=>explicit} Notify[id][message]" => "explicit",
|
661
731
|
"Notify { message=>by_default} notify {foo:} Notify[foo][message]" => "by_default",
|
662
732
|
"notify {foo:} Notify[foo]{message =>by_override} Notify[foo][message]" => "by_override",
|
733
|
+
# Parameters
|
734
|
+
"notify { id: withpath=>explicit} Notify[id][withpath]" => "explicit",
|
735
|
+
"Notify { withpath=>by_default } notify { foo: } Notify[foo][withpath]" => "by_default",
|
736
|
+
"notify {foo:}
|
737
|
+
Notify[foo]{withpath=>by_override}
|
738
|
+
Notify[foo][withpath]" => "by_override",
|
739
|
+
# Metaparameters
|
663
740
|
"notify { foo: tag => evoe} Notify[foo][tag]" => "evoe",
|
664
|
-
# Does not produce the defaults for tag
|
741
|
+
# Does not produce the defaults for tag parameter (title, type or names of scopes)
|
665
742
|
"notify { foo: } Notify[foo][tag]" => nil,
|
743
|
+
# But a default may be specified on the type
|
744
|
+
"Notify { tag=>by_default } notify { foo: } Notify[foo][tag]" => "by_default",
|
745
|
+
"Notify { tag=>by_default }
|
746
|
+
notify { foo: }
|
747
|
+
Notify[foo]{ tag=>by_override }
|
748
|
+
Notify[foo][tag]" => "by_override",
|
666
749
|
}.each do |source, result|
|
667
750
|
it "should parse and evaluate the expression '#{source}' to #{result}" do
|
668
751
|
parser.evaluate_string(scope, source, __FILE__).should == result
|
669
752
|
end
|
670
753
|
end
|
671
754
|
|
755
|
+
# Virtual and realized resource default and overridden resource parameter access with []
|
756
|
+
{
|
757
|
+
# Properties
|
758
|
+
"@notify { id: message=>explicit } Notify[id][message]" => "explicit",
|
759
|
+
"@notify { id: message=>explicit }
|
760
|
+
realize Notify[id]
|
761
|
+
Notify[id][message]" => "explicit",
|
762
|
+
"Notify { message=>by_default } @notify { id: } Notify[id][message]" => "by_default",
|
763
|
+
"Notify { message=>by_default }
|
764
|
+
@notify { id: tag=>thisone }
|
765
|
+
Notify <| tag == thisone |>;
|
766
|
+
Notify[id][message]" => "by_default",
|
767
|
+
"@notify { id: } Notify[id]{message=>by_override} Notify[id][message]" => "by_override",
|
768
|
+
# Parameters
|
769
|
+
"@notify { id: withpath=>explicit } Notify[id][withpath]" => "explicit",
|
770
|
+
"Notify { withpath=>by_default }
|
771
|
+
@notify { id: }
|
772
|
+
Notify[id][withpath]" => "by_default",
|
773
|
+
"@notify { id: }
|
774
|
+
realize Notify[id]
|
775
|
+
Notify[id]{withpath=>by_override}
|
776
|
+
Notify[id][withpath]" => "by_override",
|
777
|
+
# Metaparameters
|
778
|
+
"@notify { id: tag=>explicit } Notify[id][tag]" => "explicit",
|
779
|
+
}.each do |source, result|
|
780
|
+
it "parses and evaluates virtual and realized resources in the expression '#{source}' to #{result}" do
|
781
|
+
expect(parser.evaluate_string(scope, source, __FILE__)).to eq(result)
|
782
|
+
end
|
783
|
+
end
|
784
|
+
|
785
|
+
# Exported resource attributes
|
786
|
+
{
|
787
|
+
"@@notify { id: message=>explicit } Notify[id][message]" => "explicit",
|
788
|
+
"@@notify { id: message=>explicit, tag=>thisone }
|
789
|
+
Notify <<| tag == thisone |>>
|
790
|
+
Notify[id][message]" => "explicit",
|
791
|
+
}.each do |source, result|
|
792
|
+
it "parses and evaluates exported resources in the expression '#{source}' to #{result}" do
|
793
|
+
expect(parser.evaluate_string(scope, source, __FILE__)).to eq(result)
|
794
|
+
end
|
795
|
+
end
|
796
|
+
|
672
797
|
# Resource default and override expressions and resource parameter access error conditions
|
673
798
|
{
|
674
799
|
"notify { xid: message=>explicit} Notify[id][message]" => /Resource not found/,
|
@@ -676,6 +801,7 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
676
801
|
# NOTE: these meta-esque parameters are not recognized as such
|
677
802
|
"notify { id: message=>explicit} Notify[id][title]" => /does not have a parameter called 'title'/,
|
678
803
|
"notify { id: message=>explicit} Notify[id]['type']" => /does not have a parameter called 'type'/,
|
804
|
+
"notify { id: message=>explicit } Notify[id]{message=>override}" => /'message' is already set on Notify\[id\]/
|
679
805
|
}.each do |source, result|
|
680
806
|
it "should parse '#{source}' and raise error matching #{result}" do
|
681
807
|
expect { parser.evaluate_string(scope, source, __FILE__)}.to raise_error(result)
|
@@ -713,7 +839,7 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
713
839
|
"!! true" => true,
|
714
840
|
"!! false" => false,
|
715
841
|
"! 'x'" => false,
|
716
|
-
"! ''" =>
|
842
|
+
"! ''" => false,
|
717
843
|
"! undef" => true,
|
718
844
|
"! [a]" => false,
|
719
845
|
"! []" => false,
|
@@ -744,12 +870,15 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
744
870
|
end
|
745
871
|
|
746
872
|
context "When evaluator performs calls" do
|
873
|
+
|
747
874
|
let(:populate) do
|
748
875
|
parser.evaluate_string(scope, "$a = 10 $b = [1,2,3]")
|
749
876
|
end
|
750
877
|
|
751
878
|
{
|
752
879
|
'sprintf( "x%iy", $a )' => "x10y",
|
880
|
+
# unfolds
|
881
|
+
'sprintf( *["x%iy", $a] )' => "x10y",
|
753
882
|
'"x%iy".sprintf( $a )' => "x10y",
|
754
883
|
'$b.reduce |$memo,$x| { $memo + $x }' => 6,
|
755
884
|
'reduce($b) |$memo,$x| { $memo + $x }' => 6,
|
@@ -771,6 +900,69 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
771
900
|
it "provides location information on error in unparenthesized call logic" do
|
772
901
|
expect{parser.evaluate_string(scope, "include non_existing_class", __FILE__)}.to raise_error(Puppet::ParseError, /line 1\:1/)
|
773
902
|
end
|
903
|
+
|
904
|
+
it 'defaults can be given in a lambda and used only when arg is missing' do
|
905
|
+
env_loader = @compiler.loaders.public_environment_loader
|
906
|
+
fc = Puppet::Functions.create_function(:test) do
|
907
|
+
dispatch :test do
|
908
|
+
param 'Integer', 'count'
|
909
|
+
required_block_param
|
910
|
+
end
|
911
|
+
def test(count, block)
|
912
|
+
block.call({}, *[].fill(10, 0, count))
|
913
|
+
end
|
914
|
+
end
|
915
|
+
the_func = fc.new({}, env_loader)
|
916
|
+
env_loader.add_entry(:function, 'test', the_func, __FILE__)
|
917
|
+
expect(parser.evaluate_string(scope, "test(1) |$x, $y=20| { $x + $y}")).to eql(30)
|
918
|
+
expect(parser.evaluate_string(scope, "test(2) |$x, $y=20| { $x + $y}")).to eql(20)
|
919
|
+
end
|
920
|
+
|
921
|
+
it 'a given undef does not select the default value' do
|
922
|
+
env_loader = @compiler.loaders.public_environment_loader
|
923
|
+
fc = Puppet::Functions.create_function(:test) do
|
924
|
+
dispatch :test do
|
925
|
+
param 'Any', 'lambda_arg'
|
926
|
+
required_block_param
|
927
|
+
end
|
928
|
+
def test(lambda_arg, block)
|
929
|
+
block.call({}, lambda_arg)
|
930
|
+
end
|
931
|
+
end
|
932
|
+
the_func = fc.new({}, env_loader)
|
933
|
+
env_loader.add_entry(:function, 'test', the_func, __FILE__)
|
934
|
+
|
935
|
+
expect(parser.evaluate_string(scope, "test(undef) |$x=20| { $x == undef}")).to eql(true)
|
936
|
+
end
|
937
|
+
|
938
|
+
it 'a given undef is given as nil' do
|
939
|
+
env_loader = @compiler.loaders.public_environment_loader
|
940
|
+
fc = Puppet::Functions.create_function(:assert_no_undef) do
|
941
|
+
dispatch :assert_no_undef do
|
942
|
+
param 'Any', 'x'
|
943
|
+
end
|
944
|
+
|
945
|
+
def assert_no_undef(x)
|
946
|
+
case x
|
947
|
+
when Array
|
948
|
+
return unless x.include?(:undef)
|
949
|
+
when Hash
|
950
|
+
return unless x.keys.include?(:undef) || x.values.include?(:undef)
|
951
|
+
else
|
952
|
+
return unless x == :undef
|
953
|
+
end
|
954
|
+
raise "contains :undef"
|
955
|
+
end
|
956
|
+
end
|
957
|
+
|
958
|
+
the_func = fc.new({}, env_loader)
|
959
|
+
env_loader.add_entry(:function, 'assert_no_undef', the_func, __FILE__)
|
960
|
+
|
961
|
+
expect{parser.evaluate_string(scope, "assert_no_undef(undef)")}.to_not raise_error()
|
962
|
+
expect{parser.evaluate_string(scope, "assert_no_undef([undef])")}.to_not raise_error()
|
963
|
+
expect{parser.evaluate_string(scope, "assert_no_undef({undef => 1})")}.to_not raise_error()
|
964
|
+
expect{parser.evaluate_string(scope, "assert_no_undef({1 => undef})")}.to_not raise_error()
|
965
|
+
end
|
774
966
|
end
|
775
967
|
|
776
968
|
context "When evaluator performs string interpolation" do
|
@@ -971,7 +1163,7 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
971
1163
|
expect { parser.evaluate_string(scope, src)}.to raise_error(/Cannot parse invalid JSON string/)
|
972
1164
|
end
|
973
1165
|
|
974
|
-
it "parses interpolated heredoc
|
1166
|
+
it "parses interpolated heredoc expression" do
|
975
1167
|
src = <<-CODE
|
976
1168
|
$name = 'Fjodor'
|
977
1169
|
@("END")
|
@@ -983,12 +1175,6 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
983
1175
|
|
984
1176
|
end
|
985
1177
|
context "Handles Deprecations and Discontinuations" do
|
986
|
-
around(:each) do |example|
|
987
|
-
Puppet.override({:loaders => Puppet::Pops::Loaders.new(Puppet::Node::Environment.create(:testing, []))}, 'test') do
|
988
|
-
example.run
|
989
|
-
end
|
990
|
-
end
|
991
|
-
|
992
1178
|
it 'of import statements' do
|
993
1179
|
source = "\nimport foo"
|
994
1180
|
# Error references position 5 at the opening '{'
|
@@ -1002,7 +1188,8 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
1002
1188
|
source = '1+1 { "title": }'
|
1003
1189
|
# Error references position 5 at the opening '{'
|
1004
1190
|
# Set file to nil to make it easier to match with line number (no file name in output)
|
1005
|
-
expect { parser.
|
1191
|
+
expect { parser.evaluate_string(scope, source) }.to raise_error(
|
1192
|
+
/Illegal Resource Type expression, expected result to be a type name, or untitled Resource.*line 1:2/)
|
1006
1193
|
end
|
1007
1194
|
|
1008
1195
|
it 'for non r-value producing <| |>' do
|
@@ -1058,6 +1245,39 @@ describe 'Puppet::Pops::Evaluator::EvaluatorImpl' do
|
|
1058
1245
|
|
1059
1246
|
end
|
1060
1247
|
|
1248
|
+
context 'does not leak variables' do
|
1249
|
+
it 'local variables are gone when lambda ends' do
|
1250
|
+
source = <<-SOURCE
|
1251
|
+
[1,2,3].each |$x| { $y = $x}
|
1252
|
+
$a = $y
|
1253
|
+
SOURCE
|
1254
|
+
expect do
|
1255
|
+
parser.evaluate_string(scope, source)
|
1256
|
+
end.to raise_error(/Unknown variable: 'y'/)
|
1257
|
+
end
|
1258
|
+
|
1259
|
+
it 'lambda parameters are gone when lambda ends' do
|
1260
|
+
source = <<-SOURCE
|
1261
|
+
[1,2,3].each |$x| { $y = $x}
|
1262
|
+
$a = $x
|
1263
|
+
SOURCE
|
1264
|
+
expect do
|
1265
|
+
parser.evaluate_string(scope, source)
|
1266
|
+
end.to raise_error(/Unknown variable: 'x'/)
|
1267
|
+
end
|
1268
|
+
|
1269
|
+
it 'does not leak match variables' do
|
1270
|
+
source = <<-SOURCE
|
1271
|
+
if 'xyz' =~ /(x)(y)(z)/ { notice $2 }
|
1272
|
+
case 'abc' {
|
1273
|
+
/(a)(b)(c)/ : { $x = $2 }
|
1274
|
+
}
|
1275
|
+
"-$x-$2-"
|
1276
|
+
SOURCE
|
1277
|
+
expect(parser.evaluate_string(scope, source)).to eq('-b--')
|
1278
|
+
end
|
1279
|
+
end
|
1280
|
+
|
1061
1281
|
matcher :have_relationship do |expected|
|
1062
1282
|
calc = Puppet::Pops::Types::TypeCalculator.new
|
1063
1283
|
|