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
@@ -3,31 +3,47 @@ require 'puppet/settings/environment_conf.rb'
|
|
3
3
|
|
4
4
|
describe Puppet::Settings::EnvironmentConf do
|
5
5
|
|
6
|
+
def setup_environment_conf(config, conf_hash)
|
7
|
+
conf_hash.each do |setting,value|
|
8
|
+
config.expects(:setting).with(setting).returns(
|
9
|
+
mock('setting', :value => value)
|
10
|
+
)
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
6
14
|
context "with config" do
|
7
|
-
let(:config) { stub(
|
15
|
+
let(:config) { stub('config') }
|
8
16
|
let(:envconf) { Puppet::Settings::EnvironmentConf.new("/some/direnv", config, ["/global/modulepath"]) }
|
9
17
|
|
10
18
|
it "reads a modulepath from config and does not include global_module_path" do
|
11
|
-
config
|
12
|
-
|
13
|
-
)
|
19
|
+
setup_environment_conf(config, :modulepath => '/some/modulepath')
|
20
|
+
|
14
21
|
expect(envconf.modulepath).to eq(File.expand_path('/some/modulepath'))
|
15
22
|
end
|
16
23
|
|
17
24
|
it "reads a manifest from config" do
|
18
|
-
config
|
19
|
-
|
20
|
-
)
|
25
|
+
setup_environment_conf(config, :manifest => '/some/manifest')
|
26
|
+
|
21
27
|
expect(envconf.manifest).to eq(File.expand_path('/some/manifest'))
|
22
28
|
end
|
23
29
|
|
24
30
|
it "reads a config_version from config" do
|
25
|
-
config
|
26
|
-
|
27
|
-
)
|
31
|
+
setup_environment_conf(config, :config_version => '/some/version.sh')
|
32
|
+
|
28
33
|
expect(envconf.config_version).to eq(File.expand_path('/some/version.sh'))
|
29
34
|
end
|
30
35
|
|
36
|
+
it "read an environment_timeout from config" do
|
37
|
+
setup_environment_conf(config, :environment_timeout => '3m')
|
38
|
+
|
39
|
+
expect(envconf.environment_timeout).to eq(180)
|
40
|
+
end
|
41
|
+
|
42
|
+
it "can retrieve raw settings" do
|
43
|
+
setup_environment_conf(config, :manifest => 'manifest.pp')
|
44
|
+
|
45
|
+
expect(envconf.raw_setting(:manifest)).to eq('manifest.pp')
|
46
|
+
end
|
31
47
|
end
|
32
48
|
|
33
49
|
context "without config" do
|
@@ -47,5 +63,56 @@ describe Puppet::Settings::EnvironmentConf do
|
|
47
63
|
it "returns nothing for config_version when config has none" do
|
48
64
|
expect(envconf.config_version).to be_nil
|
49
65
|
end
|
66
|
+
|
67
|
+
it "returns a defult of 0 for environment_timeout when config has none" do
|
68
|
+
expect(envconf.environment_timeout).to eq(0)
|
69
|
+
end
|
70
|
+
|
71
|
+
it "can still retrieve raw setting" do
|
72
|
+
expect(envconf.raw_setting(:manifest)).to be_nil
|
73
|
+
end
|
74
|
+
end
|
75
|
+
|
76
|
+
describe "with disable_per_environment_manifest" do
|
77
|
+
|
78
|
+
let(:config) { stub('config') }
|
79
|
+
let(:envconf) { Puppet::Settings::EnvironmentConf.new("/some/direnv", config, ["/global/modulepath"]) }
|
80
|
+
|
81
|
+
context "set true" do
|
82
|
+
|
83
|
+
before(:each) do
|
84
|
+
Puppet[:default_manifest] = File.expand_path('/default/manifest')
|
85
|
+
Puppet[:disable_per_environment_manifest] = true
|
86
|
+
end
|
87
|
+
|
88
|
+
it "ignores environment.conf manifest" do
|
89
|
+
setup_environment_conf(config, :manifest => '/some/manifest.pp')
|
90
|
+
|
91
|
+
expect(envconf.manifest).to eq(File.expand_path('/default/manifest'))
|
92
|
+
end
|
93
|
+
|
94
|
+
it "logs error when environment.conf has manifest set" do
|
95
|
+
setup_environment_conf(config, :manifest => '/some/manifest.pp')
|
96
|
+
|
97
|
+
envconf.manifest
|
98
|
+
expect(@logs.first.to_s).to match(/disable_per_environment_manifest.*true.*environment.conf.*does not match the default_manifest/)
|
99
|
+
end
|
100
|
+
|
101
|
+
it "does not log an error when environment.conf does not have a manifest set" do
|
102
|
+
setup_environment_conf(config, :manifest => nil)
|
103
|
+
|
104
|
+
expect(envconf.manifest).to eq(File.expand_path('/default/manifest'))
|
105
|
+
expect(@logs).to be_empty
|
106
|
+
end
|
107
|
+
end
|
108
|
+
|
109
|
+
it "uses environment.conf when false" do
|
110
|
+
setup_environment_conf(config, :manifest => '/some/manifest.pp')
|
111
|
+
|
112
|
+
Puppet[:default_manifest] = File.expand_path('/default/manifest')
|
113
|
+
Puppet[:disable_per_environment_manifest] = false
|
114
|
+
|
115
|
+
expect(envconf.manifest).to eq(File.expand_path('/some/manifest.pp'))
|
116
|
+
end
|
50
117
|
end
|
51
118
|
end
|
@@ -129,7 +129,7 @@ describe Puppet::Settings::FileSetting do
|
|
129
129
|
@settings = mock 'settings'
|
130
130
|
@file = Puppet::Settings::FileSetting.new(:settings => @settings, :desc => "eh", :name => :myfile, :section => "mysect")
|
131
131
|
@file.stubs(:create_files?).returns true
|
132
|
-
@settings.stubs(:value).with(:myfile).returns @basepath
|
132
|
+
@settings.stubs(:value).with(:myfile, nil, false).returns @basepath
|
133
133
|
end
|
134
134
|
|
135
135
|
it "should return :file as its type" do
|
@@ -146,19 +146,20 @@ describe Puppet::Settings::FileSetting do
|
|
146
146
|
it "should manage existent files even if 'create_files' is not enabled" do
|
147
147
|
@file.expects(:create_files?).returns false
|
148
148
|
@file.expects(:type).returns :file
|
149
|
+
Puppet::FileSystem.stubs(:exist?)
|
149
150
|
Puppet::FileSystem.expects(:exist?).with(@basepath).returns true
|
150
151
|
@file.to_resource.should be_instance_of(Puppet::Resource)
|
151
152
|
end
|
152
153
|
|
153
154
|
describe "on POSIX systems", :if => Puppet.features.posix? do
|
154
155
|
it "should skip files in /dev" do
|
155
|
-
@settings.stubs(:value).with(:myfile).returns "/dev/file"
|
156
|
+
@settings.stubs(:value).with(:myfile, nil, false).returns "/dev/file"
|
156
157
|
@file.to_resource.should be_nil
|
157
158
|
end
|
158
159
|
end
|
159
160
|
|
160
161
|
it "should skip files whose paths are not strings" do
|
161
|
-
@settings.stubs(:value).with(:myfile).returns :foo
|
162
|
+
@settings.stubs(:value).with(:myfile, nil, false).returns :foo
|
162
163
|
@file.to_resource.should be_nil
|
163
164
|
end
|
164
165
|
|
@@ -169,7 +170,7 @@ describe Puppet::Settings::FileSetting do
|
|
169
170
|
end
|
170
171
|
|
171
172
|
it "should fully qualified returned files if necessary (#795)" do
|
172
|
-
@settings.stubs(:value).with(:myfile).returns "myfile"
|
173
|
+
@settings.stubs(:value).with(:myfile, nil, false).returns "myfile"
|
173
174
|
path = File.expand_path('myfile')
|
174
175
|
@file.to_resource.title.should == path
|
175
176
|
end
|
@@ -53,10 +53,10 @@ describe Puppet::Settings::PrioritySetting do
|
|
53
53
|
describe "on a Windows-like platform it", :if => Puppet::Util::Platform.windows? do
|
54
54
|
it "parses high, normal, low, and idle priorities" do
|
55
55
|
{
|
56
|
-
'high' => Process::HIGH_PRIORITY_CLASS,
|
57
|
-
'normal' => Process::NORMAL_PRIORITY_CLASS,
|
58
|
-
'low' => Process::BELOW_NORMAL_PRIORITY_CLASS,
|
59
|
-
'idle' => Process::IDLE_PRIORITY_CLASS
|
56
|
+
'high' => Puppet::Util::Windows::Process::HIGH_PRIORITY_CLASS,
|
57
|
+
'normal' => Puppet::Util::Windows::Process::NORMAL_PRIORITY_CLASS,
|
58
|
+
'low' => Puppet::Util::Windows::Process::BELOW_NORMAL_PRIORITY_CLASS,
|
59
|
+
'idle' => Puppet::Util::Windows::Process::IDLE_PRIORITY_CLASS
|
60
60
|
}.each do |value, converted_value|
|
61
61
|
setting.munge(value).should == converted_value
|
62
62
|
end
|
data/spec/unit/settings_spec.rb
CHANGED
@@ -1359,6 +1359,44 @@ describe Puppet::Settings do
|
|
1359
1359
|
end
|
1360
1360
|
end
|
1361
1361
|
|
1362
|
+
describe "adding default directory environment to the catalog" do
|
1363
|
+
let(:tmpenv) { tmpdir("envs") }
|
1364
|
+
let(:default_path) { "#{tmpenv}/environments" }
|
1365
|
+
before(:each) do
|
1366
|
+
@settings.define_settings :main,
|
1367
|
+
:environment => { :default => "production", :desc => "env"},
|
1368
|
+
:environmentpath => { :type => :path, :default => default_path, :desc => "envpath"}
|
1369
|
+
end
|
1370
|
+
|
1371
|
+
it "adds if environmentpath exists" do
|
1372
|
+
envpath = "#{tmpenv}/custom_envpath"
|
1373
|
+
@settings[:environmentpath] = envpath
|
1374
|
+
Dir.mkdir(envpath)
|
1375
|
+
catalog = @settings.to_catalog
|
1376
|
+
expect(catalog.resource_keys).to include(["File", "#{envpath}/production"])
|
1377
|
+
end
|
1378
|
+
|
1379
|
+
it "adds the first directory of environmentpath" do
|
1380
|
+
envdir = "#{tmpenv}/custom_envpath"
|
1381
|
+
envpath = "#{envdir}#{File::PATH_SEPARATOR}/some/other/envdir"
|
1382
|
+
@settings[:environmentpath] = envpath
|
1383
|
+
Dir.mkdir(envdir)
|
1384
|
+
catalog = @settings.to_catalog
|
1385
|
+
expect(catalog.resource_keys).to include(["File", "#{envdir}/production"])
|
1386
|
+
end
|
1387
|
+
|
1388
|
+
it "handles a non-existent environmentpath" do
|
1389
|
+
catalog = @settings.to_catalog
|
1390
|
+
expect(catalog.resource_keys).to be_empty
|
1391
|
+
end
|
1392
|
+
|
1393
|
+
it "handles a default environmentpath" do
|
1394
|
+
Dir.mkdir(default_path)
|
1395
|
+
catalog = @settings.to_catalog
|
1396
|
+
expect(catalog.resource_keys).to include(["File", "#{default_path}/production"])
|
1397
|
+
end
|
1398
|
+
end
|
1399
|
+
|
1362
1400
|
describe "when adding users and groups to the catalog" do
|
1363
1401
|
before do
|
1364
1402
|
Puppet.features.stubs(:root?).returns true
|
@@ -1468,14 +1506,14 @@ describe Puppet::Settings do
|
|
1468
1506
|
:maindir => { :type => :directory, :default => make_absolute("/maindir"), :desc => "a" },
|
1469
1507
|
:seconddir => { :type => :directory, :default => make_absolute("/seconddir"), :desc => "a"}
|
1470
1508
|
@settings.define_settings :main, :user => { :default => "suser", :desc => "doc" }, :group => { :default => "sgroup", :desc => "doc" }
|
1471
|
-
@settings.define_settings :other, :otherdir => {:type => :directory, :default => make_absolute("/otherdir"), :desc => "a", :owner => "service", :group => "service", :mode => 0755}
|
1509
|
+
@settings.define_settings :other, :otherdir => {:type => :directory, :default => make_absolute("/otherdir"), :desc => "a", :owner => "service", :group => "service", :mode => '0755'}
|
1472
1510
|
@settings.define_settings :third, :thirddir => { :type => :directory, :default => make_absolute("/thirddir"), :desc => "b"}
|
1473
|
-
@settings.define_settings :files, :myfile => {:type => :file, :default => make_absolute("/myfile"), :desc => "a", :mode => 0755}
|
1511
|
+
@settings.define_settings :files, :myfile => {:type => :file, :default => make_absolute("/myfile"), :desc => "a", :mode => '0755'}
|
1474
1512
|
end
|
1475
1513
|
|
1476
1514
|
it "should provide a method that creates directories with the correct modes" do
|
1477
1515
|
Puppet::Util::SUIDManager.expects(:asuser).with("suser", "sgroup").yields
|
1478
|
-
Dir.expects(:mkdir).with(make_absolute("/otherdir"), 0755)
|
1516
|
+
Dir.expects(:mkdir).with(make_absolute("/otherdir"), '0755')
|
1479
1517
|
@settings.mkdir(:otherdir)
|
1480
1518
|
end
|
1481
1519
|
|
@@ -7,7 +7,6 @@ require 'puppet/ssl/certificate_authority'
|
|
7
7
|
describe Puppet::SSL::CertificateAuthority do
|
8
8
|
after do
|
9
9
|
Puppet::SSL::CertificateAuthority.instance_variable_set(:@singleton_instance, nil)
|
10
|
-
Puppet.settings.clearused
|
11
10
|
end
|
12
11
|
|
13
12
|
def stub_ca_host
|
@@ -937,12 +936,36 @@ describe Puppet::SSL::CertificateAuthority do
|
|
937
936
|
cert = stub 'cert', :content => real_cert
|
938
937
|
Puppet::SSL::Certificate.indirection.expects(:find).with("host").returns nil
|
939
938
|
|
940
|
-
@ca.inventory.expects(:
|
939
|
+
@ca.inventory.expects(:serials).with("host").returns [16]
|
941
940
|
|
942
941
|
@ca.crl.expects(:revoke).with { |serial, key| serial == 16 }
|
943
942
|
@ca.revoke('host')
|
944
943
|
end
|
945
944
|
|
945
|
+
it "should revoke all serials matching a name" do
|
946
|
+
real_cert = stub 'real_cert', :serial => 15
|
947
|
+
cert = stub 'cert', :content => real_cert
|
948
|
+
Puppet::SSL::Certificate.indirection.expects(:find).with("host").returns nil
|
949
|
+
|
950
|
+
@ca.inventory.expects(:serials).with("host").returns [16, 20, 25]
|
951
|
+
|
952
|
+
@ca.crl.expects(:revoke).with { |serial, key| serial == 16 }
|
953
|
+
@ca.crl.expects(:revoke).with { |serial, key| serial == 20 }
|
954
|
+
@ca.crl.expects(:revoke).with { |serial, key| serial == 25 }
|
955
|
+
@ca.revoke('host')
|
956
|
+
end
|
957
|
+
|
958
|
+
it "should raise an error if no certificate match" do
|
959
|
+
real_cert = stub 'real_cert', :serial => 15
|
960
|
+
cert = stub 'cert', :content => real_cert
|
961
|
+
Puppet::SSL::Certificate.indirection.expects(:find).with("host").returns nil
|
962
|
+
|
963
|
+
@ca.inventory.expects(:serials).with("host").returns []
|
964
|
+
|
965
|
+
@ca.crl.expects(:revoke).never
|
966
|
+
expect { @ca.revoke('host') }.to raise_error
|
967
|
+
end
|
968
|
+
|
946
969
|
context "revocation by serial number (#16798)" do
|
947
970
|
it "revokes when given a lower case hexadecimal formatted string" do
|
948
971
|
@ca.crl.expects(:revoke).with { |serial, key| serial == 15 }
|
@@ -133,5 +133,18 @@ describe Puppet::SSL::Inventory, :unless => Puppet.features.microsoft_windows? d
|
|
133
133
|
@inventory.serial("me").should == 15
|
134
134
|
end
|
135
135
|
end
|
136
|
+
|
137
|
+
describe "and finding all serial numbers" do
|
138
|
+
it "should return nil if the inventory file is missing" do
|
139
|
+
Puppet::FileSystem.expects(:exist?).with(cert_inventory).returns false
|
140
|
+
@inventory.serials(:whatever).should be_empty
|
141
|
+
end
|
142
|
+
|
143
|
+
it "should return the all the serial numbers from the lines matching the provided name" do
|
144
|
+
File.expects(:readlines).with(cert_inventory).returns ["0x00f blah blah /CN=me\n", "0x001 blah blah /CN=you\n", "0x002 blah blah /CN=me\n"]
|
145
|
+
|
146
|
+
@inventory.serials("me").should == [15, 2]
|
147
|
+
end
|
148
|
+
end
|
136
149
|
end
|
137
150
|
end
|
@@ -352,6 +352,70 @@ describe Puppet::Transaction::ResourceHarness do
|
|
352
352
|
event.status.should != 'failure'
|
353
353
|
end
|
354
354
|
end
|
355
|
+
|
356
|
+
it "should not ignore microseconds when auditing a file's mtime" do
|
357
|
+
test_file = tmpfile('foo')
|
358
|
+
File.open(test_file, 'w').close
|
359
|
+
resource = Puppet::Type.type(:file).new :path => test_file, :audit => ['mtime'], :backup => false
|
360
|
+
|
361
|
+
# construct a property hash with nanosecond resolution as would be
|
362
|
+
# found on an ext4 file system
|
363
|
+
time_with_nsec_resolution = Time.at(1000, 123456.999)
|
364
|
+
current_from_filesystem = {:mtime => time_with_nsec_resolution}
|
365
|
+
|
366
|
+
# construct a property hash with a 1 microsecond difference from above
|
367
|
+
time_with_usec_resolution = Time.at(1000, 123457.000)
|
368
|
+
historical_from_state_yaml = {:mtime => time_with_usec_resolution}
|
369
|
+
|
370
|
+
# set up the sequence of stubs; yeah, this is pretty
|
371
|
+
# brittle, so this might need to be adjusted if the
|
372
|
+
# resource_harness logic changes
|
373
|
+
resource.expects(:retrieve).returns(current_from_filesystem)
|
374
|
+
Puppet::Util::Storage.stubs(:cache).with(resource).
|
375
|
+
returns(historical_from_state_yaml).then.
|
376
|
+
returns(current_from_filesystem).then.
|
377
|
+
returns(current_from_filesystem)
|
378
|
+
|
379
|
+
# there should be an audit change recorded, since the two
|
380
|
+
# timestamps differ by at least 1 microsecond
|
381
|
+
status = @harness.evaluate(resource)
|
382
|
+
status.events.should_not be_empty
|
383
|
+
status.events.each do |event|
|
384
|
+
event.message.should =~ /audit change: previously recorded/
|
385
|
+
end
|
386
|
+
end
|
387
|
+
|
388
|
+
it "should ignore nanoseconds when auditing a file's mtime" do
|
389
|
+
test_file = tmpfile('foo')
|
390
|
+
File.open(test_file, 'w').close
|
391
|
+
resource = Puppet::Type.type(:file).new :path => test_file, :audit => ['mtime'], :backup => false
|
392
|
+
|
393
|
+
# construct a property hash with nanosecond resolution as would be
|
394
|
+
# found on an ext4 file system
|
395
|
+
time_with_nsec_resolution = Time.at(1000, 123456.789)
|
396
|
+
current_from_filesystem = {:mtime => time_with_nsec_resolution}
|
397
|
+
|
398
|
+
# construct a property hash with the same timestamp as above,
|
399
|
+
# truncated to microseconds, as would be read back from state.yaml
|
400
|
+
time_with_usec_resolution = Time.at(1000, 123456.000)
|
401
|
+
historical_from_state_yaml = {:mtime => time_with_usec_resolution}
|
402
|
+
|
403
|
+
# set up the sequence of stubs; yeah, this is pretty
|
404
|
+
# brittle, so this might need to be adjusted if the
|
405
|
+
# resource_harness logic changes
|
406
|
+
resource.expects(:retrieve).returns(current_from_filesystem)
|
407
|
+
Puppet::Util::Storage.stubs(:cache).with(resource).
|
408
|
+
returns(historical_from_state_yaml).then.
|
409
|
+
returns(current_from_filesystem).then.
|
410
|
+
returns(current_from_filesystem)
|
411
|
+
|
412
|
+
# there should be no audit change recorded, despite the
|
413
|
+
# slight difference in the two timestamps
|
414
|
+
status = @harness.evaluate(resource)
|
415
|
+
status.events.each do |event|
|
416
|
+
event.message.should_not =~ /audit change: previously recorded/
|
417
|
+
end
|
418
|
+
end
|
355
419
|
end
|
356
420
|
|
357
421
|
describe "when applying changes" do
|
@@ -37,7 +37,8 @@ describe Puppet::Transaction do
|
|
37
37
|
# This will basically only ever be used during testing.
|
38
38
|
it "should automatically create resource statuses if asked for a non-existent status" do
|
39
39
|
resource = Puppet::Type.type(:notify).new :title => "foobar"
|
40
|
-
|
40
|
+
transaction = transaction_with_resource(resource)
|
41
|
+
transaction.resource_status(resource).should be_instance_of(Puppet::Resource::Status)
|
41
42
|
end
|
42
43
|
|
43
44
|
it "should add provided resource statuses to its report" do
|
@@ -72,15 +73,15 @@ describe Puppet::Transaction do
|
|
72
73
|
|
73
74
|
describe "when initializing" do
|
74
75
|
it "should create an event manager" do
|
75
|
-
|
76
|
-
|
77
|
-
|
76
|
+
transaction = Puppet::Transaction.new(Puppet::Resource::Catalog.new, nil, nil)
|
77
|
+
transaction.event_manager.should be_instance_of(Puppet::Transaction::EventManager)
|
78
|
+
transaction.event_manager.transaction.should equal(transaction)
|
78
79
|
end
|
79
80
|
|
80
81
|
it "should create a resource harness" do
|
81
|
-
|
82
|
-
|
83
|
-
|
82
|
+
transaction = Puppet::Transaction.new(Puppet::Resource::Catalog.new, nil, nil)
|
83
|
+
transaction.resource_harness.should be_instance_of(Puppet::Transaction::ResourceHarness)
|
84
|
+
transaction.resource_harness.transaction.should equal(transaction)
|
84
85
|
end
|
85
86
|
|
86
87
|
it "should set retrieval time on the report" do
|
@@ -95,29 +96,25 @@ describe Puppet::Transaction do
|
|
95
96
|
end
|
96
97
|
|
97
98
|
describe "when evaluating a resource" do
|
98
|
-
|
99
|
-
@catalog = Puppet::Resource::Catalog.new
|
100
|
-
@resource = Puppet::Type.type(:file).new :path => @basepath
|
101
|
-
@catalog.add_resource(@resource)
|
102
|
-
|
103
|
-
@transaction = Puppet::Transaction.new(@catalog, nil, Puppet::Graph::RandomPrioritizer.new)
|
104
|
-
@transaction.stubs(:skip?).returns false
|
105
|
-
end
|
99
|
+
let(:resource) { Puppet::Type.type(:file).new :path => @basepath }
|
106
100
|
|
107
101
|
it "should process events" do
|
108
|
-
|
102
|
+
transaction = transaction_with_resource(resource)
|
109
103
|
|
110
|
-
|
104
|
+
transaction.expects(:skip?).with(resource).returns false
|
105
|
+
transaction.event_manager.expects(:process_events).with(resource)
|
106
|
+
|
107
|
+
transaction.evaluate
|
111
108
|
end
|
112
109
|
|
113
110
|
describe "and the resource should be skipped" do
|
114
|
-
before do
|
115
|
-
@transaction.expects(:skip?).with(@resource).returns true
|
116
|
-
end
|
117
|
-
|
118
111
|
it "should mark the resource's status as skipped" do
|
119
|
-
|
120
|
-
|
112
|
+
transaction = transaction_with_resource(resource)
|
113
|
+
|
114
|
+
transaction.expects(:skip?).with(resource).returns true
|
115
|
+
|
116
|
+
transaction.evaluate
|
117
|
+
transaction.resource_status(resource).should be_skipped
|
121
118
|
end
|
122
119
|
end
|
123
120
|
end
|
@@ -288,6 +285,9 @@ describe Puppet::Transaction do
|
|
288
285
|
before :each do
|
289
286
|
catalog.add_resource generator
|
290
287
|
generator.stubs(:generate).returns generated
|
288
|
+
# avoid crude failures because of nil resources that result
|
289
|
+
# from implicit containment and lacking containers
|
290
|
+
catalog.stubs(:container_of).returns generator
|
291
291
|
end
|
292
292
|
|
293
293
|
it "should call 'generate' on all created resources" do
|
@@ -313,6 +313,31 @@ describe Puppet::Transaction do
|
|
313
313
|
end
|
314
314
|
end
|
315
315
|
|
316
|
+
describe "when performing pre-run checks" do
|
317
|
+
let(:resource) { Puppet::Type.type(:notify).new(:title => "spec") }
|
318
|
+
let(:transaction) { transaction_with_resource(resource) }
|
319
|
+
let(:spec_exception) { 'spec-exception' }
|
320
|
+
|
321
|
+
it "should invoke each resource's hook and apply the catalog after no failures" do
|
322
|
+
resource.expects(:pre_run_check)
|
323
|
+
|
324
|
+
transaction.evaluate
|
325
|
+
end
|
326
|
+
|
327
|
+
it "should abort the transaction on failure" do
|
328
|
+
resource.expects(:pre_run_check).raises(Puppet::Error, spec_exception)
|
329
|
+
|
330
|
+
expect { transaction.evaluate }.to raise_error(Puppet::Error, /Some pre-run checks failed/)
|
331
|
+
end
|
332
|
+
|
333
|
+
it "should log the resource-specific exception" do
|
334
|
+
resource.expects(:pre_run_check).raises(Puppet::Error, spec_exception)
|
335
|
+
resource.expects(:log_exception).with(responds_with(:message, spec_exception))
|
336
|
+
|
337
|
+
expect { transaction.evaluate }.to raise_error(Puppet::Error)
|
338
|
+
end
|
339
|
+
end
|
340
|
+
|
316
341
|
describe "when skipping a resource" do
|
317
342
|
before :each do
|
318
343
|
@resource = Puppet::Type.type(:notify).new :name => "foo"
|
@@ -478,44 +503,70 @@ describe Puppet::Transaction do
|
|
478
503
|
end
|
479
504
|
|
480
505
|
describe "during teardown" do
|
506
|
+
let(:catalog) { Puppet::Resource::Catalog.new }
|
507
|
+
let(:transaction) do
|
508
|
+
Puppet::Transaction.new(catalog, nil, Puppet::Graph::RandomPrioritizer.new)
|
509
|
+
end
|
510
|
+
|
511
|
+
let(:teardown_type) do
|
512
|
+
Puppet::Type.newtype(:teardown_test) do
|
513
|
+
newparam(:name) {}
|
514
|
+
end
|
515
|
+
end
|
516
|
+
|
481
517
|
before :each do
|
482
|
-
|
483
|
-
|
518
|
+
teardown_type.provide(:teardown_provider) do
|
519
|
+
class << self
|
520
|
+
attr_reader :result
|
521
|
+
|
522
|
+
def post_resource_eval
|
523
|
+
@result = 'passed'
|
524
|
+
end
|
525
|
+
end
|
526
|
+
end
|
484
527
|
end
|
485
528
|
|
486
529
|
it "should call ::post_resource_eval on provider classes that support it" do
|
487
|
-
|
488
|
-
@catalog.add_resource @resource
|
530
|
+
resource = teardown_type.new(:title => "foo", :provider => :teardown_provider)
|
489
531
|
|
490
|
-
|
491
|
-
|
492
|
-
|
532
|
+
transaction = transaction_with_resource(resource)
|
533
|
+
transaction.evaluate
|
534
|
+
|
535
|
+
expect(resource.provider.class.result).to eq('passed')
|
493
536
|
end
|
494
537
|
|
495
538
|
it "should call ::post_resource_eval even if other providers' ::post_resource_eval fails" do
|
496
|
-
|
497
|
-
|
498
|
-
|
499
|
-
|
500
|
-
|
501
|
-
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
506
|
-
@resource4.provider.class.expects(:post_resource_eval)
|
539
|
+
teardown_type.provide(:always_fails) do
|
540
|
+
class << self
|
541
|
+
attr_reader :result
|
542
|
+
|
543
|
+
def post_resource_eval
|
544
|
+
@result = 'failed'
|
545
|
+
raise Puppet::Error, "This provider always fails"
|
546
|
+
end
|
547
|
+
end
|
548
|
+
end
|
507
549
|
|
508
|
-
|
550
|
+
good_resource = teardown_type.new(:title => "bloo", :provider => :teardown_provider)
|
551
|
+
bad_resource = teardown_type.new(:title => "blob", :provider => :always_fails)
|
552
|
+
|
553
|
+
catalog.add_resource(bad_resource)
|
554
|
+
catalog.add_resource(good_resource)
|
555
|
+
|
556
|
+
transaction.evaluate
|
557
|
+
|
558
|
+
expect(good_resource.provider.class.result).to eq('passed')
|
559
|
+
expect(bad_resource.provider.class.result).to eq('failed')
|
509
560
|
end
|
510
561
|
|
511
562
|
it "should call ::post_resource_eval even if one of the resources fails" do
|
512
|
-
|
513
|
-
|
514
|
-
|
563
|
+
resource = teardown_type.new(:title => "foo", :provider => :teardown_provider)
|
564
|
+
resource.stubs(:retrieve_resource).raises
|
565
|
+
catalog.add_resource resource
|
515
566
|
|
516
|
-
|
567
|
+
resource.provider.class.expects(:post_resource_eval)
|
517
568
|
|
518
|
-
|
569
|
+
transaction.evaluate
|
519
570
|
end
|
520
571
|
end
|
521
572
|
|