puppet 5.5.22-x86-mingw32 → 6.0.0-x86-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of puppet might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/Gemfile +46 -72
- data/Gemfile.lock +86 -102
- data/MAINTAINERS +47 -0
- data/Rakefile +15 -19
- data/ext/build_defaults.yaml +0 -1
- data/ext/cert_inspector +3 -3
- data/ext/debian/copyright +0 -22
- data/ext/project_data.yaml +8 -10
- data/ext/puppet-test +2 -2
- data/ext/redhat/puppet.spec.erb +0 -4
- data/ext/regexp_nodes/regexp_nodes.rb +4 -4
- data/ext/solaris/smf/puppet.xml +0 -2
- data/ext/solaris/smf/svc-puppetd +1 -8
- data/ext/solaris/smf/svc-puppetmasterd +1 -8
- data/ext/windows/eventlog/Rakefile +32 -0
- data/ext/windows/eventlog/puppetres.dll +0 -0
- data/ext/windows/eventlog/puppetres.mc +18 -0
- data/ext/windows/service/daemon.rb +8 -54
- data/install.rb +24 -6
- data/lib/hiera/scope.rb +0 -7
- data/lib/puppet.rb +10 -21
- data/lib/puppet/agent.rb +13 -5
- data/lib/puppet/application.rb +10 -8
- data/lib/puppet/application/agent.rb +3 -21
- data/lib/puppet/application/apply.rb +22 -12
- data/lib/puppet/application/cert.rb +25 -180
- data/lib/puppet/application/describe.rb +9 -3
- data/lib/puppet/application/device.rb +41 -74
- data/lib/puppet/application/doc.rb +5 -3
- data/lib/puppet/application/filebucket.rb +1 -23
- data/lib/puppet/application/lookup.rb +2 -2
- data/lib/puppet/application/resource.rb +4 -4
- data/lib/puppet/application/script.rb +3 -3
- data/lib/puppet/application/ssl.rb +133 -0
- data/lib/puppet/application_support.rb +1 -2
- data/lib/puppet/configurer.rb +62 -127
- data/lib/puppet/configurer/downloader.rb +17 -34
- data/lib/puppet/configurer/fact_handler.rb +5 -1
- data/lib/puppet/configurer/plugin_handler.rb +2 -3
- data/lib/puppet/confine/false.rb +1 -7
- data/lib/puppet/confine/true.rb +1 -7
- data/lib/puppet/daemon.rb +2 -2
- data/lib/puppet/datatypes.rb +1 -1
- data/lib/puppet/defaults.rb +126 -286
- data/lib/puppet/environments.rb +2 -7
- data/lib/puppet/error.rb +14 -10
- data/lib/puppet/etc.rb +4 -25
- data/lib/puppet/external/dot.rb +23 -17
- data/lib/puppet/face/config.rb +50 -12
- data/lib/puppet/face/epp.rb +2 -2
- data/lib/puppet/face/facts.rb +1 -1
- data/lib/puppet/face/help.rb +21 -7
- data/lib/puppet/face/help/global.erb +2 -2
- data/lib/puppet/face/module/build.rb +4 -59
- data/lib/puppet/face/module/generate.rb +5 -247
- data/lib/puppet/face/module/install.rb +0 -4
- data/lib/puppet/face/module/list.rb +5 -10
- data/lib/puppet/face/module/search.rb +2 -2
- data/lib/puppet/face/module/uninstall.rb +1 -5
- data/lib/puppet/face/module/upgrade.rb +1 -5
- data/lib/puppet/face/node/clean.rb +14 -10
- data/lib/puppet/face/plugin.rb +2 -9
- data/lib/puppet/feature/base.rb +7 -26
- data/lib/puppet/feature/eventlog.rb +1 -1
- data/lib/puppet/file_bucket/dipper.rb +1 -1
- data/lib/puppet/file_serving/base.rb +7 -7
- data/lib/puppet/file_serving/fileset.rb +2 -2
- data/lib/puppet/file_serving/http_metadata.rb +1 -1
- data/lib/puppet/file_serving/metadata.rb +4 -3
- data/lib/puppet/file_serving/mount/locales.rb +2 -1
- data/lib/puppet/file_serving/mount/pluginfacts.rb +2 -1
- data/lib/puppet/file_serving/mount/plugins.rb +2 -1
- data/lib/puppet/file_system.rb +8 -0
- data/lib/puppet/file_system/memory_file.rb +1 -1
- data/lib/puppet/file_system/posix.rb +2 -3
- data/lib/puppet/file_system/uniquefile.rb +0 -4
- data/lib/puppet/forge.rb +8 -12
- data/lib/puppet/functions.rb +138 -0
- data/lib/puppet/functions/abs.rb +61 -0
- data/lib/puppet/functions/call.rb +38 -2
- data/lib/puppet/functions/camelcase.rb +62 -0
- data/lib/puppet/functions/capitalize.rb +61 -0
- data/lib/puppet/functions/ceiling.rb +37 -0
- data/lib/puppet/functions/chomp.rb +57 -0
- data/lib/puppet/functions/chop.rb +67 -0
- data/lib/puppet/functions/compare.rb +125 -0
- data/lib/puppet/functions/convert_to.rb +3 -2
- data/lib/puppet/functions/dig.rb +21 -1
- data/lib/puppet/functions/downcase.rb +89 -0
- data/lib/puppet/functions/epp.rb +4 -4
- data/lib/puppet/functions/eyaml_lookup_key.rb +4 -5
- data/lib/puppet/functions/filter.rb +7 -6
- data/lib/puppet/functions/floor.rb +37 -0
- data/lib/puppet/functions/get.rb +150 -0
- data/lib/puppet/functions/getvar.rb +87 -0
- data/lib/puppet/functions/inline_epp.rb +5 -5
- data/lib/puppet/functions/lstrip.rb +58 -0
- data/lib/puppet/functions/max.rb +183 -0
- data/lib/puppet/functions/min.rb +182 -0
- data/lib/puppet/functions/new.rb +3 -8
- data/lib/puppet/functions/reduce.rb +4 -2
- data/lib/puppet/functions/reverse_each.rb +1 -1
- data/lib/puppet/functions/round.rb +24 -0
- data/lib/puppet/functions/rstrip.rb +58 -0
- data/lib/puppet/functions/size.rb +15 -0
- data/lib/puppet/functions/sort.rb +74 -0
- data/lib/puppet/functions/step.rb +1 -1
- data/lib/puppet/functions/strip.rb +58 -0
- data/lib/puppet/functions/upcase.rb +89 -0
- data/lib/puppet/functions/yaml_data.rb +4 -5
- data/lib/puppet/gettext/config.rb +1 -1
- data/lib/puppet/gettext/module_translations.rb +1 -1
- data/lib/puppet/graph.rb +0 -2
- data/lib/puppet/graph/rb_tree_map.rb +2 -2
- data/lib/puppet/graph/simple_graph.rb +10 -7
- data/lib/puppet/indirector/catalog/compiler.rb +0 -8
- data/lib/puppet/indirector/catalog/json.rb +14 -3
- data/lib/puppet/indirector/catalog/yaml.rb +0 -16
- data/lib/puppet/indirector/certificate/file.rb +0 -1
- data/lib/puppet/indirector/facts/yaml.rb +4 -2
- data/lib/puppet/indirector/file_bucket_file/file.rb +1 -1
- data/lib/puppet/indirector/hiera.rb +0 -6
- data/lib/puppet/indirector/indirection.rb +8 -12
- data/lib/puppet/indirector/key/file.rb +1 -6
- data/lib/puppet/indirector/node/exec.rb +1 -3
- data/lib/puppet/indirector/node/yaml.rb +0 -6
- data/lib/puppet/indirector/request.rb +20 -27
- data/lib/puppet/indirector/resource/ral.rb +3 -1
- data/lib/puppet/indirector/resource/validator.rb +1 -1
- data/lib/puppet/indirector/rest.rb +7 -65
- data/lib/puppet/indirector/ssl_file.rb +3 -44
- data/lib/puppet/indirector/terminus.rb +1 -1
- data/lib/puppet/indirector/yaml.rb +4 -4
- data/lib/puppet/info_service/task_information_service.rb +7 -3
- data/lib/puppet/interface.rb +2 -3
- data/lib/puppet/interface/action.rb +2 -5
- data/lib/puppet/interface/face_collection.rb +3 -1
- data/lib/puppet/loaders.rb +2 -0
- data/lib/puppet/metatype/manager.rb +3 -5
- data/lib/puppet/module.rb +5 -31
- data/lib/puppet/module/task.rb +208 -30
- data/lib/puppet/module_tool.rb +2 -5
- data/lib/puppet/module_tool/applications.rb +0 -1
- data/lib/puppet/module_tool/applications/application.rb +1 -1
- data/lib/puppet/module_tool/applications/installer.rb +7 -8
- data/lib/puppet/module_tool/applications/uninstaller.rb +4 -5
- data/lib/puppet/module_tool/applications/unpacker.rb +1 -1
- data/lib/puppet/module_tool/applications/upgrader.rb +5 -6
- data/lib/puppet/module_tool/installed_modules.rb +2 -2
- data/lib/puppet/module_tool/local_tarball.rb +3 -3
- data/lib/puppet/module_tool/metadata.rb +1 -2
- data/lib/puppet/module_tool/shared_behaviors.rb +6 -6
- data/lib/puppet/module_tool/tar/mini.rb +2 -12
- data/lib/puppet/network/authconfig.rb +0 -13
- data/lib/puppet/network/format_support.rb +13 -8
- data/lib/puppet/network/formats.rb +93 -2
- data/lib/puppet/network/http.rb +0 -2
- data/lib/puppet/network/http/api.rb +1 -10
- data/lib/puppet/network/http/api/indirected_routes.rb +22 -16
- data/lib/puppet/network/http/api/master/v3/environment.rb +0 -3
- data/lib/puppet/network/http/connection.rb +14 -57
- data/lib/puppet/network/http/factory.rb +13 -7
- data/lib/puppet/network/http/handler.rb +59 -27
- data/lib/puppet/network/http/pool.rb +1 -7
- data/lib/puppet/network/http/site.rb +1 -1
- data/lib/puppet/network/resolver.rb +140 -67
- data/lib/puppet/node.rb +1 -2
- data/lib/puppet/node/environment.rb +5 -30
- data/lib/puppet/node/facts.rb +11 -1
- data/lib/puppet/parameter.rb +4 -7
- data/lib/puppet/parser/ast.rb +5 -9
- data/lib/puppet/parser/ast/branch.rb +3 -3
- data/lib/puppet/parser/ast/leaf.rb +5 -0
- data/lib/puppet/parser/ast/resourceparam.rb +1 -1
- data/lib/puppet/parser/catalog_compiler.rb +32 -0
- data/lib/puppet/parser/compiler.rb +2 -3
- data/lib/puppet/parser/compiler/catalog_validator/env_relationship_validator.rb +0 -2
- data/lib/puppet/parser/compiler/catalog_validator/site_validator.rb +0 -2
- data/lib/puppet/parser/environment_compiler.rb +0 -3
- data/lib/puppet/parser/functions.rb +48 -18
- data/lib/puppet/parser/functions/epp.rb +3 -3
- data/lib/puppet/parser/functions/filter.rb +1 -1
- data/lib/puppet/parser/functions/generate.rb +1 -1
- data/lib/puppet/parser/functions/inline_epp.rb +5 -5
- data/lib/puppet/parser/resource.rb +2 -4
- data/lib/puppet/parser/resource/param.rb +12 -11
- data/lib/puppet/parser/scope.rb +6 -8
- data/lib/puppet/parser/script_compiler.rb +7 -2
- data/lib/puppet/pops.rb +1 -0
- data/lib/puppet/pops/adaptable.rb +13 -7
- data/lib/puppet/pops/adapters.rb +18 -8
- data/lib/puppet/pops/evaluator/access_operator.rb +2 -2
- data/lib/puppet/pops/evaluator/collectors/abstract_collector.rb +4 -4
- data/lib/puppet/pops/evaluator/collectors/catalog_collector.rb +1 -1
- data/lib/puppet/pops/evaluator/collectors/exported_collector.rb +1 -1
- data/lib/puppet/pops/evaluator/compare_operator.rb +3 -1
- data/lib/puppet/pops/evaluator/deferred_resolver.rb +127 -0
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +17 -2
- data/lib/puppet/pops/evaluator/external_syntax_support.rb +2 -3
- data/lib/puppet/pops/evaluator/runtime3_converter.rb +23 -4
- data/lib/puppet/pops/evaluator/runtime3_support.rb +7 -8
- data/lib/puppet/pops/functions/dispatch.rb +6 -0
- data/lib/puppet/pops/issues.rb +9 -10
- data/lib/puppet/pops/loader/loader.rb +1 -1
- data/lib/puppet/pops/loader/loader_paths.rb +5 -3
- data/lib/puppet/pops/loader/module_loaders.rb +47 -21
- data/lib/puppet/pops/loader/null_loader.rb +60 -0
- data/lib/puppet/pops/loader/ruby_legacy_function_instantiator.rb +54 -0
- data/lib/puppet/pops/loader/static_loader.rb +0 -36
- data/lib/puppet/pops/loader/task_instantiator.rb +72 -44
- data/lib/puppet/pops/loaders.rb +21 -33
- data/lib/puppet/pops/lookup/hiera_config.rb +1 -2
- data/lib/puppet/pops/lookup/sub_lookup.rb +1 -1
- data/lib/puppet/pops/merge_strategy.rb +18 -22
- data/lib/puppet/pops/model/ast.pp +16 -0
- data/lib/puppet/pops/model/ast.rb +94 -0
- data/lib/puppet/pops/model/factory.rb +17 -38
- data/lib/puppet/pops/model/model_label_provider.rb +8 -1
- data/lib/puppet/pops/parser/egrammar.ra +14 -3
- data/lib/puppet/pops/parser/eparser.rb +1537 -1492
- data/lib/puppet/pops/parser/epp_support.rb +6 -2
- data/lib/puppet/pops/parser/heredoc_support.rb +8 -17
- data/lib/puppet/pops/parser/interpolation_support.rb +4 -4
- data/lib/puppet/pops/parser/lexer2.rb +2 -7
- data/lib/puppet/pops/parser/locator.rb +87 -107
- data/lib/puppet/pops/parser/parser_support.rb +2 -11
- data/lib/puppet/pops/parser/pn_parser.rb +16 -17
- data/lib/puppet/pops/pcore.rb +19 -8
- data/lib/puppet/pops/puppet_stack.rb +48 -51
- data/lib/puppet/pops/resource/resource_type_impl.rb +0 -2
- data/lib/puppet/pops/serialization.rb +3 -2
- data/lib/puppet/pops/serialization/from_data_converter.rb +4 -3
- data/lib/puppet/pops/serialization/to_data_converter.rb +3 -3
- data/lib/puppet/pops/serialization/to_stringified_converter.rb +226 -0
- data/lib/puppet/pops/types/iterable.rb +8 -34
- data/lib/puppet/pops/types/p_binary_type.rb +1 -2
- data/lib/puppet/pops/types/p_meta_type.rb +1 -1
- data/lib/puppet/pops/types/p_object_type.rb +3 -0
- data/lib/puppet/pops/types/p_sensitive_type.rb +1 -1
- data/lib/puppet/pops/types/p_timespan_type.rb +2 -2
- data/lib/puppet/pops/types/p_type_set_type.rb +0 -4
- data/lib/puppet/pops/types/string_converter.rb +12 -21
- data/lib/puppet/pops/types/type_calculator.rb +0 -24
- data/lib/puppet/pops/types/type_factory.rb +17 -0
- data/lib/puppet/pops/types/type_mismatch_describer.rb +1 -1
- data/lib/puppet/pops/types/types.rb +7 -32
- data/lib/puppet/pops/validation/checker4_0.rb +23 -33
- data/lib/puppet/pops/validation/tasks_checker.rb +47 -6
- data/lib/puppet/pops/validation/validator_factory_4_0.rb +7 -10
- data/lib/puppet/property.rb +1 -1
- data/lib/puppet/property/ensure.rb +1 -1
- data/lib/puppet/provider.rb +14 -2
- data/lib/puppet/provider/exec.rb +58 -59
- data/lib/puppet/provider/file/posix.rb +0 -5
- data/lib/puppet/provider/file/windows.rb +2 -50
- data/lib/puppet/provider/group/aix.rb +2 -18
- data/lib/puppet/provider/group/groupadd.rb +19 -19
- data/lib/puppet/provider/group/windows_adsi.rb +4 -11
- data/lib/puppet/provider/nameservice.rb +28 -11
- data/lib/puppet/provider/nameservice/directoryservice.rb +1 -1
- data/lib/puppet/provider/nameservice/pw.rb +2 -2
- data/lib/puppet/provider/package.rb +0 -2
- data/lib/puppet/provider/package/aix.rb +2 -17
- data/lib/puppet/provider/package/apt.rb +3 -14
- data/lib/puppet/provider/package/dnf.rb +3 -3
- data/lib/puppet/provider/package/dpkg.rb +7 -18
- data/lib/puppet/provider/package/fink.rb +3 -20
- data/lib/puppet/provider/package/gem.rb +43 -105
- data/lib/puppet/provider/package/openbsd.rb +2 -14
- data/lib/puppet/provider/package/pip.rb +108 -160
- data/lib/puppet/provider/package/pip3.rb +1 -1
- data/lib/puppet/provider/package/pkg.rb +5 -18
- data/lib/puppet/provider/package/pkgdmg.rb +1 -1
- data/lib/puppet/provider/package/pkgng.rb +4 -16
- data/lib/puppet/provider/package/portage.rb +6 -6
- data/lib/puppet/provider/package/puppet_gem.rb +2 -7
- data/lib/puppet/provider/package/rpm.rb +33 -82
- data/lib/puppet/provider/package/windows.rb +2 -6
- data/lib/puppet/provider/package/windows/exe_package.rb +10 -16
- data/lib/puppet/provider/package/windows/msi_package.rb +0 -8
- data/lib/puppet/provider/package/windows/package.rb +2 -10
- data/lib/puppet/provider/package/yum.rb +25 -37
- data/lib/puppet/provider/package/zypper.rb +0 -1
- data/lib/puppet/provider/parsedfile.rb +5 -26
- data/lib/puppet/provider/service/base.rb +1 -1
- data/lib/puppet/provider/service/daemontools.rb +9 -9
- data/lib/puppet/provider/service/debian.rb +1 -0
- data/lib/puppet/provider/service/launchd.rb +8 -39
- data/lib/puppet/provider/service/openbsd.rb +1 -1
- data/lib/puppet/provider/service/rcng.rb +2 -2
- data/lib/puppet/provider/service/runit.rb +8 -2
- data/lib/puppet/provider/service/smf.rb +0 -54
- data/lib/puppet/provider/service/systemd.rb +24 -35
- data/lib/puppet/provider/service/upstart.rb +1 -3
- data/lib/puppet/provider/service/windows.rb +3 -23
- data/lib/puppet/provider/user/aix.rb +2 -48
- data/lib/puppet/provider/user/directoryservice.rb +8 -45
- data/lib/puppet/provider/user/hpux.rb +1 -1
- data/lib/puppet/provider/user/pw.rb +3 -12
- data/lib/puppet/provider/user/user_role_add.rb +1 -5
- data/lib/puppet/provider/user/useradd.rb +44 -74
- data/lib/puppet/provider/user/windows_adsi.rb +0 -7
- data/lib/puppet/reference/indirection.rb +2 -2
- data/lib/puppet/reference/metaparameter.rb +3 -1
- data/lib/puppet/reference/providers.rb +1 -1
- data/lib/puppet/reference/type.rb +9 -3
- data/lib/puppet/reports.rb +3 -3
- data/lib/puppet/resource.rb +22 -22
- data/lib/puppet/resource/catalog.rb +8 -14
- data/lib/puppet/resource/type.rb +1 -10
- data/lib/puppet/rest/client.rb +83 -0
- data/lib/puppet/rest/errors.rb +14 -0
- data/lib/puppet/rest/response.rb +34 -0
- data/lib/puppet/rest/route.rb +84 -0
- data/lib/puppet/rest/routes.rb +154 -0
- data/lib/puppet/rest/ssl_context.rb +13 -0
- data/lib/puppet/settings.rb +9 -54
- data/lib/puppet/settings/config_file.rb +1 -2
- data/lib/puppet/settings/environment_conf.rb +0 -1
- data/lib/puppet/settings/file_setting.rb +1 -1
- data/lib/puppet/settings/server_list_setting.rb +0 -9
- data/lib/puppet/ssl.rb +0 -1
- data/lib/puppet/ssl/base.rb +1 -9
- data/lib/puppet/ssl/certificate.rb +7 -4
- data/lib/puppet/ssl/certificate_request.rb +6 -14
- data/lib/puppet/ssl/certificate_request_attributes.rb +1 -1
- data/lib/puppet/ssl/host.rb +400 -174
- data/lib/puppet/ssl/key.rb +1 -5
- data/lib/puppet/ssl/oids.rb +3 -3
- data/lib/puppet/ssl/validator/default_validator.rb +33 -49
- data/lib/puppet/test/test_helper.rb +12 -18
- data/lib/puppet/transaction.rb +7 -12
- data/lib/puppet/transaction/event.rb +37 -14
- data/lib/puppet/transaction/event_manager.rb +3 -11
- data/lib/puppet/transaction/persistence.rb +1 -1
- data/lib/puppet/transaction/report.rb +1 -1
- data/lib/puppet/transaction/resource_harness.rb +2 -5
- data/lib/puppet/type.rb +7 -10
- data/lib/puppet/type/exec.rb +16 -50
- data/lib/puppet/type/file.rb +7 -16
- data/lib/puppet/type/file/content.rb +2 -3
- data/lib/puppet/type/file/data_sync.rb +1 -5
- data/lib/puppet/type/file/mode.rb +2 -7
- data/lib/puppet/type/file/source.rb +2 -1
- data/lib/puppet/type/filebucket.rb +8 -12
- data/lib/puppet/type/group.rb +3 -33
- data/lib/puppet/type/notify.rb +2 -3
- data/lib/puppet/type/package.rb +18 -154
- data/lib/puppet/type/resources.rb +2 -12
- data/lib/puppet/type/schedule.rb +34 -96
- data/lib/puppet/type/service.rb +10 -9
- data/lib/puppet/type/tidy.rb +1 -1
- data/lib/puppet/type/user.rb +30 -14
- data/lib/puppet/util.rb +28 -52
- data/lib/puppet/util/autoload.rb +62 -56
- data/lib/puppet/util/character_encoding.rb +0 -22
- data/lib/puppet/util/classgen.rb +0 -6
- data/lib/puppet/util/command_line.rb +4 -7
- data/lib/puppet/util/command_line/trollop.rb +1 -1
- data/lib/puppet/util/connection.rb +74 -0
- data/lib/puppet/util/execution.rb +7 -22
- data/lib/puppet/util/feature.rb +63 -41
- data/lib/puppet/util/fileparsing.rb +27 -5
- data/lib/puppet/util/filetype.rb +8 -56
- data/lib/puppet/util/http_proxy.rb +18 -27
- data/lib/puppet/util/instance_loader.rb +3 -21
- data/lib/puppet/util/json.rb +0 -8
- data/lib/puppet/util/ldap/connection.rb +7 -7
- data/lib/puppet/util/log.rb +3 -8
- data/lib/puppet/util/log/destinations.rb +13 -5
- data/lib/puppet/util/logging.rb +19 -31
- data/lib/puppet/util/metric.rb +2 -2
- data/lib/puppet/util/monkey_patches.rb +1 -1
- data/lib/puppet/util/network_device/base.rb +1 -1
- data/lib/puppet/util/pidlock.rb +3 -23
- data/lib/puppet/util/platform.rb +3 -0
- data/lib/puppet/util/plist.rb +0 -6
- data/lib/puppet/util/posix.rb +0 -15
- data/lib/puppet/util/provider_features.rb +6 -7
- data/lib/puppet/util/rdoc.rb +2 -2
- data/lib/puppet/util/rdoc/parser/puppet_parser_core.rb +1 -1
- data/lib/puppet/util/reference.rb +8 -7
- data/lib/puppet/util/resource_template.rb +1 -1
- data/lib/puppet/util/rubygems.rb +1 -13
- data/lib/puppet/util/run_mode.rb +1 -1
- data/lib/puppet/util/selinux.rb +3 -9
- data/lib/puppet/util/ssl.rb +40 -1
- data/lib/puppet/util/storage.rb +1 -13
- data/lib/puppet/util/suidmanager.rb +7 -5
- data/lib/puppet/util/tag_set.rb +1 -1
- data/lib/puppet/util/tagging.rb +1 -1
- data/lib/puppet/util/windows.rb +15 -0
- data/lib/puppet/util/windows/adsi.rb +7 -116
- data/lib/puppet/util/windows/api_types.rb +33 -46
- data/lib/puppet/util/windows/eventlog.rb +6 -1
- data/lib/puppet/util/windows/principal.rb +6 -8
- data/lib/puppet/util/windows/process.rb +3 -94
- data/lib/puppet/util/windows/registry.rb +14 -46
- data/lib/puppet/util/windows/security.rb +2 -40
- data/lib/puppet/util/windows/service.rb +72 -431
- data/lib/puppet/util/windows/sid.rb +3 -4
- data/lib/puppet/util/windows/user.rb +9 -17
- data/lib/puppet/util/yaml.rb +41 -5
- data/lib/puppet/vendor.rb +1 -1
- data/lib/puppet/version.rb +1 -1
- data/lib/puppet_pal.rb +246 -23
- data/locales/ja/puppet.po +11128 -0
- data/locales/puppet.pot +1321 -2527
- data/man/man5/puppet.conf.5 +31 -191
- data/man/man8/puppet-agent.8 +2 -2
- data/man/man8/puppet-apply.8 +1 -1
- data/man/man8/puppet-catalog.8 +1 -1
- data/man/man8/puppet-config.8 +3 -3
- data/man/man8/puppet-describe.8 +1 -1
- data/man/man8/puppet-device.8 +19 -23
- data/man/man8/puppet-doc.8 +1 -1
- data/man/man8/puppet-epp.8 +1 -1
- data/man/man8/puppet-facts.8 +1 -1
- data/man/man8/puppet-filebucket.8 +2 -21
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-key.8 +1 -7
- data/man/man8/puppet-lookup.8 +1 -1
- data/man/man8/puppet-man.8 +1 -1
- data/man/man8/puppet-module.8 +10 -100
- data/man/man8/puppet-node.8 +4 -7
- data/man/man8/puppet-parser.8 +1 -1
- data/man/man8/puppet-plugin.8 +1 -1
- data/man/man8/puppet-report.8 +1 -1
- data/man/man8/puppet-resource.8 +1 -1
- data/man/man8/puppet-script.8 +1 -1
- data/man/man8/puppet-ssl.8 +28 -0
- data/man/man8/puppet-status.8 +1 -1
- data/man/man8/puppet.8 +12 -3
- data/spec/fixtures/unit/functions/hiera/hiera/backend/hieraspec_backend.rb +22 -0
- data/spec/fixtures/unit/functions/lookup/hiera/backend/custom_backend.rb +18 -0
- data/spec/fixtures/unit/functions/lookup/hiera/backend/other_backend.rb +7 -0
- data/spec/fixtures/unit/pops/loaders/loaders/dependent_modules_with_metadata/modules/user/manifests/init.pp +6 -6
- data/spec/fixtures/unit/provider/package/pkgng/pkg.info +0 -1
- data/spec/fixtures/unit/provider/package/pkgng/pkg.version +0 -2
- data/spec/fixtures/unit/provider/service/systemd/list_unit_files_services +0 -9
- data/spec/integration/agent/logging_spec.rb +9 -7
- data/spec/integration/application/apply_spec.rb +31 -26
- data/spec/integration/application/doc_spec.rb +2 -1
- data/spec/integration/application/lookup_spec.rb +5 -5
- data/spec/integration/configurer_spec.rb +8 -76
- data/spec/integration/data_binding_spec.rb +1 -1
- data/spec/integration/defaults_spec.rb +13 -16
- data/spec/integration/directory_environments_spec.rb +1 -1
- data/spec/integration/faces/config_spec.rb +4 -3
- data/spec/integration/faces/documentation_spec.rb +1 -0
- data/spec/integration/faces/plugin_spec.rb +49 -29
- data/spec/integration/file_bucket/file_spec.rb +4 -19
- data/spec/integration/file_serving/content_spec.rb +1 -0
- data/spec/integration/file_serving/fileset_spec.rb +1 -0
- data/spec/integration/file_serving/metadata_spec.rb +1 -0
- data/spec/integration/file_serving/terminus_helper_spec.rb +1 -0
- data/spec/integration/file_system/uniquefile_spec.rb +26 -29
- data/spec/integration/indirector/catalog/compiler_spec.rb +11 -10
- data/spec/integration/indirector/direct_file_server_spec.rb +1 -1
- data/spec/integration/indirector/facts/facter_spec.rb +8 -22
- data/spec/integration/indirector/file_content/file_server_spec.rb +8 -7
- data/spec/integration/indirector/file_metadata/file_server_spec.rb +8 -7
- data/spec/integration/network/authconfig_spec.rb +24 -23
- data/spec/integration/network/formats_spec.rb +1 -0
- data/spec/integration/network/http/api/indirected_routes_spec.rb +6 -34
- data/spec/integration/node/environment_spec.rb +2 -1
- data/spec/integration/node/facts_spec.rb +10 -9
- data/spec/integration/node_spec.rb +7 -10
- data/spec/integration/parser/catalog_spec.rb +8 -6
- data/spec/integration/parser/collection_spec.rb +9 -4
- data/spec/integration/parser/compiler_spec.rb +7 -25
- data/spec/integration/parser/scope_spec.rb +1 -1
- data/spec/integration/parser/undef_param_spec.rb +1 -1
- data/spec/integration/provider/service/init_spec.rb +9 -6
- data/spec/integration/provider/service/systemd_spec.rb +14 -11
- data/spec/integration/provider/service/windows_spec.rb +11 -8
- data/spec/integration/reference/providers_spec.rb +7 -0
- data/spec/integration/reports_spec.rb +2 -1
- data/spec/integration/resource/catalog_spec.rb +17 -14
- data/spec/integration/resource/type_collection_spec.rb +5 -4
- data/spec/integration/ssl/certificate_request_spec.rb +1 -2
- data/spec/integration/ssl/host_spec.rb +17 -24
- data/spec/integration/ssl/key_spec.rb +7 -2
- data/spec/integration/test/test_helper_spec.rb +32 -0
- data/spec/integration/transaction/report_spec.rb +14 -9
- data/spec/integration/type/exec_spec.rb +2 -1
- data/spec/integration/type/file_spec.rb +38 -46
- data/spec/integration/type/package_spec.rb +25 -21
- data/spec/integration/type/tidy_spec.rb +2 -1
- data/spec/integration/type_spec.rb +1 -0
- data/spec/integration/util/autoload_spec.rb +11 -7
- data/spec/integration/util/execution_spec.rb +5 -32
- data/spec/integration/util/rdoc/parser_spec.rb +14 -23
- data/spec/integration/util/settings_spec.rb +2 -1
- data/spec/integration/util/windows/adsi_spec.rb +8 -11
- data/spec/integration/util/windows/principal_spec.rb +2 -1
- data/spec/integration/util/windows/process_spec.rb +9 -7
- data/spec/integration/util/windows/registry_spec.rb +46 -127
- data/spec/integration/util/windows/security_spec.rb +15 -16
- data/spec/integration/util/windows/user_spec.rb +29 -66
- data/spec/integration/util_spec.rb +10 -7
- data/spec/lib/matchers/json.rb +12 -18
- data/{lib/puppet/ssl → spec/lib/puppet}/certificate_factory.rb +5 -6
- data/spec/lib/puppet/test_ca.rb +109 -0
- data/spec/lib/puppet_spec/compiler.rb +28 -1
- data/spec/lib/puppet_spec/files.rb +29 -23
- data/spec/lib/puppet_spec/module_tool/shared_functions.rb +1 -1
- data/spec/lib/puppet_spec/modules.rb +11 -1
- data/spec/lib/puppet_spec/scope.rb +2 -1
- data/spec/lib/puppet_spec/ssl.rb +265 -0
- data/spec/lib/puppet_spec/validators.rb +37 -0
- data/spec/shared_behaviours/all_parsedfile_providers.rb +1 -1
- data/spec/shared_behaviours/file_server_terminus.rb +9 -8
- data/spec/shared_behaviours/file_serving.rb +8 -6
- data/spec/shared_behaviours/file_serving_model.rb +5 -22
- data/spec/shared_behaviours/hiera_indirections.rb +4 -3
- data/spec/shared_behaviours/iterative_functions.rb +1 -0
- data/spec/shared_behaviours/memory_terminus.rb +2 -2
- data/spec/shared_behaviours/path_parameters.rb +1 -1
- data/spec/shared_contexts/types_setup.rb +0 -2
- data/spec/shared_examples/rhel_package_provider.rb +70 -112
- data/spec/spec_helper.rb +1 -15
- data/spec/unit/agent/disabler_spec.rb +5 -4
- data/spec/unit/agent/locker_spec.rb +13 -12
- data/spec/unit/agent_spec.rb +102 -105
- data/spec/unit/application/agent_spec.rb +95 -114
- data/spec/unit/application/apply_spec.rb +92 -119
- data/spec/unit/application/config_spec.rb +1 -0
- data/spec/unit/application/describe_spec.rb +7 -6
- data/spec/unit/application/device_spec.rb +180 -181
- data/spec/unit/application/doc_spec.rb +46 -44
- data/spec/unit/application/face_base_spec.rb +62 -61
- data/spec/unit/application/facts_spec.rb +4 -3
- data/spec/unit/application/filebucket_spec.rb +74 -66
- data/spec/unit/application/indirection_base_spec.rb +6 -8
- data/spec/unit/application/lookup_spec.rb +44 -37
- data/spec/unit/application/resource_spec.rb +48 -42
- data/spec/unit/application/ssl_spec.rb +322 -0
- data/spec/unit/application_spec.rb +108 -90
- data/spec/unit/capability_spec.rb +15 -16
- data/spec/unit/{ssl/certificate_factory_spec.rb → certificate_factory_spec.rb} +13 -20
- data/spec/unit/configurer/downloader_spec.rb +22 -31
- data/spec/unit/configurer/fact_handler_spec.rb +7 -2
- data/spec/unit/configurer/plugin_handler_spec.rb +8 -41
- data/spec/unit/configurer_spec.rb +475 -520
- data/spec/unit/confine/exists_spec.rb +15 -17
- data/spec/unit/confine/false_spec.rb +6 -32
- data/spec/unit/confine/feature_spec.rb +5 -7
- data/spec/unit/confine/true_spec.rb +6 -32
- data/spec/unit/confine/variable_spec.rb +15 -14
- data/spec/unit/confine_collection_spec.rb +29 -28
- data/spec/unit/confine_spec.rb +14 -13
- data/spec/unit/confiner_spec.rb +11 -10
- data/spec/unit/context/trusted_information_spec.rb +4 -3
- data/spec/unit/daemon_spec.rb +38 -35
- data/spec/unit/data_providers/function_data_provider_spec.rb +1 -0
- data/spec/unit/data_providers/hiera_data_provider_spec.rb +1 -0
- data/spec/unit/datatypes_spec.rb +4 -3
- data/spec/unit/defaults_spec.rb +61 -32
- data/spec/unit/environments_spec.rb +7 -7
- data/spec/unit/etc_spec.rb +29 -52
- data/spec/unit/external/pson_spec.rb +1 -0
- data/spec/unit/face/catalog_spec.rb +1 -0
- data/spec/unit/face/config_spec.rb +35 -31
- data/spec/unit/face/epp_face_spec.rb +4 -3
- data/spec/unit/face/facts_spec.rb +6 -14
- data/spec/unit/face/generate_spec.rb +5 -4
- data/spec/unit/face/help_spec.rb +8 -7
- data/spec/unit/face/key_spec.rb +1 -0
- data/spec/unit/face/man_spec.rb +2 -1
- data/spec/unit/face/module/install_spec.rb +5 -3
- data/spec/unit/face/module/list_spec.rb +12 -62
- data/spec/unit/face/module/search_spec.rb +9 -11
- data/spec/unit/face/module/uninstall_spec.rb +8 -4
- data/spec/unit/face/node_spec.rb +30 -52
- data/spec/unit/face/parser_spec.rb +3 -3
- data/spec/unit/face/plugin_spec.rb +9 -44
- data/spec/unit/face/status_spec.rb +1 -0
- data/spec/unit/file_bucket/dipper_spec.rb +24 -28
- data/spec/unit/file_bucket/file_spec.rb +2 -0
- data/spec/unit/file_serving/base_spec.rb +18 -20
- data/spec/unit/file_serving/configuration/parser_spec.rb +28 -27
- data/spec/unit/file_serving/configuration_spec.rb +66 -63
- data/spec/unit/file_serving/content_spec.rb +11 -10
- data/spec/unit/file_serving/fileset_spec.rb +58 -63
- data/spec/unit/file_serving/http_metadata_spec.rb +7 -8
- data/spec/unit/file_serving/metadata_spec.rb +40 -40
- data/spec/unit/file_serving/mount/file_spec.rb +32 -31
- data/spec/unit/file_serving/mount/locales_spec.rb +26 -25
- data/spec/unit/file_serving/mount/modules_spec.rb +15 -14
- data/spec/unit/file_serving/mount/pluginfacts_spec.rb +26 -25
- data/spec/unit/file_serving/mount/plugins_spec.rb +26 -25
- data/spec/unit/file_serving/mount/tasks_spec.rb +15 -14
- data/spec/unit/file_serving/mount_spec.rb +1 -0
- data/spec/unit/file_serving/terminus_helper_spec.rb +42 -37
- data/spec/unit/file_serving/terminus_selector_spec.rb +13 -12
- data/spec/unit/file_system/path_pattern_spec.rb +1 -1
- data/spec/unit/file_system/uniquefile_spec.rb +6 -17
- data/spec/unit/file_system_spec.rb +9 -6
- data/spec/unit/forge/errors_spec.rb +1 -1
- data/spec/unit/forge/forge_spec.rb +16 -15
- data/spec/unit/forge/module_release_spec.rb +18 -18
- data/spec/unit/forge/repository_spec.rb +30 -27
- data/spec/unit/forge_spec.rb +11 -15
- data/spec/unit/functions/abs_spec.rb +70 -0
- data/spec/unit/functions/binary_file_spec.rb +3 -3
- data/spec/unit/functions/call_spec.rb +59 -5
- data/spec/unit/functions/camelcase_spec.rb +34 -0
- data/spec/unit/functions/capitalize_spec.rb +34 -0
- data/spec/unit/functions/ceiling_spec.rb +65 -0
- data/spec/unit/functions/chomp_spec.rb +46 -0
- data/spec/unit/functions/chop_spec.rb +38 -0
- data/spec/unit/functions/compare_spec.rb +147 -0
- data/spec/unit/functions/contain_spec.rb +2 -0
- data/spec/unit/functions/convert_to_spec.rb +3 -0
- data/spec/unit/functions/defined_spec.rb +1 -0
- data/spec/unit/functions/downcase_spec.rb +34 -0
- data/spec/unit/functions/epp_spec.rb +2 -2
- data/spec/unit/functions/filter_spec.rb +4 -4
- data/spec/unit/functions/find_file_spec.rb +7 -7
- data/spec/unit/functions/floor_spec.rb +65 -0
- data/spec/unit/functions/get_spec.rb +135 -0
- data/spec/unit/functions/getvar_spec.rb +121 -0
- data/spec/unit/functions/hiera_spec.rb +14 -48
- data/spec/unit/functions/include_spec.rb +4 -0
- data/spec/unit/functions/lookup_fixture_spec.rb +1 -0
- data/spec/unit/functions/lookup_spec.rb +37 -62
- data/spec/unit/functions/lstrip_spec.rb +30 -0
- data/spec/unit/functions/match_spec.rb +3 -4
- data/spec/unit/functions/max_spec.rb +129 -0
- data/spec/unit/functions/min_spec.rb +129 -0
- data/spec/unit/functions/module_directory_spec.rb +12 -12
- data/spec/unit/functions/new_spec.rb +0 -15
- data/spec/unit/functions/regsubst_spec.rb +3 -4
- data/spec/unit/functions/require_spec.rb +3 -0
- data/spec/unit/functions/round_spec.rb +41 -0
- data/spec/unit/functions/rstrip_spec.rb +30 -0
- data/spec/unit/functions/shared.rb +8 -5
- data/spec/unit/functions/size_spec.rb +50 -0
- data/spec/unit/functions/sort_spec.rb +79 -0
- data/spec/unit/functions/split_spec.rb +3 -4
- data/spec/unit/functions/strip_spec.rb +30 -0
- data/spec/unit/functions/upcase_spec.rb +34 -0
- data/spec/unit/functions/versioncmp_spec.rb +4 -4
- data/spec/unit/functions4_spec.rb +78 -51
- data/spec/unit/gettext/config_spec.rb +4 -4
- data/spec/unit/gettext/module_loading_spec.rb +7 -7
- data/spec/unit/graph/rb_tree_map_spec.rb +2 -0
- data/spec/unit/graph/relationship_graph_spec.rb +2 -1
- data/spec/unit/graph/simple_graph_spec.rb +52 -11
- data/spec/unit/hiera/scope_spec.rb +0 -7
- data/spec/unit/hiera_puppet_spec.rb +20 -20
- data/spec/unit/indirector/catalog/compiler_spec.rb +166 -183
- data/spec/unit/indirector/catalog/json_spec.rb +2 -1
- data/spec/unit/indirector/catalog/msgpack_spec.rb +1 -0
- data/spec/unit/indirector/catalog/rest_spec.rb +1 -0
- data/spec/unit/indirector/catalog/store_configs_spec.rb +1 -0
- data/spec/unit/indirector/catalog/yaml_spec.rb +1 -0
- data/spec/unit/indirector/certificate/file_spec.rb +1 -8
- data/spec/unit/indirector/certificate/rest_spec.rb +10 -8
- data/spec/unit/indirector/certificate_request/file_spec.rb +1 -0
- data/spec/unit/indirector/certificate_request/rest_spec.rb +1 -0
- data/spec/unit/indirector/direct_file_server_spec.rb +49 -57
- data/spec/unit/indirector/envelope_spec.rb +2 -1
- data/spec/unit/indirector/exec_spec.rb +31 -26
- data/spec/unit/indirector/face_spec.rb +9 -9
- data/spec/unit/indirector/facts/facter_spec.rb +43 -37
- data/spec/unit/indirector/facts/network_device_spec.rb +9 -8
- data/spec/unit/indirector/facts/rest_spec.rb +8 -7
- data/spec/unit/indirector/facts/store_configs_spec.rb +1 -0
- data/spec/unit/indirector/facts/yaml_spec.rb +90 -77
- data/spec/unit/indirector/file_bucket_file/file_spec.rb +13 -9
- data/spec/unit/indirector/file_bucket_file/rest_spec.rb +1 -0
- data/spec/unit/indirector/file_bucket_file/selector_spec.rb +5 -4
- data/spec/unit/indirector/file_content/file_server_spec.rb +1 -0
- data/spec/unit/indirector/file_content/file_spec.rb +1 -0
- data/spec/unit/indirector/file_content/rest_spec.rb +1 -0
- data/spec/unit/indirector/file_content/selector_spec.rb +1 -0
- data/spec/unit/indirector/file_metadata/file_server_spec.rb +1 -0
- data/spec/unit/indirector/file_metadata/file_spec.rb +13 -12
- data/spec/unit/indirector/file_metadata/rest_spec.rb +1 -0
- data/spec/unit/indirector/file_metadata/selector_spec.rb +1 -0
- data/spec/unit/indirector/file_server_spec.rb +145 -145
- data/spec/unit/indirector/indirection_spec.rb +226 -249
- data/spec/unit/indirector/json_spec.rb +9 -7
- data/spec/unit/indirector/key/file_spec.rb +22 -38
- data/spec/unit/indirector/memory_spec.rb +7 -6
- data/spec/unit/indirector/msgpack_spec.rb +9 -7
- data/spec/unit/indirector/node/exec_spec.rb +43 -22
- data/spec/unit/indirector/node/memory_spec.rb +4 -2
- data/spec/unit/indirector/node/msgpack_spec.rb +1 -0
- data/spec/unit/indirector/node/plain_spec.rb +4 -2
- data/spec/unit/indirector/node/rest_spec.rb +1 -0
- data/spec/unit/indirector/node/store_configs_spec.rb +1 -0
- data/spec/unit/indirector/node/yaml_spec.rb +1 -0
- data/spec/unit/indirector/none_spec.rb +5 -5
- data/spec/unit/indirector/plain_spec.rb +8 -7
- data/spec/unit/indirector/report/msgpack_spec.rb +1 -0
- data/spec/unit/indirector/report/processor_spec.rb +22 -21
- data/spec/unit/indirector/report/rest_spec.rb +12 -11
- data/spec/unit/indirector/report/yaml_spec.rb +1 -0
- data/spec/unit/indirector/request_spec.rb +18 -15
- data/spec/unit/indirector/resource/ral_spec.rb +55 -47
- data/spec/unit/indirector/resource/store_configs_spec.rb +1 -0
- data/spec/unit/indirector/rest_spec.rb +110 -113
- data/spec/unit/indirector/ssl_file_spec.rb +100 -119
- data/spec/unit/indirector/status/local_spec.rb +1 -0
- data/spec/unit/indirector/status/rest_spec.rb +1 -0
- data/spec/unit/indirector/store_configs_spec.rb +1 -0
- data/spec/unit/indirector/terminus_spec.rb +30 -32
- data/spec/unit/indirector/yaml_spec.rb +90 -68
- data/spec/unit/indirector_spec.rb +2 -1
- data/spec/unit/info_service_spec.rb +144 -10
- data/spec/unit/interface/action_builder_spec.rb +1 -0
- data/spec/unit/interface/action_manager_spec.rb +1 -0
- data/spec/unit/interface/action_spec.rb +3 -2
- data/spec/unit/interface/documentation_spec.rb +1 -0
- data/spec/unit/interface/face_collection_spec.rb +12 -19
- data/spec/unit/interface_spec.rb +3 -3
- data/spec/unit/man_spec.rb +4 -3
- data/spec/unit/module_spec.rb +52 -102
- data/spec/unit/module_tool/applications/installer_spec.rb +13 -12
- data/spec/unit/module_tool/applications/searcher_spec.rb +3 -3
- data/spec/unit/module_tool/applications/uninstaller_spec.rb +2 -1
- data/spec/unit/module_tool/applications/unpacker_spec.rb +13 -13
- data/spec/unit/module_tool/applications/upgrader_spec.rb +6 -6
- data/spec/unit/module_tool/install_directory_spec.rb +8 -8
- data/spec/unit/module_tool/installed_modules_spec.rb +3 -3
- data/spec/unit/module_tool/tar/gnu_spec.rb +6 -6
- data/spec/unit/module_tool/tar/mini_spec.rb +12 -12
- data/spec/unit/module_tool/tar_spec.rb +13 -12
- data/spec/unit/module_tool_spec.rb +12 -29
- data/spec/unit/network/auth_config_parser_spec.rb +13 -11
- data/spec/unit/network/authconfig_spec.rb +18 -17
- data/spec/unit/network/authorization_spec.rb +5 -4
- data/spec/unit/network/authstore_spec.rb +1 -0
- data/spec/unit/network/format_handler_spec.rb +1 -0
- data/spec/unit/network/format_spec.rb +10 -9
- data/spec/unit/network/format_support_spec.rb +29 -28
- data/spec/unit/network/formats_spec.rb +31 -4
- data/spec/unit/network/http/api/indirected_routes_spec.rb +41 -51
- data/spec/unit/network/http/api/master/v3/authorization_spec.rb +7 -9
- data/spec/unit/network/http/api/master/v3/environment_spec.rb +1 -2
- data/spec/unit/network/http/api/master/v3/environments_spec.rb +7 -6
- data/spec/unit/network/http/api_spec.rb +2 -26
- data/spec/unit/network/http/compression_spec.rb +28 -24
- data/spec/unit/network/http/connection_spec.rb +122 -72
- data/spec/unit/network/http/factory_spec.rb +11 -40
- data/spec/unit/network/http/handler_spec.rb +18 -9
- data/spec/unit/network/http/nocache_pool_spec.rb +7 -6
- data/spec/unit/network/http/pool_spec.rb +29 -60
- data/spec/unit/network/http/request_spec.rb +2 -0
- data/spec/unit/network/http/response_spec.rb +13 -11
- data/spec/unit/network/http/route_spec.rb +1 -0
- data/spec/unit/network/http/session_spec.rb +2 -1
- data/spec/unit/network/http/site_spec.rb +1 -0
- data/spec/unit/network/http_pool_spec.rb +9 -18
- data/spec/unit/network/http_spec.rb +1 -0
- data/spec/unit/network/resolver_spec.rb +104 -28
- data/spec/unit/network/rights_spec.rb +53 -52
- data/spec/unit/node/environment_spec.rb +17 -18
- data/spec/unit/node/facts_spec.rb +21 -6
- data/spec/unit/node_spec.rb +23 -17
- data/spec/unit/other/selinux_spec.rb +1 -71
- data/spec/unit/parameter/boolean_spec.rb +2 -1
- data/spec/unit/parameter/package_options_spec.rb +2 -1
- data/spec/unit/parameter/path_spec.rb +1 -0
- data/spec/unit/parameter/value_collection_spec.rb +1 -0
- data/spec/unit/parameter/value_spec.rb +1 -0
- data/spec/unit/parameter_spec.rb +9 -9
- data/spec/unit/parser/ast/block_expression_spec.rb +8 -6
- data/spec/unit/parser/ast/leaf_spec.rb +21 -20
- data/spec/unit/parser/compiler_spec.rb +96 -84
- data/spec/unit/parser/environment_compiler_spec.rb +16 -23
- data/spec/unit/parser/files_spec.rb +1 -0
- data/spec/unit/parser/functions/create_resources_spec.rb +1 -1
- data/spec/unit/parser/functions/digest_spec.rb +1 -4
- data/spec/unit/parser/functions/fail_spec.rb +2 -5
- data/spec/unit/parser/functions/file_spec.rb +14 -17
- data/spec/unit/parser/functions/fqdn_rand_spec.rb +6 -5
- data/spec/unit/parser/functions/generate_spec.rb +37 -38
- data/spec/unit/parser/functions/inline_template_spec.rb +1 -4
- data/spec/unit/parser/functions/regsubst_spec.rb +1 -4
- data/spec/unit/parser/functions/scanf_spec.rb +1 -4
- data/spec/unit/parser/functions/shellquote_spec.rb +1 -0
- data/spec/unit/parser/functions/split_spec.rb +1 -4
- data/spec/unit/parser/functions/sprintf_spec.rb +1 -4
- data/spec/unit/parser/functions/tag_spec.rb +2 -5
- data/spec/unit/parser/functions/tagged_spec.rb +3 -6
- data/spec/unit/parser/functions/template_spec.rb +13 -17
- data/spec/unit/parser/functions/versioncmp_spec.rb +2 -5
- data/spec/unit/parser/functions_spec.rb +29 -3
- data/spec/unit/parser/relationship_spec.rb +1 -0
- data/spec/unit/parser/resource/param_spec.rb +1 -1
- data/spec/unit/parser/resource_spec.rb +42 -42
- data/spec/unit/parser/scope_spec.rb +35 -39
- data/spec/unit/parser/templatewrapper_spec.rb +12 -11
- data/spec/unit/parser/type_loader_spec.rb +19 -17
- data/spec/unit/pops/adaptable_spec.rb +1 -0
- data/spec/unit/pops/benchmark_spec.rb +1 -0
- data/spec/unit/pops/evaluator/access_ops_spec.rb +1 -0
- data/spec/unit/pops/evaluator/arithmetic_ops_spec.rb +11 -0
- data/spec/unit/pops/evaluator/basic_expressions_spec.rb +1 -0
- data/spec/unit/pops/evaluator/collections_ops_spec.rb +1 -0
- data/spec/unit/pops/evaluator/comparison_ops_spec.rb +1 -0
- data/spec/unit/pops/evaluator/conditionals_spec.rb +1 -0
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +78 -18
- data/spec/unit/pops/evaluator/logical_ops_spec.rb +1 -0
- data/spec/unit/pops/evaluator/runtime3_converter_spec.rb +5 -4
- data/spec/unit/pops/evaluator/string_interpolation_spec.rb +1 -0
- data/spec/unit/pops/evaluator/variables_spec.rb +1 -0
- data/spec/unit/pops/factory_spec.rb +4 -3
- data/spec/unit/pops/issues_spec.rb +20 -19
- data/spec/unit/pops/loaders/dependency_loader_spec.rb +2 -2
- data/spec/unit/pops/loaders/loader_spec.rb +12 -36
- data/spec/unit/pops/loaders/loaders_spec.rb +57 -54
- data/spec/unit/pops/loaders/module_loaders_spec.rb +35 -3
- data/spec/unit/pops/loaders/static_loader_spec.rb +0 -36
- data/spec/unit/pops/lookup/context_spec.rb +1 -0
- data/spec/unit/pops/lookup/interpolation_spec.rb +3 -2
- data/spec/unit/pops/merge_strategy_spec.rb +1 -0
- data/spec/unit/pops/migration_spec.rb +5 -3
- data/spec/unit/pops/model/model_spec.rb +1 -0
- data/spec/unit/pops/model/pn_transformer_spec.rb +1 -0
- data/spec/unit/pops/parser/lexer2_spec.rb +60 -21
- data/spec/unit/pops/parser/locator_spec.rb +6 -48
- data/spec/unit/pops/parser/parse_application_spec.rb +1 -0
- data/spec/unit/pops/parser/parse_basic_expressions_spec.rb +1 -0
- data/spec/unit/pops/parser/parse_calls_spec.rb +1 -0
- data/spec/unit/pops/parser/parse_capabilities_spec.rb +1 -0
- data/spec/unit/pops/parser/parse_conditionals_spec.rb +1 -0
- data/spec/unit/pops/parser/parse_containers_spec.rb +1 -0
- data/spec/unit/pops/parser/parse_heredoc_spec.rb +12 -124
- data/spec/unit/pops/parser/parse_plan_spec.rb +1 -0
- data/spec/unit/pops/parser/parse_resource_spec.rb +1 -0
- data/spec/unit/pops/parser/parse_site_spec.rb +1 -0
- data/spec/unit/pops/parser/pn_parser_spec.rb +1 -0
- data/spec/unit/pops/pn_spec.rb +1 -0
- data/spec/unit/pops/resource/resource_type_impl_spec.rb +1 -0
- data/spec/unit/pops/serialization/serialization_spec.rb +7 -5
- data/spec/unit/pops/serialization/to_from_hr_spec.rb +29 -4
- data/spec/unit/pops/serialization/to_stringified_spec.rb +157 -0
- data/spec/unit/pops/types/deferred_spec.rb +87 -0
- data/spec/unit/pops/types/p_object_type_spec.rb +20 -0
- data/spec/unit/pops/types/p_timespan_type_spec.rb +0 -22
- data/spec/unit/pops/types/p_timestamp_type_spec.rb +0 -19
- data/spec/unit/pops/types/recursion_guard_spec.rb +10 -10
- data/spec/unit/pops/types/ruby_generator_spec.rb +2 -2
- data/spec/unit/pops/types/string_converter_spec.rb +11 -22
- data/spec/unit/pops/types/task_spec.rb +148 -16
- data/spec/unit/pops/types/type_asserter_spec.rb +2 -2
- data/spec/unit/pops/types/type_calculator_spec.rb +36 -36
- data/spec/unit/pops/types/type_mismatch_describer_spec.rb +0 -9
- data/spec/unit/pops/types/type_parser_spec.rb +13 -13
- data/spec/unit/pops/types/types_spec.rb +12 -6
- data/spec/unit/pops/validator/validator_spec.rb +162 -82
- data/spec/unit/pops/visitor_spec.rb +1 -0
- data/spec/unit/property/boolean_spec.rb +1 -1
- data/spec/unit/property/ensure_spec.rb +1 -0
- data/spec/unit/property/keyvalue_spec.rb +34 -32
- data/spec/unit/property/list_spec.rb +27 -26
- data/spec/unit/property/ordered_list_spec.rb +14 -10
- data/spec/unit/property_spec.rb +53 -43
- data/spec/unit/provider/aix_object_spec.rb +45 -47
- data/spec/unit/provider/command_spec.rb +9 -9
- data/spec/unit/provider/exec/posix_spec.rb +9 -8
- data/spec/unit/provider/exec/shell_spec.rb +3 -1
- data/spec/unit/provider/exec/windows_spec.rb +6 -4
- data/spec/unit/provider/exec_spec.rb +1 -209
- data/spec/unit/provider/file/posix_spec.rb +24 -22
- data/spec/unit/provider/file/windows_spec.rb +19 -17
- data/spec/unit/provider/group/aix_spec.rb +7 -22
- data/spec/unit/provider/group/groupadd_spec.rb +27 -60
- data/spec/unit/provider/group/ldap_spec.rb +36 -33
- data/spec/unit/provider/group/pw_spec.rb +18 -15
- data/spec/unit/provider/group/windows_adsi_spec.rb +80 -128
- data/spec/unit/provider/ldap_spec.rb +62 -61
- data/spec/unit/provider/nameservice/directoryservice_spec.rb +109 -102
- data/spec/unit/provider/nameservice_spec.rb +41 -39
- data/spec/unit/provider/package/aix_spec.rb +22 -48
- data/spec/unit/provider/package/appdmg_spec.rb +13 -13
- data/spec/unit/provider/package/apt_spec.rb +35 -60
- data/spec/unit/provider/package/aptitude_spec.rb +7 -7
- data/spec/unit/provider/package/aptrpm_spec.rb +13 -8
- data/spec/unit/provider/package/base_spec.rb +4 -4
- data/spec/unit/provider/package/dnf_spec.rb +23 -34
- data/spec/unit/provider/package/dpkg_spec.rb +72 -114
- data/spec/unit/provider/package/freebsd_spec.rb +18 -15
- data/spec/unit/provider/package/gem_spec.rb +86 -163
- data/spec/unit/provider/package/hpux_spec.rb +18 -15
- data/spec/unit/provider/package/macports_spec.rb +54 -56
- data/spec/unit/provider/package/nim_spec.rb +49 -33
- data/spec/unit/provider/package/openbsd_spec.rb +49 -60
- data/spec/unit/provider/package/opkg_spec.rb +26 -23
- data/spec/unit/provider/package/pacman_spec.rb +118 -97
- data/spec/unit/provider/package/pip3_spec.rb +6 -20
- data/spec/unit/provider/package/pip_spec.rb +129 -185
- data/spec/unit/provider/package/pkg_spec.rb +119 -129
- data/spec/unit/provider/package/pkgdmg_spec.rb +63 -65
- data/spec/unit/provider/package/pkgin_spec.rb +23 -20
- data/spec/unit/provider/package/pkgng_spec.rb +35 -67
- data/spec/unit/provider/package/pkgutil_spec.rb +49 -45
- data/spec/unit/provider/package/portage_spec.rb +76 -72
- data/spec/unit/provider/package/puppet_gem_spec.rb +21 -45
- data/spec/unit/provider/package/rpm_spec.rb +79 -291
- data/spec/unit/provider/package/sun_spec.rb +18 -16
- data/spec/unit/provider/package/tdnf_spec.rb +12 -9
- data/spec/unit/provider/package/up2date_spec.rb +4 -2
- data/spec/unit/provider/package/urpmi_spec.rb +17 -15
- data/spec/unit/provider/package/windows/exe_package_spec.rb +18 -15
- data/spec/unit/provider/package/windows/msi_package_spec.rb +23 -20
- data/spec/unit/provider/package/windows/package_spec.rb +43 -38
- data/spec/unit/provider/package/windows_spec.rb +36 -51
- data/spec/unit/provider/package/yum_spec.rb +24 -128
- data/spec/unit/provider/package/zypper_spec.rb +106 -117
- data/spec/unit/provider/parsedfile_spec.rb +45 -44
- data/spec/unit/provider/service/base_spec.rb +6 -5
- data/spec/unit/provider/service/bsd_spec.rb +54 -47
- data/spec/unit/provider/service/daemontools_spec.rb +53 -70
- data/spec/unit/provider/service/debian_spec.rb +58 -46
- data/spec/unit/provider/service/freebsd_spec.rb +23 -20
- data/spec/unit/provider/service/gentoo_spec.rb +81 -74
- data/spec/unit/provider/service/init_spec.rb +66 -65
- data/spec/unit/provider/service/launchd_spec.rb +114 -181
- data/spec/unit/provider/service/openbsd_spec.rb +94 -87
- data/spec/unit/provider/service/openrc_spec.rb +74 -70
- data/spec/unit/provider/service/openwrt_spec.rb +38 -30
- data/spec/unit/provider/service/rcng_spec.rb +24 -19
- data/spec/unit/provider/service/redhat_spec.rb +60 -60
- data/spec/unit/provider/service/runit_spec.rb +44 -61
- data/spec/unit/provider/service/smf_spec.rb +74 -143
- data/spec/unit/provider/service/src_spec.rb +69 -60
- data/spec/unit/provider/service/systemd_spec.rb +160 -222
- data/spec/unit/provider/service/upstart_spec.rb +99 -83
- data/spec/unit/provider/service/windows_spec.rb +42 -84
- data/spec/unit/provider/user/aix_spec.rb +24 -65
- data/spec/unit/provider/user/directoryservice_spec.rb +114 -187
- data/spec/unit/provider/user/hpux_spec.rb +21 -17
- data/spec/unit/provider/user/ldap_spec.rb +83 -80
- data/spec/unit/provider/user/openbsd_spec.rb +12 -11
- data/spec/unit/provider/user/pw_spec.rb +44 -80
- data/spec/unit/provider/user/user_role_add_spec.rb +94 -94
- data/spec/unit/provider/user/useradd_spec.rb +100 -208
- data/spec/unit/provider/user/windows_adsi_spec.rb +63 -62
- data/spec/unit/provider_spec.rb +189 -41
- data/spec/unit/puppet_pal_2pec.rb +26 -12
- data/spec/unit/puppet_pal_catalog_spec.rb +801 -0
- data/spec/unit/puppet_pal_spec.rb +2 -8
- data/spec/unit/puppet_spec.rb +7 -27
- data/spec/unit/relationship_spec.rb +1 -0
- data/spec/unit/reports/http_spec.rb +23 -21
- data/spec/unit/reports/store_spec.rb +4 -3
- data/spec/unit/reports_spec.rb +14 -12
- data/spec/unit/resource/capability_finder_spec.rb +26 -29
- data/spec/unit/resource/catalog_spec.rb +77 -81
- data/spec/unit/resource/status_spec.rb +8 -6
- data/spec/unit/resource/type_collection_spec.rb +18 -17
- data/spec/unit/resource/type_spec.rb +35 -34
- data/spec/unit/resource_spec.rb +79 -67
- data/spec/unit/rest/client_spec.rb +135 -0
- data/spec/unit/rest/route_spec.rb +132 -0
- data/spec/unit/scheduler/job_spec.rb +1 -0
- data/spec/unit/scheduler/scheduler_spec.rb +1 -0
- data/spec/unit/scheduler/splay_job_spec.rb +2 -1
- data/spec/unit/settings/array_setting_spec.rb +1 -1
- data/spec/unit/settings/autosign_setting_spec.rb +9 -9
- data/spec/unit/settings/certificate_revocation_setting_spec.rb +1 -1
- data/spec/unit/settings/config_file_spec.rb +10 -0
- data/spec/unit/settings/directory_setting_spec.rb +7 -2
- data/spec/unit/settings/duration_setting_spec.rb +2 -1
- data/spec/unit/settings/enum_setting_spec.rb +1 -1
- data/spec/unit/settings/environment_conf_spec.rb +6 -4
- data/spec/unit/settings/file_setting_spec.rb +50 -46
- data/spec/unit/settings/ini_file_spec.rb +2 -4
- data/spec/unit/settings/path_setting_spec.rb +3 -2
- data/spec/unit/settings/priority_setting_spec.rb +2 -1
- data/spec/unit/settings/string_setting_spec.rb +15 -14
- data/spec/unit/settings/terminus_setting_spec.rb +2 -1
- data/spec/unit/settings/value_translator_spec.rb +1 -0
- data/spec/unit/settings_spec.rb +226 -253
- data/spec/unit/ssl/base_spec.rb +15 -14
- data/spec/unit/ssl/certificate_request_attributes_spec.rb +22 -8
- data/spec/unit/ssl/certificate_request_spec.rb +63 -92
- data/spec/unit/ssl/certificate_spec.rb +29 -37
- data/spec/unit/ssl/digest_spec.rb +1 -0
- data/spec/unit/ssl/host_spec.rb +305 -685
- data/spec/unit/ssl/key_spec.rb +34 -46
- data/spec/unit/ssl/validator_spec.rb +70 -203
- data/spec/unit/task_spec.rb +172 -26
- data/spec/unit/transaction/additional_resource_generator_spec.rb +68 -67
- data/spec/unit/transaction/event_manager_spec.rb +84 -95
- data/spec/unit/transaction/event_spec.rb +15 -16
- data/spec/unit/transaction/persistence_spec.rb +18 -17
- data/spec/unit/transaction/report_spec.rb +24 -18
- data/spec/unit/transaction/resource_harness_spec.rb +33 -72
- data/spec/unit/transaction_spec.rb +106 -176
- data/spec/unit/type/component_spec.rb +1 -0
- data/spec/unit/type/exec_spec.rb +66 -120
- data/spec/unit/type/file/checksum_spec.rb +11 -10
- data/spec/unit/type/file/checksum_value_spec.rb +32 -31
- data/spec/unit/type/file/content_spec.rb +62 -65
- data/spec/unit/type/file/ctime_spec.rb +1 -0
- data/spec/unit/type/file/ensure_spec.rb +13 -12
- data/spec/unit/type/file/group_spec.rb +7 -5
- data/spec/unit/type/file/mode_spec.rb +6 -4
- data/spec/unit/type/file/mtime_spec.rb +1 -0
- data/spec/unit/type/file/owner_spec.rb +8 -6
- data/spec/unit/type/file/selinux_spec.rb +19 -17
- data/spec/unit/type/file/source_spec.rb +110 -113
- data/spec/unit/type/file/type_spec.rb +1 -0
- data/spec/unit/type/file_spec.rb +190 -204
- data/spec/unit/type/filebucket_spec.rb +10 -11
- data/spec/unit/type/group_spec.rb +9 -15
- data/spec/unit/type/noop_metaparam_spec.rb +2 -1
- data/spec/unit/type/package/package_settings_spec.rb +23 -44
- data/spec/unit/type/package_spec.rb +64 -61
- data/spec/unit/type/resources_spec.rb +101 -103
- data/spec/unit/type/schedule_spec.rb +28 -28
- data/spec/unit/type/service_spec.rb +85 -76
- data/spec/unit/type/stage_spec.rb +1 -0
- data/spec/unit/type/tidy_spec.rb +63 -62
- data/spec/unit/type/user_spec.rb +26 -147
- data/spec/unit/type/whit_spec.rb +1 -0
- data/spec/unit/type_spec.rb +164 -125
- data/spec/unit/util/at_fork_spec.rb +19 -18
- data/spec/unit/util/autoload_spec.rb +122 -93
- data/spec/unit/util/backups_spec.rb +35 -34
- data/spec/unit/util/character_encoding_spec.rb +5 -48
- data/spec/unit/util/checksums_spec.rb +39 -38
- data/spec/unit/util/colors_spec.rb +2 -1
- data/spec/unit/util/command_line_spec.rb +20 -40
- data/spec/unit/util/constant_inflector_spec.rb +1 -0
- data/spec/unit/util/diff_spec.rb +8 -7
- data/spec/unit/util/errors_spec.rb +1 -0
- data/spec/unit/util/execution_spec.rb +167 -285
- data/spec/unit/util/execution_stub_spec.rb +3 -2
- data/spec/unit/util/feature_spec.rb +46 -28
- data/spec/unit/util/filetype_spec.rb +53 -61
- data/spec/unit/util/http_proxy_spec.rb +13 -133
- data/spec/unit/util/inifile_spec.rb +31 -26
- data/spec/unit/util/json_lockfile_spec.rb +5 -3
- data/spec/unit/util/ldap/connection_spec.rb +25 -26
- data/spec/unit/util/ldap/generator_spec.rb +1 -0
- data/spec/unit/util/ldap/manager_spec.rb +102 -118
- data/spec/unit/util/lockfile_spec.rb +2 -1
- data/spec/unit/util/log/destinations_spec.rb +40 -23
- data/spec/unit/util/log_spec.rb +146 -48
- data/spec/unit/util/logging_spec.rb +114 -252
- data/spec/unit/util/metric_spec.rb +1 -0
- data/spec/unit/util/monkey_patches_spec.rb +12 -24
- data/spec/unit/util/multi_match_spec.rb +1 -0
- data/spec/unit/util/network_device/config_spec.rb +1 -0
- data/spec/unit/util/network_device/transport/base_spec.rb +6 -5
- data/spec/unit/util/network_device_spec.rb +9 -7
- data/spec/unit/util/package_spec.rb +1 -0
- data/spec/unit/util/pidlock_spec.rb +14 -86
- data/spec/unit/util/plist_spec.rb +33 -60
- data/spec/unit/util/posix_spec.rb +47 -78
- data/spec/unit/util/profiler/object_counts_spec.rb +2 -1
- data/spec/unit/util/rdoc_spec.rb +10 -9
- data/spec/unit/util/reference_spec.rb +1 -0
- data/spec/unit/util/resource_template_spec.rb +20 -20
- data/spec/unit/util/retry_action_spec.rb +8 -7
- data/spec/unit/util/rubygems_spec.rb +7 -41
- data/spec/unit/util/run_mode_spec.rb +11 -10
- data/spec/unit/util/selinux_spec.rb +73 -84
- data/spec/unit/util/splayer_spec.rb +9 -8
- data/spec/unit/util/ssl_spec.rb +1 -0
- data/spec/unit/util/storage_spec.rb +17 -111
- data/spec/unit/util/suidmanager_spec.rb +58 -47
- data/spec/unit/util/symbolic_file_mode_spec.rb +1 -0
- data/spec/unit/util/tag_set_spec.rb +9 -1
- data/spec/unit/util/tagging_spec.rb +12 -0
- data/spec/unit/util/terminal_spec.rb +10 -9
- data/spec/unit/util/user_attr_spec.rb +2 -1
- data/spec/unit/util/warnings_spec.rb +4 -3
- data/spec/unit/util/watcher/periodic_watcher_spec.rb +2 -2
- data/spec/unit/util/watcher_spec.rb +21 -51
- data/spec/unit/util/windows/access_control_entry_spec.rb +2 -1
- data/spec/unit/util/windows/access_control_list_spec.rb +2 -1
- data/spec/unit/util/windows/adsi_spec.rb +134 -278
- data/spec/unit/util/windows/api_types_spec.rb +42 -105
- data/spec/unit/util/windows/eventlog_spec.rb +13 -10
- data/spec/unit/util/windows/file_spec.rb +1 -0
- data/spec/unit/util/windows/root_certs_spec.rb +1 -0
- data/spec/unit/util/windows/security_descriptor_spec.rb +3 -1
- data/spec/unit/util/windows/service_spec.rb +180 -432
- data/spec/unit/util/windows/sid_spec.rb +17 -15
- data/spec/unit/util/windows/string_spec.rb +2 -1
- data/spec/unit/util/yaml_spec.rb +162 -28
- data/spec/unit/util_spec.rb +74 -119
- data/spec/unit/version_spec.rb +6 -6
- data/tasks/benchmark.rake +5 -1
- data/tasks/ci.rake +0 -5
- data/tasks/manpages.rake +9 -2
- data/tasks/parser.rake +11 -3
- metadata +162 -479
- data/CODEOWNERS +0 -30
- data/ext/rack/config.ru +0 -44
- data/ext/rack/example-passenger-vhost.conf +0 -57
- data/lib/puppet/application/ca.rb +0 -11
- data/lib/puppet/application/certificate.rb +0 -17
- data/lib/puppet/application/certificate_request.rb +0 -7
- data/lib/puppet/application/certificate_revocation_list.rb +0 -7
- data/lib/puppet/application/master.rb +0 -319
- data/lib/puppet/confine/boolean.rb +0 -45
- data/lib/puppet/external/nagios.rb +0 -46
- data/lib/puppet/external/nagios/base.rb +0 -472
- data/lib/puppet/external/nagios/grammar.ry +0 -248
- data/lib/puppet/external/nagios/makefile +0 -9
- data/lib/puppet/external/nagios/parser.rb +0 -400
- data/lib/puppet/face/ca.rb +0 -266
- data/lib/puppet/face/certificate.rb +0 -167
- data/lib/puppet/face/certificate_request.rb +0 -56
- data/lib/puppet/face/certificate_revocation_list.rb +0 -56
- data/lib/puppet/feature/rack.rb +0 -19
- data/lib/puppet/graph/random_prioritizer.rb +0 -16
- data/lib/puppet/graph/title_hash_prioritizer.rb +0 -16
- data/lib/puppet/indirector/certificate/ca.rb +0 -9
- data/lib/puppet/indirector/certificate/disabled_ca.rb +0 -22
- data/lib/puppet/indirector/certificate_request/ca.rb +0 -22
- data/lib/puppet/indirector/certificate_request/disabled_ca.rb +0 -22
- data/lib/puppet/indirector/certificate_revocation_list/ca.rb +0 -8
- data/lib/puppet/indirector/certificate_revocation_list/disabled_ca.rb +0 -22
- data/lib/puppet/indirector/certificate_revocation_list/file.rb +0 -8
- data/lib/puppet/indirector/certificate_revocation_list/rest.rb +0 -22
- data/lib/puppet/indirector/certificate_status.rb +0 -4
- data/lib/puppet/indirector/certificate_status/file.rb +0 -91
- data/lib/puppet/indirector/certificate_status/rest.rb +0 -11
- data/lib/puppet/indirector/key/ca.rb +0 -16
- data/lib/puppet/indirector/key/disabled_ca.rb +0 -22
- data/lib/puppet/indirector/ldap.rb +0 -86
- data/lib/puppet/indirector/node/ldap.rb +0 -275
- data/lib/puppet/indirector/node/write_only_yaml.rb +0 -39
- data/lib/puppet/module_tool/applications/builder.rb +0 -152
- data/lib/puppet/module_tool/skeleton/templates/generator/Gemfile +0 -18
- data/lib/puppet/module_tool/skeleton/templates/generator/README.md.erb +0 -89
- data/lib/puppet/module_tool/skeleton/templates/generator/Rakefile +0 -32
- data/lib/puppet/module_tool/skeleton/templates/generator/examples/init.pp.erb +0 -12
- data/lib/puppet/module_tool/skeleton/templates/generator/manifests/init.pp.erb +0 -48
- data/lib/puppet/module_tool/skeleton/templates/generator/metadata.json.erb +0 -1
- data/lib/puppet/module_tool/skeleton/templates/generator/spec/classes/init_spec.rb.erb +0 -6
- data/lib/puppet/module_tool/skeleton/templates/generator/spec/spec_helper.rb +0 -1
- data/lib/puppet/network/http/api/ca.rb +0 -2
- data/lib/puppet/network/http/api/ca/v1.rb +0 -11
- data/lib/puppet/network/http/rack.rb +0 -33
- data/lib/puppet/network/http/rack/rest.rb +0 -162
- data/lib/puppet/network/http/webrick.rb +0 -124
- data/lib/puppet/network/http/webrick/rest.rb +0 -114
- data/lib/puppet/network/server.rb +0 -39
- data/lib/puppet/provider/augeas/augeas.rb +0 -767
- data/lib/puppet/provider/cisco.rb +0 -9
- data/lib/puppet/provider/computer/computer.rb +0 -20
- data/lib/puppet/provider/cron/crontab.rb +0 -297
- data/lib/puppet/provider/host/parsed.rb +0 -46
- data/lib/puppet/provider/interface/cisco.rb +0 -27
- data/lib/puppet/provider/macauthorization/macauthorization.rb +0 -298
- data/lib/puppet/provider/mailalias/aliases.rb +0 -50
- data/lib/puppet/provider/maillist/mailman.rb +0 -108
- data/lib/puppet/provider/mcx/mcxcontent.rb +0 -173
- data/lib/puppet/provider/mount.rb +0 -76
- data/lib/puppet/provider/mount/parsed.rb +0 -285
- data/lib/puppet/provider/naginator.rb +0 -63
- data/lib/puppet/provider/package/dnfmodule.rb +0 -141
- data/lib/puppet/provider/package_targetable.rb +0 -69
- data/lib/puppet/provider/scheduled_task/win32_taskscheduler.rb +0 -590
- data/lib/puppet/provider/selboolean/getsetsebool.rb +0 -47
- data/lib/puppet/provider/selmodule/semodule.rb +0 -157
- data/lib/puppet/provider/ssh_authorized_key/parsed.rb +0 -105
- data/lib/puppet/provider/sshkey/parsed.rb +0 -50
- data/lib/puppet/provider/vlan/cisco.rb +0 -28
- data/lib/puppet/provider/yumrepo/inifile.rb +0 -315
- data/lib/puppet/provider/zfs/zfs.rb +0 -108
- data/lib/puppet/provider/zone/solaris.rb +0 -364
- data/lib/puppet/provider/zpool/zpool.rb +0 -125
- data/lib/puppet/ssl/certificate_authority.rb +0 -554
- data/lib/puppet/ssl/certificate_authority/autosign_command.rb +0 -45
- data/lib/puppet/ssl/certificate_authority/interface.rb +0 -324
- data/lib/puppet/ssl/certificate_revocation_list.rb +0 -111
- data/lib/puppet/ssl/configuration.rb +0 -61
- data/lib/puppet/ssl/inventory.rb +0 -55
- data/lib/puppet/type/augeas.rb +0 -211
- data/lib/puppet/type/computer.rb +0 -66
- data/lib/puppet/type/cron.rb +0 -480
- data/lib/puppet/type/host.rb +0 -95
- data/lib/puppet/type/interface.rb +0 -121
- data/lib/puppet/type/k5login.rb +0 -165
- data/lib/puppet/type/macauthorization.rb +0 -167
- data/lib/puppet/type/mailalias.rb +0 -46
- data/lib/puppet/type/maillist.rb +0 -62
- data/lib/puppet/type/mcx.rb +0 -98
- data/lib/puppet/type/mount.rb +0 -314
- data/lib/puppet/type/nagios_command.rb +0 -3
- data/lib/puppet/type/nagios_contact.rb +0 -3
- data/lib/puppet/type/nagios_contactgroup.rb +0 -3
- data/lib/puppet/type/nagios_host.rb +0 -3
- data/lib/puppet/type/nagios_hostdependency.rb +0 -3
- data/lib/puppet/type/nagios_hostescalation.rb +0 -3
- data/lib/puppet/type/nagios_hostextinfo.rb +0 -3
- data/lib/puppet/type/nagios_hostgroup.rb +0 -3
- data/lib/puppet/type/nagios_service.rb +0 -3
- data/lib/puppet/type/nagios_servicedependency.rb +0 -3
- data/lib/puppet/type/nagios_serviceescalation.rb +0 -3
- data/lib/puppet/type/nagios_serviceextinfo.rb +0 -3
- data/lib/puppet/type/nagios_servicegroup.rb +0 -3
- data/lib/puppet/type/nagios_timeperiod.rb +0 -3
- data/lib/puppet/type/router.rb +0 -17
- data/lib/puppet/type/scheduled_task.rb +0 -183
- data/lib/puppet/type/selboolean.rb +0 -40
- data/lib/puppet/type/selmodule.rb +0 -58
- data/lib/puppet/type/ssh_authorized_key.rb +0 -143
- data/lib/puppet/type/sshkey.rb +0 -83
- data/lib/puppet/type/vlan.rb +0 -26
- data/lib/puppet/type/yumrepo.rb +0 -430
- data/lib/puppet/type/zfs.rb +0 -154
- data/lib/puppet/type/zone.rb +0 -382
- data/lib/puppet/type/zpool.rb +0 -91
- data/lib/puppet/util/methodhelper.rb +0 -32
- data/lib/puppet/util/nagios_maker.rb +0 -85
- data/lib/puppet/util/network_device/cisco.rb +0 -4
- data/lib/puppet/util/network_device/cisco/device.rb +0 -285
- data/lib/puppet/util/network_device/cisco/facts.rb +0 -72
- data/lib/puppet/util/network_device/cisco/interface.rb +0 -94
- data/lib/puppet/util/network_device/ipcalc.rb +0 -68
- data/lib/puppet/util/network_device/transport/ssh.rb +0 -126
- data/lib/puppet/util/network_device/transport/telnet.rb +0 -47
- data/lib/puppet/util/windows/taskscheduler.rb +0 -1267
- data/lib/puppet/vendor/load_semantic.rb +0 -1
- data/lib/puppet/vendor/load_semantic_puppet.rb +0 -1
- data/lib/puppet/vendor/semantic/lib/semantic.rb +0 -5
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet.rb +0 -11
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet/dependency.rb +0 -181
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet/dependency/graph.rb +0 -60
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet/dependency/graph_node.rb +0 -117
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet/dependency/module_release.rb +0 -58
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet/dependency/source.rb +0 -25
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet/dependency/unsatisfiable_graph.rb +0 -31
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet/gem_version.rb +0 -3
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet/version.rb +0 -203
- data/lib/puppet/vendor/semantic_puppet/lib/semantic_puppet/version_range.rb +0 -758
- data/lib/puppet/vendor/semantic_puppet/locales/config.yaml +0 -21
- data/man/man8/puppet-ca.8 +0 -196
- data/man/man8/puppet-cert.8 +0 -118
- data/man/man8/puppet-certificate.8 +0 -240
- data/man/man8/puppet-certificate_request.8 +0 -161
- data/man/man8/puppet-certificate_revocation_list.8 +0 -139
- data/man/man8/puppet-master.8 +0 -85
- data/spec/fixtures/integration/provider/cron/crontab/create_normal_entry +0 -19
- data/spec/fixtures/integration/provider/cron/crontab/create_special_entry +0 -18
- data/spec/fixtures/integration/provider/cron/crontab/crontab_user1 +0 -15
- data/spec/fixtures/integration/provider/cron/crontab/crontab_user2 +0 -4
- data/spec/fixtures/integration/provider/cron/crontab/modify_entry +0 -13
- data/spec/fixtures/integration/provider/cron/crontab/moved_cronjob_input1 +0 -15
- data/spec/fixtures/integration/provider/cron/crontab/moved_cronjob_input2 +0 -6
- data/spec/fixtures/integration/provider/cron/crontab/purged +0 -8
- data/spec/fixtures/integration/provider/cron/crontab/remove_named_resource +0 -12
- data/spec/fixtures/integration/provider/cron/crontab/remove_unnamed_resource +0 -14
- data/spec/fixtures/integration/provider/cron/crontab/unspecialized +0 -15
- data/spec/fixtures/integration/provider/mailalias/aliases/test1 +0 -32
- data/spec/fixtures/integration/provider/sshkey/sample +0 -21
- data/spec/fixtures/unit/provider/augeas/augeas/augeas/lenses/test.aug +0 -13
- data/spec/fixtures/unit/provider/augeas/augeas/etc/fstab +0 -10
- data/spec/fixtures/unit/provider/augeas/augeas/etc/hosts +0 -6
- data/spec/fixtures/unit/provider/augeas/augeas/etc/test +0 -3
- data/spec/fixtures/unit/provider/augeas/augeas/test.aug +0 -13
- data/spec/fixtures/unit/provider/host/parsed/valid_hosts +0 -19
- data/spec/fixtures/unit/provider/mount/mount-output.aix.txt +0 -7
- data/spec/fixtures/unit/provider/mount/parsed/aix.filesystems +0 -152
- data/spec/fixtures/unit/provider/mount/parsed/aix.mount +0 -11
- data/spec/fixtures/unit/provider/mount/parsed/darwin.mount +0 -6
- data/spec/fixtures/unit/provider/mount/parsed/freebsd.fstab +0 -9
- data/spec/fixtures/unit/provider/mount/parsed/freebsd.mount +0 -4
- data/spec/fixtures/unit/provider/mount/parsed/hpux.mount +0 -17
- data/spec/fixtures/unit/provider/mount/parsed/linux.fstab +0 -12
- data/spec/fixtures/unit/provider/mount/parsed/linux.mount +0 -6
- data/spec/fixtures/unit/provider/mount/parsed/netbsd.fstab +0 -10
- data/spec/fixtures/unit/provider/mount/parsed/netbsd.mount +0 -9
- data/spec/fixtures/unit/provider/mount/parsed/openbsd.fstab +0 -5
- data/spec/fixtures/unit/provider/mount/parsed/openbsd.mount +0 -5
- data/spec/fixtures/unit/provider/mount/parsed/solaris.fstab +0 -11
- data/spec/fixtures/unit/provider/mount/parsed/solaris.mount +0 -6
- data/spec/fixtures/unit/provider/naginator/define_empty_param +0 -6
- data/spec/fixtures/unit/provider/package/dnfmodule/dnf-module-list.txt +0 -19
- data/spec/fixtures/unit/provider/package/yum/yum-check-update-subscription-manager.txt +0 -9
- data/spec/fixtures/unit/provider/service/smf/svcs_fmri.out +0 -6
- data/spec/fixtures/unit/provider/service/smf/svcs_multiple_fmris.out +0 -13
- data/spec/fixtures/unit/provider/ssh_authorized_key/parsed/authorized_keys +0 -7
- data/spec/fixtures/unit/provider/ssh_authorized_key/parsed/authorized_keys1 +0 -3
- data/spec/fixtures/unit/provider/ssh_authorized_key/parsed/authorized_keys2 +0 -1
- data/spec/fixtures/unit/provider/sshkey/parsed/sample +0 -21
- data/spec/fixtures/unit/provider/sshkey/parsed/sample_with_blank_lines +0 -8
- data/spec/fixtures/unit/provider/zfs/zfs/zfs-list.out +0 -2
- data/spec/fixtures/unit/provider/zpool/zpool/zpool-list.out +0 -2
- data/spec/integration/faces/ca_spec.rb +0 -353
- data/spec/integration/indirector/node/ldap_spec.rb +0 -13
- data/spec/integration/network/http_pool_spec.rb +0 -120
- data/spec/integration/provider/cron/crontab_spec.rb +0 -240
- data/spec/integration/provider/file/windows_spec.rb +0 -162
- data/spec/integration/provider/mailalias/aliases_spec.rb +0 -9
- data/spec/integration/provider/mount_spec.rb +0 -163
- data/spec/integration/provider/ssh_authorized_key_spec.rb +0 -217
- data/spec/integration/provider/sshkey_spec.rb +0 -153
- data/spec/integration/provider/yumrepo_spec.rb +0 -126
- data/spec/integration/ssl/autosign_spec.rb +0 -145
- data/spec/integration/ssl/certificate_authority_spec.rb +0 -161
- data/spec/integration/ssl/certificate_revocation_list_spec.rb +0 -33
- data/spec/integration/transaction_spec.rb +0 -553
- data/spec/integration/type/nagios_spec.rb +0 -69
- data/spec/integration/type/notify_spec.rb +0 -46
- data/spec/integration/type/user_spec.rb +0 -63
- data/spec/lib/puppet_spec/https.rb +0 -166
- data/spec/unit/application/cert_spec.rb +0 -272
- data/spec/unit/application/certificate_spec.rb +0 -21
- data/spec/unit/application/master_spec.rb +0 -414
- data/spec/unit/face/ca_spec.rb +0 -9
- data/spec/unit/face/certificate_request_spec.rb +0 -9
- data/spec/unit/face/certificate_revocation_list_spec.rb +0 -9
- data/spec/unit/face/certificate_spec.rb +0 -228
- data/spec/unit/face/module/build_spec.rb +0 -69
- data/spec/unit/graph/title_hash_prioritizer_spec.rb +0 -50
- data/spec/unit/indirector/certificate/ca_spec.rb +0 -21
- data/spec/unit/indirector/certificate/disabled_ca_spec.rb +0 -32
- data/spec/unit/indirector/certificate_request/ca_spec.rb +0 -56
- data/spec/unit/indirector/certificate_request/disabled_ca_spec.rb +0 -32
- data/spec/unit/indirector/certificate_revocation_list/ca_spec.rb +0 -15
- data/spec/unit/indirector/certificate_revocation_list/disabled_ca_spec.rb +0 -32
- data/spec/unit/indirector/certificate_revocation_list/file_spec.rb +0 -16
- data/spec/unit/indirector/certificate_revocation_list/rest_spec.rb +0 -33
- data/spec/unit/indirector/certificate_status/file_spec.rb +0 -190
- data/spec/unit/indirector/certificate_status/rest_spec.rb +0 -17
- data/spec/unit/indirector/code_spec.rb +0 -30
- data/spec/unit/indirector/key/ca_spec.rb +0 -22
- data/spec/unit/indirector/key/disabled_ca_spec.rb +0 -32
- data/spec/unit/indirector/ldap_spec.rb +0 -151
- data/spec/unit/indirector/node/ldap_spec.rb +0 -463
- data/spec/unit/indirector/node/write_only_yaml_spec.rb +0 -11
- data/spec/unit/module_tool/applications/builder_spec.rb +0 -439
- data/spec/unit/network/http/api/ca/v1_spec.rb +0 -26
- data/spec/unit/network/http/rack/rest_spec.rb +0 -322
- data/spec/unit/network/http/rack_spec.rb +0 -42
- data/spec/unit/network/http/webrick/rest_spec.rb +0 -230
- data/spec/unit/network/http/webrick_spec.rb +0 -277
- data/spec/unit/network/server_spec.rb +0 -94
- data/spec/unit/provider/augeas/augeas_spec.rb +0 -1096
- data/spec/unit/provider/cisco_spec.rb +0 -14
- data/spec/unit/provider/cron/crontab_spec.rb +0 -206
- data/spec/unit/provider/cron/parsed_spec.rb +0 -355
- data/spec/unit/provider/host/parsed_spec.rb +0 -219
- data/spec/unit/provider/interface/cisco_spec.rb +0 -53
- data/spec/unit/provider/macauthorization_spec.rb +0 -134
- data/spec/unit/provider/mcx/mcxcontent_spec.rb +0 -190
- data/spec/unit/provider/mount/parsed_spec.rb +0 -318
- data/spec/unit/provider/mount_spec.rb +0 -169
- data/spec/unit/provider/naginator_spec.rb +0 -78
- data/spec/unit/provider/network_device_spec.rb +0 -152
- data/spec/unit/provider/package/dnfmodule_spec.rb +0 -247
- data/spec/unit/provider/package_targetable_spec.rb +0 -60
- data/spec/unit/provider/scheduled_task/win32_taskscheduler_spec.rb +0 -2050
- data/spec/unit/provider/selboolean_spec.rb +0 -34
- data/spec/unit/provider/selmodule-example.pp +0 -0
- data/spec/unit/provider/selmodule_spec.rb +0 -154
- data/spec/unit/provider/ssh_authorized_key/parsed_spec.rb +0 -259
- data/spec/unit/provider/sshkey/parsed_spec.rb +0 -92
- data/spec/unit/provider/vlan/cisco_spec.rb +0 -53
- data/spec/unit/provider/yumrepo/inifile_spec.rb +0 -413
- data/spec/unit/provider/zfs/zfs_spec.rb +0 -171
- data/spec/unit/provider/zone/solaris_spec.rb +0 -261
- data/spec/unit/provider/zpool/zpool_spec.rb +0 -250
- data/spec/unit/settings/server_list_setting_spec.rb +0 -21
- data/spec/unit/ssl/certificate_authority/autosign_command_spec.rb +0 -29
- data/spec/unit/ssl/certificate_authority/interface_spec.rb +0 -563
- data/spec/unit/ssl/certificate_authority_spec.rb +0 -1165
- data/spec/unit/ssl/certificate_revocation_list_spec.rb +0 -196
- data/spec/unit/ssl/configuration_spec.rb +0 -138
- data/spec/unit/ssl/inventory_spec.rb +0 -155
- data/spec/unit/test/test_helper_spec.rb +0 -17
- data/spec/unit/type/augeas_spec.rb +0 -120
- data/spec/unit/type/computer_spec.rb +0 -77
- data/spec/unit/type/cron_spec.rb +0 -539
- data/spec/unit/type/host_spec.rb +0 -680
- data/spec/unit/type/interface_spec.rb +0 -128
- data/spec/unit/type/k5login_spec.rb +0 -204
- data/spec/unit/type/macauthorization_spec.rb +0 -111
- data/spec/unit/type/mailalias_spec.rb +0 -48
- data/spec/unit/type/maillist_spec.rb +0 -38
- data/spec/unit/type/mcx_spec.rb +0 -75
- data/spec/unit/type/mount_spec.rb +0 -622
- data/spec/unit/type/nagios_spec.rb +0 -312
- data/spec/unit/type/scheduled_task_spec.rb +0 -117
- data/spec/unit/type/selboolean_spec.rb +0 -41
- data/spec/unit/type/selmodule_spec.rb +0 -16
- data/spec/unit/type/ssh_authorized_key_spec.rb +0 -228
- data/spec/unit/type/sshkey_spec.rb +0 -75
- data/spec/unit/type/vlan_spec.rb +0 -42
- data/spec/unit/type/yumrepo_spec.rb +0 -476
- data/spec/unit/type/zfs_spec.rb +0 -45
- data/spec/unit/type/zone_spec.rb +0 -182
- data/spec/unit/type/zpool_spec.rb +0 -108
- data/spec/unit/util/nagios_maker_spec.rb +0 -121
- data/spec/unit/util/network_device/cisco/device_spec.rb +0 -491
- data/spec/unit/util/network_device/cisco/facts_spec.rb +0 -63
- data/spec/unit/util/network_device/cisco/interface_spec.rb +0 -97
- data/spec/unit/util/network_device/ipcalc_spec.rb +0 -61
- data/spec/unit/util/network_device/transport/ssh_spec.rb +0 -252
- data/spec/unit/util/network_device/transport/telnet_spec.rb +0 -90
| @@ -1,89 +1,66 @@ | |
| 1 1 | 
             
            # encoding: UTF-8
         | 
| 2 | 
            +
            #!/usr/bin/env ruby
         | 
| 2 3 |  | 
| 3 4 | 
             
            require 'spec_helper'
         | 
| 4 5 |  | 
| 5 | 
            -
            describe "FFI::MemoryPointer", :if => Puppet. | 
| 6 | 
            +
            describe "FFI::MemoryPointer", :if => Puppet::Util::Platform.windows? do
         | 
| 6 7 | 
             
              # use 2 bad bytes at end so we have even number of bytes / characters
         | 
| 7 | 
            -
              let(:bad_string) { "hello invalid world".encode(Encoding::UTF_16LE) + "\xDD\xDD".force_encoding(Encoding::UTF_16LE) }
         | 
| 8 | 
            -
              let(:bad_string_bytes) { bad_string.bytes.to_a }
         | 
| 9 | 
            -
              let(:a_wide_bytes) { "A".encode(Encoding::UTF_16LE).bytes.to_a }
         | 
| 10 | 
            -
              let(:b_wide_bytes) { "B".encode(Encoding::UTF_16LE).bytes.to_a }
         | 
| 8 | 
            +
              let (:bad_string) { "hello invalid world".encode(Encoding::UTF_16LE) + "\xDD\xDD".force_encoding(Encoding::UTF_16LE) }
         | 
| 9 | 
            +
              let (:bad_string_bytes) { bad_string.bytes.to_a }
         | 
| 11 10 |  | 
| 12 11 | 
             
              context "read_wide_string" do
         | 
| 13 12 | 
             
                let (:string) { "foo_bar" }
         | 
| 14 13 |  | 
| 15 14 | 
             
                it "should properly roundtrip a given string" do
         | 
| 15 | 
            +
                  read_string = nil
         | 
| 16 16 | 
             
                  FFI::MemoryPointer.from_string_to_wide_string(string) do |ptr|
         | 
| 17 | 
            -
                     | 
| 17 | 
            +
                    read_string = ptr.read_wide_string(string.length)
         | 
| 18 18 | 
             
                  end
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                  expect(read_string).to eq(string)
         | 
| 19 21 | 
             
                end
         | 
| 20 22 |  | 
| 21 23 | 
             
                it "should return a given string in UTF-8" do
         | 
| 24 | 
            +
                  read_string = nil
         | 
| 22 25 | 
             
                  FFI::MemoryPointer.from_string_to_wide_string(string) do |ptr|
         | 
| 23 26 | 
             
                    read_string = ptr.read_wide_string(string.length)
         | 
| 24 | 
            -
                    expect(read_string.encoding).to eq(Encoding::UTF_8)
         | 
| 25 27 | 
             
                  end
         | 
| 28 | 
            +
             | 
| 29 | 
            +
                  expect(read_string.encoding).to eq(Encoding::UTF_8)
         | 
| 26 30 | 
             
                end
         | 
| 27 31 |  | 
| 28 32 | 
             
                it "should raise an error and emit a debug message when receiving a string containing invalid bytes in the destination encoding" do
         | 
| 29 | 
            -
                   | 
| 33 | 
            +
                  # enable a debug output sink to local string array
         | 
| 34 | 
            +
                  Puppet.debug = true
         | 
| 35 | 
            +
                  arraydest = []
         | 
| 36 | 
            +
                  Puppet::Util::Log.newdestination(Puppet::Test::LogCollector.new(arraydest))
         | 
| 37 | 
            +
             | 
| 38 | 
            +
                  read_string = nil
         | 
| 30 39 |  | 
| 31 40 | 
             
                  expect {
         | 
| 32 41 | 
             
                    FFI::MemoryPointer.new(:byte, bad_string_bytes.count) do |ptr|
         | 
| 33 42 | 
             
                      # uchar here is synonymous with byte
         | 
| 34 43 | 
             
                      ptr.put_array_of_uchar(0, bad_string_bytes)
         | 
| 35 44 |  | 
| 36 | 
            -
                      ptr.read_wide_string(bad_string.length)
         | 
| 45 | 
            +
                      read_string = ptr.read_wide_string(bad_string.length)
         | 
| 37 46 | 
             
                    end
         | 
| 38 47 | 
             
                  }.to raise_error(Encoding::InvalidByteSequenceError)
         | 
| 39 48 |  | 
| 40 | 
            -
                  expect( | 
| 49 | 
            +
                  expect(read_string).to be_nil
         | 
| 50 | 
            +
                  expect(arraydest.last.message).to eq("Unable to convert value #{bad_string.dump} to encoding UTF-8 due to #<Encoding::InvalidByteSequenceError: \"\\xDD\\xDD\" on UTF-16LE>")
         | 
| 41 51 | 
             
                end
         | 
| 42 52 |  | 
| 43 53 | 
             
                it "should not raise an error when receiving a string containing invalid bytes in the destination encoding, when specifying :invalid => :replace" do
         | 
| 54 | 
            +
                  read_string = nil
         | 
| 55 | 
            +
             | 
| 44 56 | 
             
                  FFI::MemoryPointer.new(:byte, bad_string_bytes.count) do |ptr|
         | 
| 45 57 | 
             
                    # uchar here is synonymous with byte
         | 
| 46 58 | 
             
                    ptr.put_array_of_uchar(0, bad_string_bytes)
         | 
| 47 59 |  | 
| 48 | 
            -
                    read_string = ptr.read_wide_string(bad_string.length, Encoding::UTF_8,  | 
| 49 | 
            -
                    expect(read_string).to eq("hello invalid world\uFFFD")
         | 
| 60 | 
            +
                    read_string = ptr.read_wide_string(bad_string.length, Encoding::UTF_8, :invalid => :replace)
         | 
| 50 61 | 
             
                  end
         | 
| 51 | 
            -
                end
         | 
| 52 62 |  | 
| 53 | 
            -
             | 
| 54 | 
            -
                  expect {
         | 
| 55 | 
            -
                    FFI::MemoryPointer.new(:byte, 1) do |ptr|
         | 
| 56 | 
            -
                      ptr.read_wide_string(1) # 1 wchar = 2 bytes
         | 
| 57 | 
            -
                    end
         | 
| 58 | 
            -
                  }.to raise_error(IndexError, /out of bounds/)
         | 
| 59 | 
            -
                end
         | 
| 60 | 
            -
             | 
| 61 | 
            -
                it "raises an IndexError if asked to read a negative number of characters" do
         | 
| 62 | 
            -
                  expect {
         | 
| 63 | 
            -
                    FFI::MemoryPointer.new(:byte, 1) do |ptr|
         | 
| 64 | 
            -
                      ptr.read_wide_string(-1)
         | 
| 65 | 
            -
                    end
         | 
| 66 | 
            -
                  }.to raise_error(IndexError, /out of bounds/)
         | 
| 67 | 
            -
                end
         | 
| 68 | 
            -
             | 
| 69 | 
            -
                it "returns an empty string if asked to read 0 characters" do
         | 
| 70 | 
            -
                  FFI::MemoryPointer.new(:byte, 1) do |ptr|
         | 
| 71 | 
            -
                    expect(ptr.read_wide_string(0)).to eq("")
         | 
| 72 | 
            -
                  end
         | 
| 73 | 
            -
                end
         | 
| 74 | 
            -
             | 
| 75 | 
            -
                it "returns a substring if asked to read fewer characters than are in the byte array" do
         | 
| 76 | 
            -
                  FFI::MemoryPointer.new(:byte, 4) do |ptr|
         | 
| 77 | 
            -
                    ptr.write_array_of_uint8("AB".encode('UTF-16LE').bytes.to_a)
         | 
| 78 | 
            -
                    expect(ptr.read_wide_string(1)).to eq("A")
         | 
| 79 | 
            -
                  end
         | 
| 80 | 
            -
                end
         | 
| 81 | 
            -
             | 
| 82 | 
            -
                it "preserves wide null characters in the string" do
         | 
| 83 | 
            -
                  FFI::MemoryPointer.new(:byte, 6) do |ptr|
         | 
| 84 | 
            -
                    ptr.write_array_of_uint8(a_wide_bytes + [0, 0] + b_wide_bytes)
         | 
| 85 | 
            -
                    expect(ptr.read_wide_string(3)).to eq("A\x00B")
         | 
| 86 | 
            -
                  end
         | 
| 63 | 
            +
                  expect(read_string).to eq("hello invalid world\uFFFD")
         | 
| 87 64 | 
             
                end
         | 
| 88 65 | 
             
              end
         | 
| 89 66 |  | 
| @@ -93,92 +70,52 @@ describe "FFI::MemoryPointer", :if => Puppet.features.microsoft_windows? do | |
| 93 70 | 
             
                let (:double_null_string) { string + "\x00\x00" }
         | 
| 94 71 |  | 
| 95 72 | 
             
                it "should read a short single null terminated string" do
         | 
| 73 | 
            +
                  read_string = nil
         | 
| 96 74 | 
             
                  FFI::MemoryPointer.from_string_to_wide_string(single_null_string) do |ptr|
         | 
| 97 | 
            -
                     | 
| 75 | 
            +
                    read_string = ptr.read_arbitrary_wide_string_up_to()
         | 
| 98 76 | 
             
                  end
         | 
| 99 | 
            -
                end
         | 
| 100 77 |  | 
| 101 | 
            -
             | 
| 102 | 
            -
                  FFI::MemoryPointer.from_string_to_wide_string(double_null_string) do |ptr|
         | 
| 103 | 
            -
                    expect(ptr.read_arbitrary_wide_string_up_to(512, :double_null)).to eq(string)
         | 
| 104 | 
            -
                  end
         | 
| 78 | 
            +
                  expect(read_string).to eq(string)
         | 
| 105 79 | 
             
                end
         | 
| 106 80 |  | 
| 107 | 
            -
                it " | 
| 108 | 
            -
                   | 
| 109 | 
            -
                    expect(ptr).to receive(:read_wide_string).with(string.length, anything, anything, anything).and_call_original
         | 
| 110 | 
            -
             | 
| 111 | 
            -
                    expect(ptr.read_arbitrary_wide_string_up_to).to eq(string)
         | 
| 112 | 
            -
                  end
         | 
| 113 | 
            -
                end
         | 
| 114 | 
            -
             | 
| 115 | 
            -
                it "detects trailing double null wchar" do
         | 
| 81 | 
            +
                it "should read a short double null terminated string" do
         | 
| 82 | 
            +
                  read_string = nil
         | 
| 116 83 | 
             
                  FFI::MemoryPointer.from_string_to_wide_string(double_null_string) do |ptr|
         | 
| 117 | 
            -
                     | 
| 118 | 
            -
             | 
| 119 | 
            -
                    expect(ptr.read_arbitrary_wide_string_up_to(512, :double_null)).to eq(string)
         | 
| 120 | 
            -
                  end
         | 
| 121 | 
            -
                end
         | 
| 122 | 
            -
             | 
| 123 | 
            -
                it "should raises an IndexError if max_length is negative" do
         | 
| 124 | 
            -
                  FFI::MemoryPointer.from_string_to_wide_string(single_null_string) do |ptr|
         | 
| 125 | 
            -
                    expect {
         | 
| 126 | 
            -
                      ptr.read_arbitrary_wide_string_up_to(-1)
         | 
| 127 | 
            -
                    }.to raise_error(IndexError, /out of bounds/)
         | 
| 84 | 
            +
                    read_string = ptr.read_arbitrary_wide_string_up_to(512, :double_null)
         | 
| 128 85 | 
             
                  end
         | 
| 129 | 
            -
                end
         | 
| 130 86 |  | 
| 131 | 
            -
             | 
| 132 | 
            -
                  FFI::MemoryPointer.from_string_to_wide_string(single_null_string) do |ptr|
         | 
| 133 | 
            -
                    expect(ptr.read_arbitrary_wide_string_up_to(0)).to eq("")
         | 
| 134 | 
            -
                  end
         | 
| 87 | 
            +
                  expect(read_string).to eq(string)
         | 
| 135 88 | 
             
                end
         | 
| 136 89 |  | 
| 137 90 | 
             
                it "should return a string of max_length characters when specified" do
         | 
| 91 | 
            +
                  read_string = nil
         | 
| 138 92 | 
             
                  FFI::MemoryPointer.from_string_to_wide_string(single_null_string) do |ptr|
         | 
| 139 | 
            -
                     | 
| 93 | 
            +
                    read_string = ptr.read_arbitrary_wide_string_up_to(3)
         | 
| 140 94 | 
             
                  end
         | 
| 95 | 
            +
             | 
| 96 | 
            +
                  expect(read_string).to eq(string[0..2])
         | 
| 141 97 | 
             
                end
         | 
| 142 98 |  | 
| 143 99 | 
             
                it "should return wide strings in UTF-8" do
         | 
| 100 | 
            +
                  read_string = nil
         | 
| 144 101 | 
             
                  FFI::MemoryPointer.from_string_to_wide_string(string) do |ptr|
         | 
| 145 | 
            -
                    read_string = ptr.read_arbitrary_wide_string_up_to
         | 
| 146 | 
            -
                    expect(read_string.encoding).to eq(Encoding::UTF_8)
         | 
| 102 | 
            +
                    read_string = ptr.read_arbitrary_wide_string_up_to()
         | 
| 147 103 | 
             
                  end
         | 
| 104 | 
            +
             | 
| 105 | 
            +
                  expect(read_string.encoding).to eq(Encoding::UTF_8)
         | 
| 148 106 | 
             
                end
         | 
| 149 107 |  | 
| 150 108 | 
             
                it "should not raise an error when receiving a string containing invalid bytes in the destination encoding, when specifying :invalid => :replace" do
         | 
| 109 | 
            +
                  read_string = nil
         | 
| 110 | 
            +
             | 
| 151 111 | 
             
                  FFI::MemoryPointer.new(:byte, bad_string_bytes.count) do |ptr|
         | 
| 152 112 | 
             
                    # uchar here is synonymous with byte
         | 
| 153 113 | 
             
                    ptr.put_array_of_uchar(0, bad_string_bytes)
         | 
| 154 114 |  | 
| 155 115 | 
             
                    read_string = ptr.read_arbitrary_wide_string_up_to(ptr.size / 2, :single_null, :invalid => :replace)
         | 
| 156 | 
            -
                    expect(read_string).to eq("hello invalid world\uFFFD")
         | 
| 157 | 
            -
                  end
         | 
| 158 | 
            -
                end
         | 
| 159 | 
            -
             | 
| 160 | 
            -
                it "should raise an IndexError if there isn't a null terminator" do
         | 
| 161 | 
            -
                  # This only works when using a memory pointer with a known number of cells
         | 
| 162 | 
            -
                  # and size per cell, but not arbitrary Pointers
         | 
| 163 | 
            -
                  FFI::MemoryPointer.new(:wchar, 1) do |ptr|
         | 
| 164 | 
            -
                    ptr.write_array_of_uint8(a_wide_bytes)
         | 
| 165 | 
            -
             | 
| 166 | 
            -
                    expect {
         | 
| 167 | 
            -
                      ptr.read_arbitrary_wide_string_up_to(42)
         | 
| 168 | 
            -
                    }.to raise_error(IndexError, /out of bounds/)
         | 
| 169 116 | 
             
                  end
         | 
| 170 | 
            -
                end
         | 
| 171 | 
            -
             | 
| 172 | 
            -
                it "should raise an IndexError if there isn't a double null terminator" do
         | 
| 173 | 
            -
                  # This only works when using a memory pointer with a known number of cells
         | 
| 174 | 
            -
                  # and size per cell, but not arbitrary Pointers
         | 
| 175 | 
            -
                  FFI::MemoryPointer.new(:wchar, 1) do |ptr|
         | 
| 176 | 
            -
                    ptr.write_array_of_uint8(a_wide_bytes)
         | 
| 177 117 |  | 
| 178 | 
            -
             | 
| 179 | 
            -
                      ptr.read_arbitrary_wide_string_up_to(42, :double_null)
         | 
| 180 | 
            -
                    }.to raise_error(IndexError, /out of bounds/)
         | 
| 181 | 
            -
                  end
         | 
| 118 | 
            +
                  expect(read_string).to eq("hello invalid world\uFFFD")
         | 
| 182 119 | 
             
                end
         | 
| 183 120 | 
             
              end
         | 
| 184 121 | 
             
            end
         | 
| @@ -1,8 +1,10 @@ | |
| 1 | 
            +
            #!/usr/bin/env ruby
         | 
| 2 | 
            +
             | 
| 1 3 | 
             
            require 'spec_helper'
         | 
| 2 4 |  | 
| 3 5 | 
             
            require 'puppet/util/windows'
         | 
| 4 6 |  | 
| 5 | 
            -
            describe Puppet::Util::Windows::EventLog, :if => Puppet. | 
| 7 | 
            +
            describe Puppet::Util::Windows::EventLog, :if => Puppet::Util::Platform.windows? do
         | 
| 6 8 |  | 
| 7 9 | 
             
              before(:each) { @event_log = Puppet::Util::Windows::EventLog.new }
         | 
| 8 10 | 
             
              after(:each) { @event_log.close }
         | 
| @@ -21,7 +23,7 @@ describe Puppet::Util::Windows::EventLog, :if => Puppet.features.microsoft_windo | |
| 21 23 | 
             
                it "sets a handle to the event log" do
         | 
| 22 24 | 
             
                  default_name = Puppet::Util::Windows::String.wide_string('Puppet')
         | 
| 23 25 | 
             
                  # return nil explicitly just to reinforce that we're not leaking eventlog handle
         | 
| 24 | 
            -
                   | 
| 26 | 
            +
                  Puppet::Util::Windows::EventLog.any_instance.expects(:RegisterEventSourceW).with(nil, default_name).returns(nil)
         | 
| 25 27 | 
             
                  Puppet::Util::Windows::EventLog.new
         | 
| 26 28 | 
             
                end
         | 
| 27 29 |  | 
| @@ -29,7 +31,7 @@ describe Puppet::Util::Windows::EventLog, :if => Puppet.features.microsoft_windo | |
| 29 31 | 
             
                  before do
         | 
| 30 32 | 
             
                    # RegisterEventSourceW will return NULL on failure
         | 
| 31 33 | 
             
                    # Stubbing prevents leaking eventlog handle
         | 
| 32 | 
            -
                     | 
| 34 | 
            +
                    Puppet::Util::Windows::EventLog.any_instance.stubs(:RegisterEventSourceW).returns(Puppet::Util::Windows::EventLog::NULL_HANDLE)
         | 
| 33 35 | 
             
                  end
         | 
| 34 36 |  | 
| 35 37 | 
             
                  it "raises an exception warning that the event log failed to open" do
         | 
| @@ -38,11 +40,11 @@ describe Puppet::Util::Windows::EventLog, :if => Puppet.features.microsoft_windo | |
| 38 40 |  | 
| 39 41 | 
             
                  it "passes the exit code to the exception constructor" do
         | 
| 40 42 | 
             
                    fake_error = Puppet::Util::Windows::EventLog::EventLogError.new('foo', 87)
         | 
| 41 | 
            -
                     | 
| 43 | 
            +
                    FFI.stubs(:errno).returns(87)
         | 
| 42 44 | 
             
                    # All we're testing here is that the constructor actually receives the exit code from FFI.errno (87)
         | 
| 43 45 | 
             
                    # We do so because `expect to...raise_error` doesn't support multiple parameter match arguments
         | 
| 44 46 | 
             
                    # We return fake_error just because `raise` expects an exception class
         | 
| 45 | 
            -
                     | 
| 47 | 
            +
                    Puppet::Util::Windows::EventLog::EventLogError.expects(:new).with(regexp_matches(/failed to open Windows eventlog/), 87).returns(fake_error)
         | 
| 46 48 | 
             
                    expect { Puppet::Util::Windows::EventLog.open('foo') }.to raise_error(Puppet::Util::Windows::EventLog::EventLogError)
         | 
| 47 49 | 
             
                  end
         | 
| 48 50 | 
             
                end
         | 
| @@ -51,9 +53,9 @@ describe Puppet::Util::Windows::EventLog, :if => Puppet.features.microsoft_windo | |
| 51 53 | 
             
              describe "#close" do
         | 
| 52 54 | 
             
                it "closes the handle to the event log" do
         | 
| 53 55 | 
             
                  @handle = "12345"
         | 
| 54 | 
            -
                   | 
| 56 | 
            +
                  Puppet::Util::Windows::EventLog.any_instance.stubs(:RegisterEventSourceW).returns(@handle)
         | 
| 55 57 | 
             
                  event_log = Puppet::Util::Windows::EventLog.new
         | 
| 56 | 
            -
                   | 
| 58 | 
            +
                  event_log.expects(:DeregisterEventSource).with(@handle).returns(1)
         | 
| 57 59 | 
             
                  event_log.close
         | 
| 58 60 | 
             
                end
         | 
| 59 61 | 
             
              end
         | 
| @@ -66,7 +68,7 @@ describe Puppet::Util::Windows::EventLog, :if => Puppet.features.microsoft_windo | |
| 66 68 | 
             
                context "when an event report fails" do
         | 
| 67 69 | 
             
                  before do
         | 
| 68 70 | 
             
                    # ReportEventW returns 0 on failure, which is mapped to WIN32_FALSE
         | 
| 69 | 
            -
                     | 
| 71 | 
            +
                    @event_log.stubs(:ReportEventW).returns(Puppet::Util::Windows::EventLog::WIN32_FALSE)
         | 
| 70 72 | 
             
                  end
         | 
| 71 73 |  | 
| 72 74 | 
             
                  it "raises an exception warning that the event report failed" do
         | 
| @@ -75,17 +77,18 @@ describe Puppet::Util::Windows::EventLog, :if => Puppet.features.microsoft_windo | |
| 75 77 |  | 
| 76 78 | 
             
                  it "passes the exit code to the exception constructor" do
         | 
| 77 79 | 
             
                    fake_error = Puppet::Util::Windows::EventLog::EventLogError.new('foo', 5)
         | 
| 78 | 
            -
                     | 
| 80 | 
            +
                    FFI.stubs(:errno).returns(5)
         | 
| 79 81 | 
             
                    # All we're testing here is that the constructor actually receives the exit code from FFI.errno (5)
         | 
| 80 82 | 
             
                    # We do so because `expect to...raise_error` doesn't support multiple parameter match arguments
         | 
| 81 83 | 
             
                    # We return fake_error just because `raise` expects an exception class
         | 
| 82 | 
            -
                     | 
| 84 | 
            +
                    Puppet::Util::Windows::EventLog::EventLogError.expects(:new).with(regexp_matches(/failed to report event/), 5).returns(fake_error)
         | 
| 83 85 | 
             
                    expect { @event_log.report_event(:data => 'foo', :event_type => Puppet::Util::Windows::EventLog::EVENTLOG_ERROR_TYPE, :event_id => 0x03) }.to raise_error(Puppet::Util::Windows::EventLog::EventLogError)
         | 
| 84 86 | 
             
                  end
         | 
| 85 87 | 
             
                end
         | 
| 86 88 | 
             
              end
         | 
| 87 89 |  | 
| 88 90 | 
             
              describe "self.to_native" do
         | 
| 91 | 
            +
             | 
| 89 92 | 
             
                it "raises an exception if the log level is not supported" do
         | 
| 90 93 | 
             
                  expect { Puppet::Util::Windows::EventLog.to_native(:foo) }.to raise_error(ArgumentError)
         | 
| 91 94 | 
             
                end
         | 
| @@ -1,7 +1,9 @@ | |
| 1 | 
            +
            #!/usr/bin/env ruby
         | 
| 2 | 
            +
             | 
| 1 3 | 
             
            require 'spec_helper'
         | 
| 2 4 | 
             
            require 'puppet/util/windows'
         | 
| 3 5 |  | 
| 4 | 
            -
            describe "Puppet::Util::Windows::SecurityDescriptor", :if => Puppet. | 
| 6 | 
            +
            describe "Puppet::Util::Windows::SecurityDescriptor", :if => Puppet::Util::Platform.windows? do
         | 
| 5 7 | 
             
              let(:system_sid) { Puppet::Util::Windows::SID::LocalSystem }
         | 
| 6 8 | 
             
              let(:admins_sid) { Puppet::Util::Windows::SID::BuiltinAdministrators }
         | 
| 7 9 | 
             
              let(:group_sid) { Puppet::Util::Windows::SID::Nobody }
         | 
| @@ -1,18 +1,9 @@ | |
| 1 | 
            +
            #!/usr/bin/env ruby
         | 
| 1 2 | 
             
            require 'spec_helper'
         | 
| 2 3 |  | 
| 3 4 | 
             
            describe "Puppet::Util::Windows::Service", :if => Puppet.features.microsoft_windows? do
         | 
| 4 5 | 
             
              require 'puppet/util/windows'
         | 
| 5 6 |  | 
| 6 | 
            -
              before(:each) do
         | 
| 7 | 
            -
                allow(Puppet::Util::Windows::Error).to receive(:format_error_code)
         | 
| 8 | 
            -
                  .with(anything)
         | 
| 9 | 
            -
                  .and_return("fake error!")
         | 
| 10 | 
            -
              end
         | 
| 11 | 
            -
             | 
| 12 | 
            -
              def service_state_str(state)
         | 
| 13 | 
            -
                Puppet::Util::Windows::Service::SERVICE_STATES[state].to_s
         | 
| 14 | 
            -
              end
         | 
| 15 | 
            -
             | 
| 16 7 | 
             
              # The following should emulate a successful call to the private function
         | 
| 17 8 | 
             
              # query_status that returns the value of query_return. This should give
         | 
| 18 9 | 
             
              # us a way to mock changes in service status.
         | 
| @@ -21,13 +12,7 @@ describe "Puppet::Util::Windows::Service", :if => Puppet.features.microsoft_wind | |
| 21 12 | 
             
              # just an expectation of subject::SERVICE_STATUS_PROCESS.new in sequence that
         | 
| 22 13 | 
             
              # returns the value passed in as a param
         | 
| 23 14 | 
             
              def expect_successful_status_query_and_return(query_return)
         | 
| 24 | 
            -
                 | 
| 25 | 
            -
              end
         | 
| 26 | 
            -
             | 
| 27 | 
            -
              def expect_successful_status_queries_and_return(*query_returns)
         | 
| 28 | 
            -
                query_returns.each do |query_return|
         | 
| 29 | 
            -
                  expect_successful_status_query_and_return(query_return)
         | 
| 30 | 
            -
                end
         | 
| 15 | 
            +
                subject::SERVICE_STATUS_PROCESS.expects(:new).in_sequence(status_checks).returns(query_return)
         | 
| 31 16 | 
             
              end
         | 
| 32 17 |  | 
| 33 18 | 
             
              # The following should emulate a successful call to the private function
         | 
| @@ -38,471 +23,237 @@ describe "Puppet::Util::Windows::Service", :if => Puppet.features.microsoft_wind | |
| 38 23 | 
             
              # just an expectation of subject::QUERY_SERVICE_CONFIGW.new in sequence that
         | 
| 39 24 | 
             
              # returns the value passed in as a param
         | 
| 40 25 | 
             
              def expect_successful_config_query_and_return(query_return)
         | 
| 41 | 
            -
                 | 
| 42 | 
            -
              end
         | 
| 43 | 
            -
             | 
| 44 | 
            -
              def expect_successful_config_query2_and_return(param, query_return)
         | 
| 45 | 
            -
                expect(param).to receive(:new).and_return(query_return)
         | 
| 26 | 
            +
                subject::QUERY_SERVICE_CONFIGW.expects(:new).in_sequence(status_checks).returns(query_return)
         | 
| 46 27 | 
             
              end
         | 
| 47 28 |  | 
| 48 29 | 
             
              let(:subject)      { Puppet::Util::Windows::Service }
         | 
| 49 | 
            -
              let(:pointer) {  | 
| 50 | 
            -
              let(: | 
| 51 | 
            -
              let(: | 
| 52 | 
            -
              let(: | 
| 30 | 
            +
              let(:pointer) { mock() }
         | 
| 31 | 
            +
              let(:status_checks) { sequence('status_checks') }
         | 
| 32 | 
            +
              let(:mock_service_name) { mock() }
         | 
| 33 | 
            +
              let(:service) { mock() }
         | 
| 34 | 
            +
              let(:scm) { mock() }
         | 
| 53 35 |  | 
| 54 36 | 
             
              before do
         | 
| 55 | 
            -
                 | 
| 56 | 
            -
                 | 
| 57 | 
            -
                 | 
| 58 | 
            -
                 | 
| 59 | 
            -
                 | 
| 60 | 
            -
                 | 
| 61 | 
            -
                 | 
| 62 | 
            -
                 | 
| 63 | 
            -
                 | 
| 64 | 
            -
                 | 
| 65 | 
            -
                 | 
| 66 | 
            -
                 | 
| 67 | 
            -
                 | 
| 68 | 
            -
                 | 
| 69 | 
            -
                 | 
| 70 | 
            -
                 | 
| 71 | 
            -
                 | 
| 72 | 
            -
                 | 
| 73 | 
            -
                allow(subject).to receive(:sleep)
         | 
| 37 | 
            +
                subject.stubs(:QueryServiceStatusEx).returns(1)
         | 
| 38 | 
            +
                subject.stubs(:QueryServiceConfigW).returns(1)
         | 
| 39 | 
            +
                subject.stubs(:StartServiceW).returns(1)
         | 
| 40 | 
            +
                subject.stubs(:ControlService).returns(1)
         | 
| 41 | 
            +
                subject.stubs(:ChangeServiceConfigW).returns(1)
         | 
| 42 | 
            +
                subject.stubs(:OpenSCManagerW).returns(scm)
         | 
| 43 | 
            +
                subject.stubs(:OpenServiceW).returns(service)
         | 
| 44 | 
            +
                subject.stubs(:CloseServiceHandle)
         | 
| 45 | 
            +
                subject.stubs(:EnumServicesStatusExW).returns(1)
         | 
| 46 | 
            +
                subject.stubs(:wide_string)
         | 
| 47 | 
            +
                subject::SERVICE_STATUS_PROCESS.stubs(:new)
         | 
| 48 | 
            +
                subject::QUERY_SERVICE_CONFIGW.stubs(:new)
         | 
| 49 | 
            +
                subject::SERVICE_STATUS.stubs(:new).returns({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 50 | 
            +
                Puppet::Util::Windows::Error.stubs(:new).raises(Puppet::Error.new('fake error'))
         | 
| 51 | 
            +
                FFI::MemoryPointer.stubs(:new).yields(pointer)
         | 
| 52 | 
            +
                pointer.stubs(:read_dword)
         | 
| 53 | 
            +
                pointer.stubs(:write_dword)
         | 
| 54 | 
            +
                pointer.stubs(:size)
         | 
| 74 55 | 
             
              end
         | 
| 75 56 |  | 
| 76 | 
            -
              describe "# | 
| 57 | 
            +
              describe "#start" do
         | 
| 58 | 
            +
             | 
| 77 59 | 
             
                context "when the service control manager cannot be opened" do
         | 
| 78 60 | 
             
                  let(:scm) { FFI::Pointer::NULL_HANDLE }
         | 
| 79 61 | 
             
                  it "raises a puppet error" do
         | 
| 80 | 
            -
                    expect{ subject. | 
| 62 | 
            +
                    expect{ subject.start(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 81 63 | 
             
                  end
         | 
| 82 64 | 
             
                end
         | 
| 83 65 |  | 
| 84 66 | 
             
                context "when the service cannot be opened" do
         | 
| 85 67 | 
             
                  let(:service) { FFI::Pointer::NULL_HANDLE }
         | 
| 86 | 
            -
             | 
| 87 | 
            -
             | 
| 88 | 
            -
                    allow(FFI).to receive(:errno).and_return(Puppet::Util::Windows::Service::ERROR_SERVICE_DOES_NOT_EXIST)
         | 
| 89 | 
            -
             | 
| 90 | 
            -
                    expect(subject.exists?(mock_service_name)).to be false
         | 
| 91 | 
            -
                  end
         | 
| 92 | 
            -
             | 
| 93 | 
            -
                  it "raises a puppet error if it fails to open for some other reason" do
         | 
| 94 | 
            -
                    expect{ subject.exists?(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 95 | 
            -
                  end
         | 
| 96 | 
            -
                end
         | 
| 97 | 
            -
             | 
| 98 | 
            -
                context "when the service can be opened" do
         | 
| 99 | 
            -
                  it "returns true" do
         | 
| 100 | 
            -
                    expect(subject.exists?(mock_service_name)).to be true
         | 
| 68 | 
            +
                  it "raises a puppet error" do
         | 
| 69 | 
            +
                    expect{ subject.start(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 101 70 | 
             
                  end
         | 
| 102 71 | 
             
                end
         | 
| 103 | 
            -
              end
         | 
| 104 | 
            -
             | 
| 105 | 
            -
              # This shared example contains the unit tests for the wait_on_pending_state
         | 
| 106 | 
            -
              # helper as used by service actions like #start and #stop. Before including
         | 
| 107 | 
            -
              # this shared example, be sure to mock out any intermediate calls prior to
         | 
| 108 | 
            -
              # the pending transition, and make sure that the post-condition _after_ those
         | 
| 109 | 
            -
              # intermediate calls leaves the service in the pending state. Before including
         | 
| 110 | 
            -
              # this example in your tests, be sure to define the following variables in a `let`
         | 
| 111 | 
            -
              # context:
         | 
| 112 | 
            -
              #     * action -- The service action
         | 
| 113 | 
            -
              shared_examples "a service action waiting on a pending transition" do |pending_state|
         | 
| 114 | 
            -
                pending_state_str = Puppet::Util::Windows::Service::SERVICE_STATES[pending_state].to_s
         | 
| 115 | 
            -
             | 
| 116 | 
            -
                final_state = Puppet::Util::Windows::Service::FINAL_STATES[pending_state]
         | 
| 117 | 
            -
                final_state_str = Puppet::Util::Windows::Service::SERVICE_STATES[final_state].to_s
         | 
| 118 | 
            -
             | 
| 119 | 
            -
                it "raises a Puppet::Error if the service query fails" do
         | 
| 120 | 
            -
                  expect(subject).to receive(:QueryServiceStatusEx).and_return(FFI::WIN32_FALSE)
         | 
| 121 | 
            -
             | 
| 122 | 
            -
                  expect { subject.send(action, mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 123 | 
            -
                end
         | 
| 124 | 
            -
             | 
| 125 | 
            -
                it "raises a Puppet::Error if the service unexpectedly transitions to a state other than #{pending_state_str} or #{final_state_str}" do
         | 
| 126 | 
            -
                  invalid_state = (subject::SERVICE_STATES.keys - [pending_state, final_state]).first
         | 
| 127 | 
            -
             | 
| 128 | 
            -
                  expect_successful_status_query_and_return(dwCurrentState: invalid_state)
         | 
| 129 | 
            -
             | 
| 130 | 
            -
                  expect { subject.send(action, mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 131 | 
            -
                end
         | 
| 132 | 
            -
             | 
| 133 | 
            -
                it "waits for at least 1 second if the wait_hint/10 is < 1 second" do
         | 
| 134 | 
            -
                  expect_successful_status_queries_and_return(
         | 
| 135 | 
            -
                    { :dwCurrentState => pending_state, :dwWaitHint => 0, :dwCheckPoint => 1 },
         | 
| 136 | 
            -
                    { :dwCurrentState => final_state }
         | 
| 137 | 
            -
                  )
         | 
| 138 | 
            -
             | 
| 139 | 
            -
                  expect(subject).to receive(:sleep).with(1)
         | 
| 140 | 
            -
             | 
| 141 | 
            -
                  subject.send(action, mock_service_name)
         | 
| 142 | 
            -
                end
         | 
| 143 | 
            -
             | 
| 144 | 
            -
                it "waits for at most 10 seconds if wait_hint/10 is > 10 seconds" do
         | 
| 145 | 
            -
                  expect_successful_status_queries_and_return(
         | 
| 146 | 
            -
                    { :dwCurrentState => pending_state, :dwWaitHint => 1000000, :dwCheckPoint => 1 },
         | 
| 147 | 
            -
                    { :dwCurrentState => final_state }
         | 
| 148 | 
            -
                  )
         | 
| 149 | 
            -
             | 
| 150 | 
            -
                  expect(subject).to receive(:sleep).with(10)
         | 
| 151 | 
            -
             | 
| 152 | 
            -
                  subject.send(action, mock_service_name)
         | 
| 153 | 
            -
                end
         | 
| 154 | 
            -
             | 
| 155 | 
            -
                it "does not raise an error if the service makes any progress while transitioning to #{final_state_str}" do
         | 
| 156 | 
            -
                  expect_successful_status_queries_and_return(
         | 
| 157 | 
            -
                    # The three "pending_state" statuses simulate the scenario where the service
         | 
| 158 | 
            -
                    # makes some progress during the transition right when Puppet's about to
         | 
| 159 | 
            -
                    # time out.
         | 
| 160 | 
            -
                    { :dwCurrentState => pending_state, :dwWaitHint => 100000, :dwCheckPoint => 1 },
         | 
| 161 | 
            -
                    { :dwCurrentState => pending_state, :dwWaitHint => 100000, :dwCheckPoint => 1 },
         | 
| 162 | 
            -
                    { :dwCurrentState => pending_state, :dwWaitHint => 100000, :dwCheckPoint => 2 },
         | 
| 163 | 
            -
             | 
| 164 | 
            -
                    { :dwCurrentState => final_state }
         | 
| 165 | 
            -
                  )
         | 
| 166 | 
            -
             | 
| 167 | 
            -
                  expect { subject.send(action, mock_service_name) }.to_not raise_error
         | 
| 168 | 
            -
                end
         | 
| 169 72 |  | 
| 170 | 
            -
                 | 
| 171 | 
            -
                   | 
| 172 | 
            -
                    expect_successful_status_query_and_return(
         | 
| 173 | 
            -
                      dwCurrentState: pending_state,
         | 
| 174 | 
            -
                      dwWaitHint: 10000,
         | 
| 175 | 
            -
                      dwCheckPoint: 1
         | 
| 176 | 
            -
                    )
         | 
| 73 | 
            +
                context "when the service can be opened and is in the stopped state" do
         | 
| 74 | 
            +
                  before do
         | 
| 75 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 177 76 | 
             
                  end
         | 
| 178 77 |  | 
| 179 | 
            -
                   | 
| 180 | 
            -
             | 
| 181 | 
            -
             | 
| 182 | 
            -
             | 
| 183 | 
            -
              # This shared example contains the unit tests for the transition_service_state
         | 
| 184 | 
            -
              # helper, which is the helper that all of our service actions like #start, #stop
         | 
| 185 | 
            -
              # delegate to. Including these tests under a shared example lets us include them in each of
         | 
| 186 | 
            -
              # those service action's unit tests. Before including this example in your tests, be
         | 
| 187 | 
            -
              # sure to define the following variables in a `let` context:
         | 
| 188 | 
            -
              #     * initial_state         -- The initial state of the service prior to performing the state
         | 
| 189 | 
            -
              #                                transition
         | 
| 190 | 
            -
              #
         | 
| 191 | 
            -
              #     * mock_state_transition -- A lambda that mocks the state transition. This should mock
         | 
| 192 | 
            -
              #                                any code in the block that's passed to the
         | 
| 193 | 
            -
              #                                transition_service_state helper
         | 
| 194 | 
            -
              #
         | 
| 195 | 
            -
              # See the unit tests for the #start method to see how this shared example's
         | 
| 196 | 
            -
              # included.
         | 
| 197 | 
            -
              #
         | 
| 198 | 
            -
              shared_examples "a service action that transitions the service state" do |action, valid_initial_states, pending_state, final_state|
         | 
| 199 | 
            -
                valid_initial_states_str = valid_initial_states.map do |state|
         | 
| 200 | 
            -
                  Puppet::Util::Windows::Service::SERVICE_STATES[state]
         | 
| 201 | 
            -
                end.join(', ')
         | 
| 202 | 
            -
                pending_state_str = Puppet::Util::Windows::Service::SERVICE_STATES[pending_state].to_s
         | 
| 203 | 
            -
                final_state_str = Puppet::Util::Windows::Service::SERVICE_STATES[final_state].to_s
         | 
| 204 | 
            -
             | 
| 205 | 
            -
                it "noops if the service is already in the #{final_state} state" do
         | 
| 206 | 
            -
                  expect_successful_status_query_and_return(dwCurrentState: final_state)
         | 
| 207 | 
            -
             | 
| 208 | 
            -
                  expect { subject.send(action, mock_service_name) }.to_not raise_error
         | 
| 209 | 
            -
                end
         | 
| 210 | 
            -
             | 
| 211 | 
            -
                # invalid_initial_states will be empty for the #stop action
         | 
| 212 | 
            -
                invalid_initial_states = Puppet::Util::Windows::Service::SERVICE_STATES.keys - valid_initial_states - [final_state]
         | 
| 213 | 
            -
                unless invalid_initial_states.empty?
         | 
| 214 | 
            -
                  it "raises a Puppet::Error if the service's initial state is not one of #{valid_initial_states_str}" do
         | 
| 215 | 
            -
                    invalid_initial_state = invalid_initial_states.first
         | 
| 216 | 
            -
                    expect_successful_status_query_and_return(dwCurrentState: invalid_initial_state)
         | 
| 217 | 
            -
              
         | 
| 218 | 
            -
                    expect{ subject.send(action, mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 78 | 
            +
                  it "Starts the service once the service reports SERVICE_RUNNING" do
         | 
| 79 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 80 | 
            +
                    subject.start(mock_service_name)
         | 
| 219 81 | 
             
                  end
         | 
| 220 | 
            -
                end
         | 
| 221 82 |  | 
| 222 | 
            -
             | 
| 223 | 
            -
             | 
| 224 | 
            -
                     | 
| 83 | 
            +
                  it "Raises an error if after calling StartServiceW the service is not in RUNNING or START_PENDING" do
         | 
| 84 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_PAUSED})
         | 
| 85 | 
            +
                    expect{ subject.start(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 225 86 | 
             
                  end
         | 
| 226 87 |  | 
| 227 | 
            -
                   | 
| 228 | 
            -
                     | 
| 88 | 
            +
                  it "raises a puppet error if StartServiceW returns false" do
         | 
| 89 | 
            +
                    subject.expects(:StartServiceW).returns(FFI::WIN32_FALSE)
         | 
| 90 | 
            +
                    expect{ subject.start(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 229 91 | 
             
                  end
         | 
| 230 92 | 
             
                end
         | 
| 231 93 |  | 
| 232 | 
            -
                 | 
| 233 | 
            -
             | 
| 234 | 
            -
             | 
| 235 | 
            -
             | 
| 236 | 
            -
             | 
| 237 | 
            -
             | 
| 238 | 
            -
             | 
| 239 | 
            -
             | 
| 240 | 
            -
                  context "waiting for a service with #{unsafe_pending_state_str} as its initial state" do
         | 
| 241 | 
            -
                    before(:each) do
         | 
| 242 | 
            -
                      # This mocks the status query to return the 'final_state' by default. Otherwise,
         | 
| 243 | 
            -
                      # we will fail the tests in the latter parts of the code where we wait for the
         | 
| 244 | 
            -
                      # service to finish transitioning to the 'final_state'.
         | 
| 245 | 
            -
                      allow(subject::SERVICE_STATUS_PROCESS).to receive(:new).and_return(dwCurrentState: final_state)
         | 
| 246 | 
            -
             | 
| 247 | 
            -
                      # Set our service's initial state
         | 
| 248 | 
            -
                      expect_successful_status_query_and_return(dwCurrentState: unsafe_pending_state)
         | 
| 249 | 
            -
             | 
| 250 | 
            -
                      mock_state_transition.call
         | 
| 251 | 
            -
                    end
         | 
| 252 | 
            -
             | 
| 253 | 
            -
                    include_examples "a service action waiting on a pending transition", unsafe_pending_state do
         | 
| 254 | 
            -
                      let(:action) { action }
         | 
| 255 | 
            -
                    end
         | 
| 94 | 
            +
                context "when the service hasn't stopped yet:" do
         | 
| 95 | 
            +
                  it "waits, then queries again until SERVICE_STOPPED" do
         | 
| 96 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 30000, :dwCheckPoint => 1})
         | 
| 97 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 30000, :dwCheckPoint => 50})
         | 
| 98 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 99 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 100 | 
            +
                    subject.expects(:sleep).with(3).twice
         | 
| 101 | 
            +
                    subject.start(mock_service_name)
         | 
| 256 102 | 
             
                  end
         | 
| 257 | 
            -
                end
         | 
| 258 | 
            -
             | 
| 259 | 
            -
                # reads e.g. "waiting for the service to transition to the SERVICE_RUNNING state after executing the 'start' action"
         | 
| 260 | 
            -
                #
         | 
| 261 | 
            -
                # NOTE: This is really unit testing the wait_on_state_transition helper
         | 
| 262 | 
            -
                context "waiting for the service to transition to the #{final_state_str} state after executing the '#{action}' action" do
         | 
| 263 | 
            -
                  before(:each) do
         | 
| 264 | 
            -
                    # Set our service's initial state prior to performing the state transition
         | 
| 265 | 
            -
                    expect_successful_status_query_and_return(dwCurrentState: initial_state)
         | 
| 266 103 |  | 
| 267 | 
            -
             | 
| 104 | 
            +
                  it "waits for at least 1 second if wait hint/10 is < 1 second" do
         | 
| 105 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 0, :dwCheckPoint => 1})
         | 
| 106 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 107 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 108 | 
            +
                    subject.expects(:sleep).with(1)
         | 
| 109 | 
            +
                    subject.start(mock_service_name)
         | 
| 268 110 | 
             
                  end
         | 
| 269 111 |  | 
| 270 | 
            -
                  it " | 
| 271 | 
            -
                     | 
| 272 | 
            -
             | 
| 273 | 
            -
                     | 
| 112 | 
            +
                  it "waits for at most 10 seconds if wait hint/10 is > 10 seconds" do
         | 
| 113 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 1000000, :dwCheckPoint => 1})
         | 
| 114 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 115 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 116 | 
            +
                    subject.expects(:sleep).with(10)
         | 
| 117 | 
            +
                    subject.start(mock_service_name)
         | 
| 274 118 | 
             
                  end
         | 
| 275 119 |  | 
| 276 | 
            -
                  it " | 
| 277 | 
            -
                     | 
| 278 | 
            -
             | 
| 279 | 
            -
             | 
| 280 | 
            -
                      { :dwCurrentState => final_state }
         | 
| 281 | 
            -
                    )
         | 
| 282 | 
            -
             | 
| 283 | 
            -
                    expect(subject).to receive(:sleep).with(1).twice
         | 
| 284 | 
            -
             | 
| 285 | 
            -
                    subject.send(action, mock_service_name)
         | 
| 120 | 
            +
                  it "raises a puppet error if the service query fails" do
         | 
| 121 | 
            +
                    subject.expects(:QueryServiceStatusEx).in_sequence(status_checks).returns(1)
         | 
| 122 | 
            +
                    subject.expects(:QueryServiceStatusEx).in_sequence(status_checks).returns(FFI::WIN32_FALSE)
         | 
| 123 | 
            +
                    expect{subject.start(mock_service_name)}.to raise_error(Puppet::Error)
         | 
| 286 124 | 
             
                  end
         | 
| 287 125 |  | 
| 288 | 
            -
                   | 
| 289 | 
            -
                     | 
| 290 | 
            -
             | 
| 291 | 
            -
                     | 
| 292 | 
            -
             | 
| 293 | 
            -
                    include_examples "a service action waiting on a pending transition", pending_state do
         | 
| 294 | 
            -
                      let(:action) { action }
         | 
| 295 | 
            -
                    end
         | 
| 126 | 
            +
                  it "raises a puppet error if the services configured dwWaitHint is 0, 30 seconds have passed and dwCheckPoint hasn't increased" do
         | 
| 127 | 
            +
                    # the number of times here is a little strange: there are 31 and 32 status queries sleeps because:
         | 
| 128 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 0, :dwCheckPoint => 0}).times(31)
         | 
| 129 | 
            +
                    subject.expects(:sleep).times(30).with(1)
         | 
| 130 | 
            +
                    expect{subject.start(mock_service_name)}.to raise_error(Puppet::Error)
         | 
| 296 131 | 
             
                  end
         | 
| 297 132 |  | 
| 298 | 
            -
                  it "raises a  | 
| 299 | 
            -
                     | 
| 300 | 
            -
             | 
| 301 | 
            -
                     | 
| 133 | 
            +
                  it "raises a puppet error if the services configured dwWaitHint has passed and dwCheckPoint hasn't increased" do
         | 
| 134 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 40000, :dwCheckPoint => 0}).times(11)
         | 
| 135 | 
            +
                    subject.expects(:sleep).times(10).with(4)
         | 
| 136 | 
            +
                    expect{subject.start(mock_service_name)}.to raise_error(Puppet::Error)
         | 
| 137 | 
            +
                  end
         | 
| 302 138 |  | 
| 303 | 
            -
             | 
| 139 | 
            +
                  it "Does not raise an error if the service makes progress" do
         | 
| 140 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 0, :dwCheckPoint => 0})
         | 
| 141 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 0, :dwCheckPoint => 2})
         | 
| 142 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 0, :dwCheckPoint => 30})
         | 
| 143 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 0, :dwCheckPoint => 50})
         | 
| 144 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 0, :dwCheckPoint => 98})
         | 
| 145 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 146 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 147 | 
            +
                    subject.expects(:sleep).times(5).with(1)
         | 
| 148 | 
            +
                    expect{subject.start(mock_service_name)}.to_not raise_error
         | 
| 304 149 | 
             
                  end
         | 
| 305 150 | 
             
                end
         | 
| 306 | 
            -
              end
         | 
| 307 151 |  | 
| 308 | 
            -
             | 
| 309 | 
            -
             | 
| 310 | 
            -
             | 
| 311 | 
            -
             | 
| 312 | 
            -
             | 
| 313 | 
            -
             | 
| 314 | 
            -
             | 
| 315 | 
            -
             | 
| 316 | 
            -
             | 
| 317 | 
            -
                # Thus, we add the next here to ensure that rspec does not
         | 
| 318 | 
            -
                # attempt to load our test code. This is OK for us to do
         | 
| 319 | 
            -
                # because we do not want to run these tests on non-Windows
         | 
| 320 | 
            -
                # platforms.
         | 
| 321 | 
            -
                next unless Puppet.features.microsoft_windows?
         | 
| 152 | 
            +
                context "when the service ends up in START_PENDING:" do
         | 
| 153 | 
            +
                  it "waits, then queries again until SERVICE_RUNNING" do
         | 
| 154 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 155 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 30000, :dwCheckPoint => 1})
         | 
| 156 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 30000, :dwCheckPoint => 50})
         | 
| 157 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 158 | 
            +
                    subject.expects(:sleep).with(3).twice
         | 
| 159 | 
            +
                    subject.start(mock_service_name)
         | 
| 160 | 
            +
                  end
         | 
| 322 161 |  | 
| 323 | 
            -
             | 
| 324 | 
            -
             | 
| 325 | 
            -
             | 
| 326 | 
            -
                     | 
| 162 | 
            +
                  it "waits for at least 1 second if wait hint/10 is < 1 second" do
         | 
| 163 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 164 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 0, :dwCheckPoint => 1})
         | 
| 165 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 166 | 
            +
                    subject.expects(:sleep).with(1)
         | 
| 167 | 
            +
                    subject.start(mock_service_name)
         | 
| 327 168 | 
             
                  end
         | 
| 328 | 
            -
                end
         | 
| 329 169 |  | 
| 330 | 
            -
             | 
| 331 | 
            -
             | 
| 332 | 
            -
             | 
| 333 | 
            -
                     | 
| 170 | 
            +
                  it "waits for at most 10 seconds if wait hint/10 is > 10 seconds" do
         | 
| 171 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 172 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 1000000, :dwCheckPoint => 1})
         | 
| 173 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 174 | 
            +
                    subject.expects(:sleep).with(10)
         | 
| 175 | 
            +
                    subject.start(mock_service_name)
         | 
| 334 176 | 
             
                  end
         | 
| 335 | 
            -
                end
         | 
| 336 177 |  | 
| 337 | 
            -
             | 
| 338 | 
            -
             | 
| 339 | 
            -
             | 
| 340 | 
            -
             | 
| 341 | 
            -
             | 
| 342 | 
            -
                    service::SERVICE_STOP_PENDING,
         | 
| 343 | 
            -
                    service::SERVICE_STOPPED,
         | 
| 344 | 
            -
                    service::SERVICE_START_PENDING
         | 
| 345 | 
            -
                  ]
         | 
| 346 | 
            -
                  final_state = service::SERVICE_RUNNING
         | 
| 347 | 
            -
              
         | 
| 348 | 
            -
                  include_examples "a service action that transitions the service state", :start, valid_initial_states, service::SERVICE_START_PENDING, final_state do
         | 
| 349 | 
            -
                    let(:initial_state) { subject::SERVICE_STOPPED }
         | 
| 350 | 
            -
                    let(:mock_state_transition) do
         | 
| 351 | 
            -
                      lambda do
         | 
| 352 | 
            -
                        allow(subject).to receive(:StartServiceW).and_return(1)
         | 
| 353 | 
            -
                      end
         | 
| 354 | 
            -
                    end
         | 
| 178 | 
            +
                  it "raises a puppet error if the service's configured dwWaitHint has passed and dwCheckPoint hasn't increased" do
         | 
| 179 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 180 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 40000, :dwCheckPoint => 0}).times(11)
         | 
| 181 | 
            +
                    subject.expects(:sleep).times(10).with(4)
         | 
| 182 | 
            +
                    expect{subject.start(mock_service_name)}.to raise_error(Puppet::Error)
         | 
| 355 183 | 
             
                  end
         | 
| 356 | 
            -
             | 
| 357 | 
            -
                  it " | 
| 358 | 
            -
                    expect_successful_status_query_and_return(dwCurrentState | 
| 359 | 
            -
             | 
| 360 | 
            -
                     | 
| 361 | 
            -
             | 
| 362 | 
            -
                     | 
| 363 | 
            -
             | 
| 364 | 
            -
             | 
| 365 | 
            -
             | 
| 366 | 
            -
                     | 
| 367 | 
            -
                      { dwCurrentState: subject::SERVICE_STOPPED },
         | 
| 368 | 
            -
                      { dwCurrentState: subject::SERVICE_RUNNING }
         | 
| 369 | 
            -
                    )
         | 
| 370 | 
            -
              
         | 
| 371 | 
            -
                    expect(subject).to receive(:StartServiceW).and_return(1)
         | 
| 372 | 
            -
              
         | 
| 373 | 
            -
                    subject.start(mock_service_name)
         | 
| 184 | 
            +
             | 
| 185 | 
            +
                  it "Does not raise an error if the service makes progress" do
         | 
| 186 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 187 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 0, :dwCheckPoint => 0})
         | 
| 188 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 0, :dwCheckPoint => 2})
         | 
| 189 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 0, :dwCheckPoint => 30})
         | 
| 190 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 0, :dwCheckPoint => 50})
         | 
| 191 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 0, :dwCheckPoint => 98})
         | 
| 192 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 193 | 
            +
                    subject.expects(:sleep).times(5).with(1)
         | 
| 194 | 
            +
                    expect{subject.start(mock_service_name)}.to_not raise_error
         | 
| 374 195 | 
             
                  end
         | 
| 375 196 | 
             
                end
         | 
| 376 197 | 
             
              end
         | 
| 377 198 |  | 
| 378 199 | 
             
              describe "#stop" do
         | 
| 379 | 
            -
                next unless Puppet.features.microsoft_windows?
         | 
| 380 | 
            -
             | 
| 381 200 | 
             
                context "when the service control manager cannot be opened" do
         | 
| 382 201 | 
             
                  let(:scm) { FFI::Pointer::NULL_HANDLE }
         | 
| 383 202 | 
             
                  it "raises a puppet error" do
         | 
| 384 | 
            -
                    expect{ subject. | 
| 203 | 
            +
                    expect{ subject.stop(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 385 204 | 
             
                  end
         | 
| 386 205 | 
             
                end
         | 
| 387 206 |  | 
| 388 207 | 
             
                context "when the service cannot be opened" do
         | 
| 389 208 | 
             
                  let(:service) { FFI::Pointer::NULL_HANDLE }
         | 
| 390 209 | 
             
                  it "raises a puppet error" do
         | 
| 391 | 
            -
                    expect{ subject. | 
| 210 | 
            +
                    expect{ subject.stop(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 392 211 | 
             
                  end
         | 
| 393 212 | 
             
                end
         | 
| 394 213 |  | 
| 395 | 
            -
                context "when the service can be opened" do
         | 
| 396 | 
            -
                   | 
| 397 | 
            -
             | 
| 398 | 
            -
                  final_state = service::SERVICE_STOPPED
         | 
| 399 | 
            -
              
         | 
| 400 | 
            -
                  include_examples "a service action that transitions the service state", :stop, valid_initial_states, service::SERVICE_STOP_PENDING, final_state do
         | 
| 401 | 
            -
                    let(:initial_state) { subject::SERVICE_RUNNING }
         | 
| 402 | 
            -
                    let(:mock_state_transition) do
         | 
| 403 | 
            -
                      lambda do
         | 
| 404 | 
            -
                        allow(subject).to receive(:ControlService).and_return(1)
         | 
| 405 | 
            -
                      end
         | 
| 406 | 
            -
                    end
         | 
| 214 | 
            +
                context "when the service can be opened and is in the running state:" do
         | 
| 215 | 
            +
                  before do
         | 
| 216 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 407 217 | 
             
                  end
         | 
| 408 218 |  | 
| 409 | 
            -
                  it " | 
| 410 | 
            -
                    expect_successful_status_query_and_return(dwCurrentState | 
| 411 | 
            -
             | 
| 412 | 
            -
                    allow(subject).to receive(:ControlService).and_return(FFI::WIN32_FALSE)
         | 
| 413 | 
            -
             | 
| 414 | 
            -
                    expect { subject.stop(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 415 | 
            -
                  end
         | 
| 416 | 
            -
              
         | 
| 417 | 
            -
                  it "stops the service" do
         | 
| 418 | 
            -
                    expect_successful_status_queries_and_return(
         | 
| 419 | 
            -
                      { dwCurrentState: subject::SERVICE_RUNNING },
         | 
| 420 | 
            -
                      { dwCurrentState: subject::SERVICE_STOPPED }
         | 
| 421 | 
            -
                    )
         | 
| 422 | 
            -
             | 
| 423 | 
            -
                    expect(subject).to receive(:ControlService).and_return(1)
         | 
| 424 | 
            -
             | 
| 219 | 
            +
                  it "Sends the SERVICE_CONTROL_STOP to the service once the service reports SERVICE_RUNNING" do
         | 
| 220 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 425 221 | 
             
                    subject.stop(mock_service_name)
         | 
| 426 222 | 
             
                  end
         | 
| 427 | 
            -
                end
         | 
| 428 | 
            -
              end
         | 
| 429 | 
            -
             | 
| 430 | 
            -
              describe "#resume" do
         | 
| 431 | 
            -
                next unless Puppet.features.microsoft_windows?
         | 
| 432 223 |  | 
| 433 | 
            -
             | 
| 434 | 
            -
             | 
| 435 | 
            -
             | 
| 436 | 
            -
                    expect{ subject.start(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 224 | 
            +
                  it "Raises an error if after calling ControlService the service is not in STOPPED or STOP_PENDING" do
         | 
| 225 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_PAUSED})
         | 
| 226 | 
            +
                    expect{ subject.stop(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 437 227 | 
             
                  end
         | 
| 438 | 
            -
                end
         | 
| 439 228 |  | 
| 440 | 
            -
             | 
| 441 | 
            -
             | 
| 442 | 
            -
             | 
| 443 | 
            -
                    expect{ subject.start(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 229 | 
            +
                  it "raises a puppet error if ControlService returns false" do
         | 
| 230 | 
            +
                    subject.expects(:ControlService).returns(FFI::WIN32_FALSE)
         | 
| 231 | 
            +
                    expect{ subject.stop(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 444 232 | 
             
                  end
         | 
| 445 233 | 
             
                end
         | 
| 446 234 |  | 
| 447 | 
            -
                 | 
| 448 | 
            -
             | 
| 449 | 
            -
             | 
| 450 | 
            -
             | 
| 451 | 
            -
             | 
| 452 | 
            -
                     | 
| 453 | 
            -
             | 
| 454 | 
            -
             | 
| 455 | 
            -
             | 
| 456 | 
            -
             | 
| 457 | 
            -
                     | 
| 458 | 
            -
                    let(:mock_state_transition) do
         | 
| 459 | 
            -
                      lambda do
         | 
| 460 | 
            -
                        # We need to mock the status query because in the block for #resume, we
         | 
| 461 | 
            -
                        # wait for the service to enter the SERVICE_PAUSED state prior to
         | 
| 462 | 
            -
                        # performing the transition (in case it is in SERVICE_PAUSE_PENDING).
         | 
| 463 | 
            -
                        expect_successful_status_query_and_return(dwCurrentState: subject::SERVICE_PAUSED)
         | 
| 464 | 
            -
             | 
| 465 | 
            -
                        allow(subject).to receive(:ControlService).and_return(1)
         | 
| 466 | 
            -
                      end
         | 
| 467 | 
            -
                    end
         | 
| 468 | 
            -
                  end
         | 
| 469 | 
            -
             | 
| 470 | 
            -
                  context "waiting for the SERVICE_PAUSE_PENDING => SERVICE_PAUSED transition to finish before resuming it" do
         | 
| 471 | 
            -
                    before(:each) do
         | 
| 472 | 
            -
                      # This mocks the status query to return the SERVICE_RUNNING state by default.
         | 
| 473 | 
            -
                      # Otherwise, we will fail the tests in the latter parts of the code where we
         | 
| 474 | 
            -
                      # wait for the service to finish transitioning to the 'SERVICE_RUNNING' state.
         | 
| 475 | 
            -
                      allow(subject::SERVICE_STATUS_PROCESS).to receive(:new).and_return(dwCurrentState: subject::SERVICE_RUNNING)
         | 
| 476 | 
            -
             | 
| 477 | 
            -
                      expect_successful_status_query_and_return(dwCurrentState: subject::SERVICE_PAUSE_PENDING)
         | 
| 478 | 
            -
             | 
| 479 | 
            -
                      allow(subject).to receive(:ControlService).and_return(1)
         | 
| 480 | 
            -
                    end
         | 
| 481 | 
            -
             | 
| 482 | 
            -
                    include_examples "a service action waiting on a pending transition", service::SERVICE_PAUSE_PENDING do
         | 
| 483 | 
            -
                      let(:action) { :resume }
         | 
| 484 | 
            -
                    end
         | 
| 485 | 
            -
                  end
         | 
| 486 | 
            -
             | 
| 487 | 
            -
                  it "raises a Puppet::Error if ControlService returns false" do
         | 
| 488 | 
            -
                    expect_successful_status_query_and_return(dwCurrentState: subject::SERVICE_PAUSED)
         | 
| 489 | 
            -
                    expect_successful_status_query_and_return(dwCurrentState: subject::SERVICE_PAUSED)
         | 
| 490 | 
            -
             | 
| 491 | 
            -
                    allow(subject).to receive(:ControlService).and_return(FFI::WIN32_FALSE)
         | 
| 492 | 
            -
             | 
| 493 | 
            -
                    expect { subject.resume(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 235 | 
            +
                # No need to retest much of the wait functionality here, since
         | 
| 236 | 
            +
                # both stop and start use the wait_for_pending_transition helper
         | 
| 237 | 
            +
                # which is tested in the start unit tests.
         | 
| 238 | 
            +
                context "when the service hasn't started yet:" do
         | 
| 239 | 
            +
                  it "waits, then queries again until SERVICE_STOPPED" do
         | 
| 240 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 30000, :dwCheckPoint => 1})
         | 
| 241 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_START_PENDING, :dwWaitHint => 30000, :dwCheckPoint => 50})
         | 
| 242 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 243 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 244 | 
            +
                    subject.expects(:sleep).with(3).twice
         | 
| 245 | 
            +
                    subject.stop(mock_service_name)
         | 
| 494 246 | 
             
                  end
         | 
| 495 | 
            -
             | 
| 496 | 
            -
                  it "resumes the service" do
         | 
| 497 | 
            -
                    expect_successful_status_queries_and_return(
         | 
| 498 | 
            -
                      { dwCurrentState: subject::SERVICE_PAUSED },
         | 
| 499 | 
            -
                      { dwCurrentState: subject::SERVICE_PAUSED },
         | 
| 500 | 
            -
                      { dwCurrentState: subject::SERVICE_RUNNING }
         | 
| 501 | 
            -
                    )
         | 
| 502 | 
            -
             | 
| 503 | 
            -
                    expect(subject).to receive(:ControlService).and_return(1)
         | 
| 247 | 
            +
                end
         | 
| 504 248 |  | 
| 505 | 
            -
             | 
| 249 | 
            +
                context "when the service ends up in STOP_PENDING:" do
         | 
| 250 | 
            +
                  it "waits, then queries again until SERVICE_RUNNING" do
         | 
| 251 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_RUNNING})
         | 
| 252 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 30000, :dwCheckPoint => 1})
         | 
| 253 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOP_PENDING, :dwWaitHint => 30000, :dwCheckPoint => 50})
         | 
| 254 | 
            +
                    expect_successful_status_query_and_return({:dwCurrentState => subject::SERVICE_STOPPED})
         | 
| 255 | 
            +
                    subject.expects(:sleep).with(3).twice
         | 
| 256 | 
            +
                    subject.stop(mock_service_name)
         | 
| 506 257 | 
             
                  end
         | 
| 507 258 | 
             
                end
         | 
| 508 259 | 
             
              end
         | 
| @@ -570,6 +321,7 @@ describe "Puppet::Util::Windows::Service", :if => Puppet.features.microsoft_wind | |
| 570 321 | 
             
                end
         | 
| 571 322 |  | 
| 572 323 | 
             
                context "when the service can be opened" do
         | 
| 324 | 
            +
             | 
| 573 325 | 
             
                  # We need to guard this section explicitly since rspec will always
         | 
| 574 326 | 
             
                  # construct all examples, even if it isn't going to run them.
         | 
| 575 327 | 
             
                  if Puppet.features.microsoft_windows?
         | 
| @@ -582,17 +334,13 @@ describe "Puppet::Util::Windows::Service", :if => Puppet.features.microsoft_wind | |
| 582 334 | 
             
                    }.each do |start_type_name, start_type|
         | 
| 583 335 | 
             
                      it "queries the service and returns the service start type #{start_type_name}" do
         | 
| 584 336 | 
             
                        expect_successful_config_query_and_return({:dwStartType => start_type})
         | 
| 585 | 
            -
                        if start_type_name == :SERVICE_AUTO_START
         | 
| 586 | 
            -
                          expect_successful_config_query2_and_return(subject::SERVICE_DELAYED_AUTO_START_INFO, {:fDelayedAutostart => 0})
         | 
| 587 | 
            -
                        end
         | 
| 588 337 | 
             
                        expect(subject.service_start_type(mock_service_name)).to eq(start_type_name)
         | 
| 589 338 | 
             
                      end
         | 
| 590 339 | 
             
                    end
         | 
| 591 340 | 
             
                  end
         | 
| 592 | 
            -
             | 
| 593 341 | 
             
                  it "raises a puppet error if the service query fails" do
         | 
| 594 | 
            -
                     | 
| 595 | 
            -
                     | 
| 342 | 
            +
                    subject.expects(:QueryServiceConfigW).in_sequence(status_checks)
         | 
| 343 | 
            +
                    subject.expects(:QueryServiceConfigW).in_sequence(status_checks).returns(FFI::WIN32_FALSE)
         | 
| 596 344 | 
             
                    expect{ subject.service_start_type(mock_service_name) }.to raise_error(Puppet::Error)
         | 
| 597 345 | 
             
                  end
         | 
| 598 346 | 
             
                end
         | 
| @@ -617,7 +365,7 @@ describe "Puppet::Util::Windows::Service", :if => Puppet.features.microsoft_wind | |
| 617 365 |  | 
| 618 366 | 
             
                context "when the service can be opened" do
         | 
| 619 367 | 
             
                  it "Raises an error on an unsuccessful change" do
         | 
| 620 | 
            -
                     | 
| 368 | 
            +
                    subject.expects(:ChangeServiceConfigW).returns(FFI::WIN32_FALSE)
         | 
| 621 369 | 
             
                    expect{ subject.set_startup_mode(mock_service_name, :SERVICE_DEMAND_START) }.to raise_error(Puppet::Error)
         | 
| 622 370 | 
             
                  end
         | 
| 623 371 | 
             
                end
         | 
| @@ -635,36 +383,36 @@ describe "Puppet::Util::Windows::Service", :if => Puppet.features.microsoft_wind | |
| 635 383 |  | 
| 636 384 | 
             
                context "when the service control manager is open" do
         | 
| 637 385 | 
             
                  let(:cursor) { [ 'svc1', 'svc2', 'svc3' ] }
         | 
| 638 | 
            -
                  let(:svc1name_ptr) {  | 
| 639 | 
            -
                  let(:svc2name_ptr) {  | 
| 640 | 
            -
                  let(:svc3name_ptr) {  | 
| 641 | 
            -
                  let(:svc1displayname_ptr) {  | 
| 642 | 
            -
                  let(:svc2displayname_ptr) {  | 
| 643 | 
            -
                  let(:svc3displayname_ptr) {  | 
| 386 | 
            +
                  let(:svc1name_ptr) { mock() }
         | 
| 387 | 
            +
                  let(:svc2name_ptr) { mock() }
         | 
| 388 | 
            +
                  let(:svc3name_ptr) { mock() }
         | 
| 389 | 
            +
                  let(:svc1displayname_ptr) { mock() }
         | 
| 390 | 
            +
                  let(:svc2displayname_ptr) { mock() }
         | 
| 391 | 
            +
                  let(:svc3displayname_ptr) { mock() }
         | 
| 644 392 | 
             
                  let(:svc1) { { :lpServiceName => svc1name_ptr, :lpDisplayName => svc1displayname_ptr, :ServiceStatusProcess => 'foo' } }
         | 
| 645 393 | 
             
                  let(:svc2) { { :lpServiceName => svc2name_ptr, :lpDisplayName => svc2displayname_ptr, :ServiceStatusProcess => 'foo' } }
         | 
| 646 394 | 
             
                  let(:svc3) { { :lpServiceName => svc3name_ptr, :lpDisplayName => svc3displayname_ptr, :ServiceStatusProcess => 'foo' } }
         | 
| 647 395 |  | 
| 648 396 | 
             
                  it "Raises an error if EnumServicesStatusExW fails" do
         | 
| 649 | 
            -
                     | 
| 650 | 
            -
                     | 
| 397 | 
            +
                    subject.expects(:EnumServicesStatusExW).in_sequence(pointer_sequence)
         | 
| 398 | 
            +
                    subject.expects(:EnumServicesStatusExW).in_sequence(pointer_sequence).returns(FFI::WIN32_FALSE)
         | 
| 651 399 | 
             
                    expect{ subject.services }.to raise_error(Puppet::Error)
         | 
| 652 400 | 
             
                  end
         | 
| 653 401 |  | 
| 654 402 | 
             
                  it "Reads the buffer using pointer arithmetic to create a hash of service entries" do
         | 
| 655 403 | 
             
                    # the first read_dword is for reading the bytes required, let that return 3 too.
         | 
| 656 404 | 
             
                    # the second read_dword will actually read the number of services returned
         | 
| 657 | 
            -
                     | 
| 658 | 
            -
                     | 
| 659 | 
            -
                     | 
| 660 | 
            -
                     | 
| 661 | 
            -
                     | 
| 662 | 
            -
                     | 
| 663 | 
            -
                     | 
| 664 | 
            -
                     | 
| 665 | 
            -
                     | 
| 666 | 
            -
                     | 
| 667 | 
            -
                     | 
| 405 | 
            +
                    pointer.expects(:read_dword).twice.returns(3)
         | 
| 406 | 
            +
                    FFI::Pointer.expects(:new).with(subject::ENUM_SERVICE_STATUS_PROCESSW, pointer).returns(cursor)
         | 
| 407 | 
            +
                    subject::ENUM_SERVICE_STATUS_PROCESSW.expects(:new).in_sequence(pointer_sequence).with('svc1').returns(svc1)
         | 
| 408 | 
            +
                    subject::ENUM_SERVICE_STATUS_PROCESSW.expects(:new).in_sequence(pointer_sequence).with('svc2').returns(svc2)
         | 
| 409 | 
            +
                    subject::ENUM_SERVICE_STATUS_PROCESSW.expects(:new).in_sequence(pointer_sequence).with('svc3').returns(svc3)
         | 
| 410 | 
            +
                    svc1name_ptr.expects(:read_arbitrary_wide_string_up_to).returns('svc1')
         | 
| 411 | 
            +
                    svc2name_ptr.expects(:read_arbitrary_wide_string_up_to).returns('svc2')
         | 
| 412 | 
            +
                    svc3name_ptr.expects(:read_arbitrary_wide_string_up_to).returns('svc3')
         | 
| 413 | 
            +
                    svc1displayname_ptr.expects(:read_arbitrary_wide_string_up_to).returns('service 1')
         | 
| 414 | 
            +
                    svc2displayname_ptr.expects(:read_arbitrary_wide_string_up_to).returns('service 2')
         | 
| 415 | 
            +
                    svc3displayname_ptr.expects(:read_arbitrary_wide_string_up_to).returns('service 3')
         | 
| 668 416 | 
             
                    expect(subject.services).to eq({
         | 
| 669 417 | 
             
                      'svc1' => { :display_name => 'service 1', :service_status_process => 'foo' },
         | 
| 670 418 | 
             
                      'svc2' => { :display_name => 'service 2', :service_status_process => 'foo' },
         |