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
@@ -99,6 +99,32 @@ describe Puppet::SSL::CertificateAuthority, :unless => Puppet.features.microsoft
|
|
99
99
|
end
|
100
100
|
end
|
101
101
|
|
102
|
+
describe "when revoking certificate" do
|
103
|
+
it "should work for one certificate" do
|
104
|
+
certificate_request_for("luke.madstop.com")
|
105
|
+
|
106
|
+
ca.sign("luke.madstop.com")
|
107
|
+
ca.revoke("luke.madstop.com")
|
108
|
+
|
109
|
+
expect { ca.verify("luke.madstop.com") }.to raise_error(
|
110
|
+
Puppet::SSL::CertificateAuthority::CertificateVerificationError,
|
111
|
+
"certificate revoked"
|
112
|
+
)
|
113
|
+
end
|
114
|
+
|
115
|
+
it "should work for several certificates" do
|
116
|
+
3.times.each do |c|
|
117
|
+
certificate_request_for("luke.madstop.com")
|
118
|
+
ca.sign("luke.madstop.com")
|
119
|
+
ca.destroy("luke.madstop.com")
|
120
|
+
end
|
121
|
+
ca.revoke("luke.madstop.com")
|
122
|
+
|
123
|
+
ca.crl.content.revoked.map { |r| r.serial }.should == [2,3,4] # ca has serial 1
|
124
|
+
end
|
125
|
+
|
126
|
+
end
|
127
|
+
|
102
128
|
it "allows autosigning certificates concurrently", :unless => Puppet::Util::Platform.windows? do
|
103
129
|
Puppet[:autosign] = true
|
104
130
|
hosts = (0..4).collect { |i| certificate_request_for("host#{i}") }
|
@@ -10,8 +10,6 @@ describe Puppet::SSL::CertificateRequest do
|
|
10
10
|
# Get a safe temporary file
|
11
11
|
dir = tmpdir("csr_integration_testing")
|
12
12
|
|
13
|
-
Puppet.settings.clear
|
14
|
-
|
15
13
|
Puppet.settings[:confdir] = dir
|
16
14
|
Puppet.settings[:vardir] = dir
|
17
15
|
Puppet.settings[:group] = Process.gid
|
@@ -26,10 +24,6 @@ describe Puppet::SSL::CertificateRequest do
|
|
26
24
|
Puppet::SSL::CertificateRequest.indirection.termini.clear
|
27
25
|
end
|
28
26
|
|
29
|
-
after do
|
30
|
-
Puppet.settings.clear
|
31
|
-
end
|
32
|
-
|
33
27
|
it "should be able to generate CSRs" do
|
34
28
|
@csr.generate(@key)
|
35
29
|
end
|
@@ -193,6 +193,22 @@ describe Puppet::Transaction do
|
|
193
193
|
Puppet::FileSystem.exist?(file2).should be_true
|
194
194
|
end
|
195
195
|
|
196
|
+
it "should apply no resources whatsoever if a pre_run_check fails" do
|
197
|
+
path = tmpfile("path")
|
198
|
+
file = Puppet::Type.type(:file).new(
|
199
|
+
:path => path,
|
200
|
+
:ensure => "file"
|
201
|
+
)
|
202
|
+
notify = Puppet::Type.type(:notify).new(
|
203
|
+
:title => "foo"
|
204
|
+
)
|
205
|
+
notify.expects(:pre_run_check).raises(Puppet::Error, "fail for testing")
|
206
|
+
|
207
|
+
catalog = mk_catalog(file, notify)
|
208
|
+
catalog.apply
|
209
|
+
Puppet::FileSystem.exist?(path).should_not be_true
|
210
|
+
end
|
211
|
+
|
196
212
|
it "should not let one failed refresh result in other refreshes failing" do
|
197
213
|
path = tmpfile("path")
|
198
214
|
newfile = tmpfile("file")
|
@@ -78,7 +78,7 @@ describe Puppet::Type.type(:file), :uses_checksums => true do
|
|
78
78
|
it "should not attempt to manage files that do not exist if no means of creating the file is specified" do
|
79
79
|
source = tmpfile('source')
|
80
80
|
|
81
|
-
catalog.add_resource described_class.new :path => source, :mode => 0755
|
81
|
+
catalog.add_resource described_class.new :path => source, :mode => '0755'
|
82
82
|
|
83
83
|
status = catalog.apply.report.resource_statuses["File[#{source}]"]
|
84
84
|
status.should_not be_failed
|
@@ -155,7 +155,7 @@ describe Puppet::Type.type(:file), :uses_checksums => true do
|
|
155
155
|
it "should set executable bits for existing readable directories" do
|
156
156
|
set_mode(0600, target)
|
157
157
|
|
158
|
-
catalog.add_resource described_class.new(:path => target, :ensure => :directory, :mode => 0644)
|
158
|
+
catalog.add_resource described_class.new(:path => target, :ensure => :directory, :mode => '0644')
|
159
159
|
catalog.apply
|
160
160
|
|
161
161
|
(get_mode(target) & 07777).should == 0755
|
@@ -992,13 +992,13 @@ describe Puppet::Type.type(:file), :uses_checksums => true do
|
|
992
992
|
|
993
993
|
describe "on Windows systems", :if => Puppet.features.microsoft_windows? do
|
994
994
|
def expects_sid_granted_full_access_explicitly(path, sid)
|
995
|
-
inherited_ace = Windows::
|
995
|
+
inherited_ace = Puppet::Util::Windows::AccessControlEntry::INHERITED_ACE
|
996
996
|
|
997
997
|
aces = get_aces_for_path_by_sid(path, sid)
|
998
998
|
aces.should_not be_empty
|
999
999
|
|
1000
1000
|
aces.each do |ace|
|
1001
|
-
ace.mask.should == Windows::File::FILE_ALL_ACCESS
|
1001
|
+
ace.mask.should == Puppet::Util::Windows::File::FILE_ALL_ACCESS
|
1002
1002
|
(ace.flags & inherited_ace).should_not == inherited_ace
|
1003
1003
|
end
|
1004
1004
|
end
|
@@ -1008,13 +1008,13 @@ describe Puppet::Type.type(:file), :uses_checksums => true do
|
|
1008
1008
|
end
|
1009
1009
|
|
1010
1010
|
def expects_at_least_one_inherited_ace_grants_full_access(path, sid)
|
1011
|
-
inherited_ace = Windows::
|
1011
|
+
inherited_ace = Puppet::Util::Windows::AccessControlEntry::INHERITED_ACE
|
1012
1012
|
|
1013
1013
|
aces = get_aces_for_path_by_sid(path, sid)
|
1014
1014
|
aces.should_not be_empty
|
1015
1015
|
|
1016
1016
|
aces.any? do |ace|
|
1017
|
-
ace.mask == Windows::File::FILE_ALL_ACCESS &&
|
1017
|
+
ace.mask == Puppet::Util::Windows::File::FILE_ALL_ACCESS &&
|
1018
1018
|
(ace.flags & inherited_ace) == inherited_ace
|
1019
1019
|
end.should be_true
|
1020
1020
|
end
|
@@ -1045,10 +1045,10 @@ describe Puppet::Type.type(:file), :uses_checksums => true do
|
|
1045
1045
|
describe "when processing SYSTEM ACEs" do
|
1046
1046
|
before do
|
1047
1047
|
@sids = {
|
1048
|
-
:current_user => Puppet::Util::Windows::
|
1048
|
+
:current_user => Puppet::Util::Windows::SID.name_to_sid(Puppet::Util::Windows::ADSI::User.current_user_name),
|
1049
1049
|
:system => Win32::Security::SID::LocalSystem,
|
1050
|
-
:admin => Puppet::Util::Windows::
|
1051
|
-
:guest => Puppet::Util::Windows::
|
1050
|
+
:admin => Puppet::Util::Windows::SID.name_to_sid("Administrator"),
|
1051
|
+
:guest => Puppet::Util::Windows::SID.name_to_sid("Guest"),
|
1052
1052
|
:users => Win32::Security::SID::BuiltinUsers,
|
1053
1053
|
:power_users => Win32::Security::SID::PowerUsers,
|
1054
1054
|
:none => Win32::Security::SID::Nobody
|
@@ -1132,7 +1132,7 @@ describe Puppet::Type.type(:file), :uses_checksums => true do
|
|
1132
1132
|
system_aces.should_not be_empty
|
1133
1133
|
|
1134
1134
|
system_aces.each do |ace|
|
1135
|
-
ace.mask.should == Windows::File::FILE_GENERIC_READ
|
1135
|
+
ace.mask.should == Puppet::Util::Windows::File::FILE_GENERIC_READ
|
1136
1136
|
end
|
1137
1137
|
end
|
1138
1138
|
|
@@ -1173,8 +1173,9 @@ describe Puppet::Type.type(:file), :uses_checksums => true do
|
|
1173
1173
|
sd = Puppet::Util::Windows::Security.get_security_descriptor(path)
|
1174
1174
|
sd.dacl.allow(
|
1175
1175
|
'S-1-1-0', #everyone
|
1176
|
-
Windows::File::FILE_ALL_ACCESS,
|
1177
|
-
Windows::
|
1176
|
+
Puppet::Util::Windows::File::FILE_ALL_ACCESS,
|
1177
|
+
Puppet::Util::Windows::AccessControlEntry::OBJECT_INHERIT_ACE |
|
1178
|
+
Puppet::Util::Windows::AccessControlEntry::CONTAINER_INHERIT_ACE)
|
1178
1179
|
Puppet::Util::Windows::Security.set_security_descriptor(path, sd)
|
1179
1180
|
end
|
1180
1181
|
|
@@ -1252,7 +1253,7 @@ describe Puppet::Type.type(:file), :uses_checksums => true do
|
|
1252
1253
|
|
1253
1254
|
system_aces.each do |ace|
|
1254
1255
|
# unlike files, Puppet sets execute bit on directories that are readable
|
1255
|
-
ace.mask.should == Windows::File::FILE_GENERIC_READ | Windows::File::FILE_GENERIC_EXECUTE
|
1256
|
+
ace.mask.should == Puppet::Util::Windows::File::FILE_GENERIC_READ | Puppet::Util::Windows::File::FILE_GENERIC_EXECUTE
|
1256
1257
|
end
|
1257
1258
|
end
|
1258
1259
|
|
@@ -6,9 +6,11 @@ require 'puppet/file_bucket/dipper'
|
|
6
6
|
describe "Nagios file creation" do
|
7
7
|
include PuppetSpec::Files
|
8
8
|
|
9
|
+
let(:initial_mode) { 0600 }
|
10
|
+
|
9
11
|
before :each do
|
10
12
|
FileUtils.touch(target_file)
|
11
|
-
|
13
|
+
Puppet::FileSystem.chmod(initial_mode, target_file)
|
12
14
|
Puppet::FileBucket::Dipper.any_instance.stubs(:backup) # Don't backup to filebucket
|
13
15
|
end
|
14
16
|
|
@@ -33,13 +35,6 @@ describe "Nagios file creation" do
|
|
33
35
|
catalog.apply
|
34
36
|
end
|
35
37
|
|
36
|
-
# These three helpers are from file_spec.rb
|
37
|
-
#
|
38
|
-
# @todo Define those centrally as well?
|
39
|
-
def get_mode(file)
|
40
|
-
Puppet::FileSystem.stat(file).mode
|
41
|
-
end
|
42
|
-
|
43
38
|
context "when creating a nagios config file" do
|
44
39
|
context "which is not managed" do
|
45
40
|
it "should choose the file mode if requested" do
|
@@ -51,14 +46,12 @@ describe "Nagios file creation" do
|
|
51
46
|
:mode => '0640'
|
52
47
|
)
|
53
48
|
run_in_catalog(resource)
|
54
|
-
|
55
|
-
mode = Puppet.features.microsoft_windows? ? "640" : "100640"
|
56
|
-
( "%o" % get_mode(target_file) ).should == mode
|
49
|
+
expect_file_mode(target_file, "640")
|
57
50
|
end
|
58
51
|
end
|
59
52
|
|
60
53
|
context "which is managed" do
|
61
|
-
it "should not the mode" do
|
54
|
+
it "should not override the mode" do
|
62
55
|
file_res = Puppet::Type.type(:file).new(
|
63
56
|
:name => target_file,
|
64
57
|
:ensure => :present
|
@@ -71,10 +64,8 @@ describe "Nagios file creation" do
|
|
71
64
|
:mode => '0640'
|
72
65
|
)
|
73
66
|
run_in_catalog(file_res, nag_res)
|
74
|
-
(
|
67
|
+
expect_file_mode(target_file, initial_mode.to_s(8))
|
75
68
|
end
|
76
69
|
end
|
77
|
-
|
78
70
|
end
|
79
|
-
|
80
71
|
end
|
@@ -0,0 +1,22 @@
|
|
1
|
+
#! /usr/bin/env ruby
|
2
|
+
require 'spec_helper'
|
3
|
+
require 'puppet_spec/files'
|
4
|
+
require 'puppet_spec/compiler'
|
5
|
+
|
6
|
+
describe Puppet::Type.type(:sshkey), '(integration)', :unless => Puppet.features.microsoft_windows? do
|
7
|
+
include PuppetSpec::Files
|
8
|
+
include PuppetSpec::Compiler
|
9
|
+
|
10
|
+
let(:target) { tmpfile('ssh_known_hosts') }
|
11
|
+
let(:manifest) { "sshkey { 'test':
|
12
|
+
ensure => 'present',
|
13
|
+
type => 'rsa',
|
14
|
+
key => 'TESTKEY',
|
15
|
+
target => '#{target}' }"
|
16
|
+
}
|
17
|
+
|
18
|
+
it "should create a new known_hosts file with mode 0644" do
|
19
|
+
apply_compiled_manifest(manifest)
|
20
|
+
expect_file_mode(target, "644")
|
21
|
+
end
|
22
|
+
end
|
@@ -23,6 +23,9 @@ describe Puppet::Type.type(:tidy) do
|
|
23
23
|
|
24
24
|
catalog = Puppet::Resource::Catalog.new
|
25
25
|
catalog.add_resource(tidy)
|
26
|
+
# avoid crude failures because of nil resources that result
|
27
|
+
# from implicit containment and lacking containers
|
28
|
+
catalog.stubs(:container_of).returns tidy
|
26
29
|
|
27
30
|
catalog.apply
|
28
31
|
|
@@ -8,22 +8,27 @@ describe Puppet::Type.type(:user), '(integration)', :unless => Puppet.features.m
|
|
8
8
|
include PuppetSpec::Compiler
|
9
9
|
|
10
10
|
context "when set to purge ssh keys from a file" do
|
11
|
-
let(:tempfile) { file_containing('user_spec', "# comment\nssh-rsa KEY-DATA key-name") }
|
11
|
+
let(:tempfile) { file_containing('user_spec', "# comment\nssh-rsa KEY-DATA key-name\nssh-rsa KEY-DATA key name\n") }
|
12
12
|
# must use an existing user, or the generated key resource
|
13
13
|
# will fail on account of an invalid user for the key
|
14
14
|
# - root should be a safe default
|
15
15
|
let(:manifest) { "user { 'root': purge_ssh_keys => '#{tempfile}' }" }
|
16
16
|
|
17
17
|
it "should purge authorized ssh keys" do
|
18
|
-
apply_compiled_manifest(manifest
|
18
|
+
apply_compiled_manifest(manifest)
|
19
19
|
File.read(tempfile).should_not =~ /key-name/
|
20
20
|
end
|
21
21
|
|
22
|
+
it "should purge keys with spaces in the comment string" do
|
23
|
+
apply_compiled_manifest(manifest)
|
24
|
+
File.read(tempfile).should_not =~ /key name/
|
25
|
+
end
|
26
|
+
|
22
27
|
context "with other prefetching resources evaluated first" do
|
23
28
|
let(:manifest) { "host { 'test': before => User[root] } user { 'root': purge_ssh_keys => '#{tempfile}' }" }
|
24
29
|
|
25
30
|
it "should purge authorized ssh keys" do
|
26
|
-
apply_compiled_manifest(manifest
|
31
|
+
apply_compiled_manifest(manifest)
|
27
32
|
File.read(tempfile).should_not =~ /key-name/
|
28
33
|
end
|
29
34
|
end
|
@@ -95,12 +95,12 @@ describe Puppet::Util::Autoload do
|
|
95
95
|
|
96
96
|
file = File.join(libdir, "plugin.rb")
|
97
97
|
|
98
|
-
Puppet[
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
98
|
+
Puppet.override(:environments => Puppet::Environments::Static.new(Puppet::Node::Environment.create(:production, [modulepath]))) do
|
99
|
+
with_loader("foo", "foo") do |dir, loader|
|
100
|
+
with_file(:plugin, file.split("/")) do
|
101
|
+
loader.load(:plugin)
|
102
|
+
loader.class.should be_loaded("foo/plugin.rb")
|
103
|
+
end
|
104
104
|
end
|
105
105
|
end
|
106
106
|
end
|
@@ -127,6 +127,13 @@ end
|
|
127
127
|
end.should_not(be_empty, "Could not match #{content_patterns} in any of the files found in #{glob}")
|
128
128
|
end
|
129
129
|
|
130
|
+
around(:each) do |example|
|
131
|
+
env = Puppet::Node::Environment.create(:doc_test_env, [modules_dir], manifests_dir)
|
132
|
+
Puppet.override({:environments => Puppet::Environments::Static.new(env), :current_environment => env}) do
|
133
|
+
example.run
|
134
|
+
end
|
135
|
+
end
|
136
|
+
|
130
137
|
before :each do
|
131
138
|
prepare_manifests_and_modules
|
132
139
|
Puppet.settings[:document_all] = document_all
|
@@ -18,5 +18,17 @@ describe "Puppet::Util::Windows::Process", :if => Puppet.features.microsoft_wind
|
|
18
18
|
Puppet::Util::Windows::User.should be_admin
|
19
19
|
Puppet::Util::Windows::Process.process_privilege_symlink?.should be_false
|
20
20
|
end
|
21
|
+
|
22
|
+
it "should be able to lookup a standard Windows process privilege" do
|
23
|
+
Puppet::Util::Windows::Process.lookup_privilege_value('SeShutdownPrivilege') do |luid|
|
24
|
+
luid.should_not be_nil
|
25
|
+
luid.should be_instance_of(Puppet::Util::Windows::Process::LUID)
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
it "should raise an error for an unknown privilege name" do
|
30
|
+
fail_msg = /LookupPrivilegeValue\(, foo, .*\): A specified privilege does not exist/
|
31
|
+
expect { Puppet::Util::Windows::Process.lookup_privilege_value('foo') }.to raise_error(Puppet::Util::Windows::Error, fail_msg)
|
32
|
+
end
|
21
33
|
end
|
22
34
|
end
|
@@ -1,8 +1,6 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
2
|
require 'spec_helper'
|
3
3
|
|
4
|
-
require 'puppet/util/adsi'
|
5
|
-
|
6
4
|
if Puppet.features.microsoft_windows?
|
7
5
|
class WindowsSecurityTester
|
8
6
|
require 'puppet/util/windows/security'
|
@@ -15,11 +13,11 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
15
13
|
|
16
14
|
before :all do
|
17
15
|
@sids = {
|
18
|
-
:current_user => Puppet::Util::Windows::
|
16
|
+
:current_user => Puppet::Util::Windows::SID.name_to_sid(Puppet::Util::Windows::ADSI::User.current_user_name),
|
19
17
|
:system => Win32::Security::SID::LocalSystem,
|
20
|
-
:admin => Puppet::Util::Windows::
|
18
|
+
:admin => Puppet::Util::Windows::SID.name_to_sid("Administrator"),
|
21
19
|
:administrators => Win32::Security::SID::BuiltinAdministrators,
|
22
|
-
:guest => Puppet::Util::Windows::
|
20
|
+
:guest => Puppet::Util::Windows::SID.name_to_sid("Guest"),
|
23
21
|
:users => Win32::Security::SID::BuiltinUsers,
|
24
22
|
:power_users => Win32::Security::SID::PowerUsers,
|
25
23
|
:none => Win32::Security::SID::Nobody,
|
@@ -31,11 +29,12 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
31
29
|
# (like \\localhost) to fail with unhelpful error messages.
|
32
30
|
# Put a check for this upfront to aid debug should this strike again.
|
33
31
|
service = Puppet::Type.type(:service).new(:name => 'lmhosts')
|
34
|
-
service.provider.status.
|
32
|
+
expect(service.provider.status).to eq(:running), 'lmhosts service is not running'
|
35
33
|
end
|
36
34
|
|
37
35
|
let (:sids) { @sids }
|
38
36
|
let (:winsec) { WindowsSecurityTester.new }
|
37
|
+
let (:klass) { Puppet::Util::Windows::File }
|
39
38
|
|
40
39
|
def set_group_depending_on_current_user(path)
|
41
40
|
if sids[:current_user] == sids[:system]
|
@@ -53,8 +52,8 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
53
52
|
def grant_everyone_full_access(path)
|
54
53
|
sd = winsec.get_security_descriptor(path)
|
55
54
|
everyone = 'S-1-1-0'
|
56
|
-
inherit =
|
57
|
-
sd.dacl.allow(everyone,
|
55
|
+
inherit = Puppet::Util::Windows::AccessControlEntry::OBJECT_INHERIT_ACE | Puppet::Util::Windows::AccessControlEntry::CONTAINER_INHERIT_ACE
|
56
|
+
sd.dacl.allow(everyone, klass::FILE_ALL_ACCESS, inherit)
|
58
57
|
winsec.set_security_descriptor(path, sd)
|
59
58
|
end
|
60
59
|
|
@@ -178,7 +177,7 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
178
177
|
# when running under SYSTEM account, multiple ACEs come back
|
179
178
|
# so we only care that we have at least one of these
|
180
179
|
system_aces.any? do |ace|
|
181
|
-
ace.mask ==
|
180
|
+
ace.mask == klass::FILE_ALL_ACCESS
|
182
181
|
end.should be_true
|
183
182
|
|
184
183
|
# changing the owner/group will no longer make the SD protected
|
@@ -186,7 +185,7 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
186
185
|
winsec.set_owner(sids[:administrators], path)
|
187
186
|
|
188
187
|
system_aces.find do |ace|
|
189
|
-
ace.mask ==
|
188
|
+
ace.mask == klass::FILE_ALL_ACCESS && ace.inherited?
|
190
189
|
end.should_not be_nil
|
191
190
|
end
|
192
191
|
|
@@ -227,7 +226,7 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
227
226
|
# when running under SYSTEM account, multiple ACEs come back
|
228
227
|
# so we only care that we have at least one of these
|
229
228
|
system_aces.any? do |ace|
|
230
|
-
ace.mask ==
|
229
|
+
ace.mask == klass::FILE_ALL_ACCESS
|
231
230
|
end.should be_true
|
232
231
|
|
233
232
|
# changing the mode will make the SD protected
|
@@ -237,7 +236,7 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
237
236
|
# and should have a non-inherited SYSTEM ACE(s)
|
238
237
|
system_aces = winsec.get_aces_for_path_by_sid(path, sids[:system])
|
239
238
|
system_aces.each do |ace|
|
240
|
-
ace.mask.should ==
|
239
|
+
ace.mask.should == klass::FILE_ALL_ACCESS && ! ace.inherited?
|
241
240
|
end
|
242
241
|
end
|
243
242
|
|
@@ -259,25 +258,25 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
259
258
|
before :each do
|
260
259
|
winsec.set_group(sids[:none], path)
|
261
260
|
winsec.set_mode(0600, path)
|
262
|
-
|
263
|
-
(
|
261
|
+
Puppet::Util::Windows::File.add_attributes(path, klass::FILE_ATTRIBUTE_READONLY)
|
262
|
+
(Puppet::Util::Windows::File.get_attributes(path) & klass::FILE_ATTRIBUTE_READONLY).should be_nonzero
|
264
263
|
end
|
265
264
|
|
266
265
|
it "should make them writable if any sid has write permission" do
|
267
266
|
winsec.set_mode(WindowsSecurityTester::S_IWUSR, path)
|
268
|
-
(
|
267
|
+
(Puppet::Util::Windows::File.get_attributes(path) & klass::FILE_ATTRIBUTE_READONLY).should == 0
|
269
268
|
end
|
270
269
|
|
271
270
|
it "should leave them read-only if no sid has write permission and should allow full access for SYSTEM" do
|
272
271
|
winsec.set_mode(WindowsSecurityTester::S_IRUSR | WindowsSecurityTester::S_IXGRP, path)
|
273
|
-
(
|
272
|
+
(Puppet::Util::Windows::File.get_attributes(path) & klass::FILE_ATTRIBUTE_READONLY).should be_nonzero
|
274
273
|
|
275
274
|
system_aces = winsec.get_aces_for_path_by_sid(path, sids[:system])
|
276
275
|
|
277
276
|
# when running under SYSTEM account, and set_group / set_owner hasn't been called
|
278
277
|
# SYSTEM full access will be restored
|
279
278
|
system_aces.any? do |ace|
|
280
|
-
ace.mask ==
|
279
|
+
ace.mask == klass::FILE_ALL_ACCESS
|
281
280
|
end.should be_true
|
282
281
|
end
|
283
282
|
end
|
@@ -291,7 +290,7 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
291
290
|
it "should report when extra aces are encounted" do
|
292
291
|
sd = winsec.get_security_descriptor(path)
|
293
292
|
(544..547).each do |rid|
|
294
|
-
sd.dacl.allow("S-1-5-32-#{rid}",
|
293
|
+
sd.dacl.allow("S-1-5-32-#{rid}", klass::STANDARD_RIGHTS_ALL)
|
295
294
|
end
|
296
295
|
winsec.set_security_descriptor(path, sd)
|
297
296
|
|
@@ -301,12 +300,12 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
301
300
|
|
302
301
|
it "should return deny aces" do
|
303
302
|
sd = winsec.get_security_descriptor(path)
|
304
|
-
sd.dacl.deny(sids[:guest],
|
303
|
+
sd.dacl.deny(sids[:guest], klass::FILE_GENERIC_WRITE)
|
305
304
|
winsec.set_security_descriptor(path, sd)
|
306
305
|
|
307
306
|
guest_aces = winsec.get_aces_for_path_by_sid(path, sids[:guest])
|
308
307
|
guest_aces.find do |ace|
|
309
|
-
ace.type ==
|
308
|
+
ace.type == Puppet::Util::Windows::AccessControlEntry::ACCESS_DENIED_ACE_TYPE
|
310
309
|
end.should_not be_nil
|
311
310
|
end
|
312
311
|
|
@@ -314,12 +313,12 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
314
313
|
sd = winsec.get_security_descriptor(path)
|
315
314
|
dacl = Puppet::Util::Windows::AccessControlList.new
|
316
315
|
dacl.allow(
|
317
|
-
sids[:current_user],
|
316
|
+
sids[:current_user], klass::STANDARD_RIGHTS_ALL | klass::SPECIFIC_RIGHTS_ALL
|
318
317
|
)
|
319
318
|
dacl.allow(
|
320
319
|
sids[:everyone],
|
321
|
-
|
322
|
-
|
320
|
+
klass::FILE_GENERIC_READ,
|
321
|
+
Puppet::Util::Windows::AccessControlEntry::INHERIT_ONLY_ACE | Puppet::Util::Windows::AccessControlEntry::OBJECT_INHERIT_ACE
|
323
322
|
)
|
324
323
|
winsec.set_security_descriptor(path, sd)
|
325
324
|
|
@@ -344,8 +343,8 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
344
343
|
|
345
344
|
it "should be present when the access control list is unprotected" do
|
346
345
|
# add a bunch of aces to the parent with permission to add children
|
347
|
-
allow =
|
348
|
-
inherit =
|
346
|
+
allow = klass::STANDARD_RIGHTS_ALL | klass::SPECIFIC_RIGHTS_ALL
|
347
|
+
inherit = Puppet::Util::Windows::AccessControlEntry::OBJECT_INHERIT_ACE | Puppet::Util::Windows::AccessControlEntry::CONTAINER_INHERIT_ACE
|
349
348
|
|
350
349
|
sd = winsec.get_security_descriptor(parent)
|
351
350
|
sd.dacl.allow(
|
@@ -356,7 +355,7 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
356
355
|
(544..547).each do |rid|
|
357
356
|
sd.dacl.allow(
|
358
357
|
"S-1-5-32-#{rid}",
|
359
|
-
|
358
|
+
klass::STANDARD_RIGHTS_ALL,
|
360
359
|
inherit
|
361
360
|
)
|
362
361
|
end
|
@@ -371,10 +370,12 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
371
370
|
|
372
371
|
describe "for an administrator", :if => Puppet.features.root? do
|
373
372
|
before :each do
|
373
|
+
is_dir = Puppet::FileSystem.directory?(path)
|
374
374
|
winsec.set_mode(WindowsSecurityTester::S_IRWXU | WindowsSecurityTester::S_IRWXG, path)
|
375
375
|
set_group_depending_on_current_user(path)
|
376
376
|
winsec.set_owner(sids[:guest], path)
|
377
|
-
|
377
|
+
expected_error = RUBY_VERSION =~ /^2\./ && is_dir ? Errno::EISDIR : Errno::EACCES
|
378
|
+
lambda { File.open(path, 'r') }.should raise_error(expected_error)
|
378
379
|
end
|
379
380
|
|
380
381
|
after :each do
|
@@ -446,14 +447,14 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
446
447
|
describe "when the sid refers to a deleted trustee" do
|
447
448
|
it "should retrieve the user sid" do
|
448
449
|
sid = nil
|
449
|
-
user = Puppet::Util::ADSI::User.create("delete_me_user")
|
450
|
+
user = Puppet::Util::Windows::ADSI::User.create("delete_me_user")
|
450
451
|
user.commit
|
451
452
|
begin
|
452
|
-
sid =
|
453
|
+
sid = Puppet::Util::Windows::ADSI::User.new(user.name).sid.to_s
|
453
454
|
winsec.set_owner(sid, path)
|
454
455
|
winsec.set_mode(WindowsSecurityTester::S_IRWXU, path)
|
455
456
|
ensure
|
456
|
-
Puppet::Util::ADSI::User.delete(user.name)
|
457
|
+
Puppet::Util::Windows::ADSI::User.delete(user.name)
|
457
458
|
end
|
458
459
|
|
459
460
|
winsec.get_owner(path).should == sid
|
@@ -462,14 +463,14 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
462
463
|
|
463
464
|
it "should retrieve the group sid" do
|
464
465
|
sid = nil
|
465
|
-
group = Puppet::Util::ADSI::Group.create("delete_me_group")
|
466
|
+
group = Puppet::Util::Windows::ADSI::Group.create("delete_me_group")
|
466
467
|
group.commit
|
467
468
|
begin
|
468
|
-
sid =
|
469
|
+
sid = Puppet::Util::Windows::ADSI::Group.new(group.name).sid.to_s
|
469
470
|
winsec.set_group(sid, path)
|
470
471
|
winsec.set_mode(WindowsSecurityTester::S_IRWXG, path)
|
471
472
|
ensure
|
472
|
-
Puppet::Util::ADSI::Group.delete(group.name)
|
473
|
+
Puppet::Util::Windows::ADSI::Group.delete(group.name)
|
473
474
|
end
|
474
475
|
winsec.get_group(path).should == sid
|
475
476
|
winsec.get_mode(path).should == WindowsSecurityTester::S_IRWXG
|
@@ -813,7 +814,7 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
813
814
|
Puppet::Util::Windows::AccessControlEntry::CONTAINER_INHERIT_ACE
|
814
815
|
|
815
816
|
sd = winsec.get_security_descriptor(dir)
|
816
|
-
sd.dacl.allow(sd.owner,
|
817
|
+
sd.dacl.allow(sd.owner, klass::FILE_ALL_ACCESS, inherit_flags)
|
817
818
|
winsec.set_security_descriptor(dir, sd)
|
818
819
|
|
819
820
|
sd = winsec.get_security_descriptor(dir)
|
@@ -834,7 +835,7 @@ describe "Puppet::Util::Windows::Security", :if => Puppet.features.microsoft_win
|
|
834
835
|
Puppet::Util::Windows::AccessControlEntry::CONTAINER_INHERIT_ACE
|
835
836
|
|
836
837
|
sd = winsec.get_security_descriptor(dir)
|
837
|
-
sd.dacl.deny(sids[:guest],
|
838
|
+
sd.dacl.deny(sids[:guest], klass::FILE_ALL_ACCESS, inherit_flags)
|
838
839
|
winsec.set_security_descriptor(dir, sd)
|
839
840
|
|
840
841
|
sd = winsec.get_security_descriptor(dir)
|