puppet 5.5.16-x64-mingw32 → 5.5.21-x64-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/CODEOWNERS +10 -10
- data/Gemfile +2 -3
- data/Gemfile.lock +57 -52
- data/ext/build_defaults.yaml +1 -0
- data/ext/cert_inspector +3 -3
- data/ext/project_data.yaml +2 -2
- data/ext/puppet-test +2 -2
- data/ext/regexp_nodes/regexp_nodes.rb +4 -4
- data/ext/windows/service/daemon.rb +54 -8
- data/install.rb +6 -24
- data/lib/puppet.rb +5 -2
- data/lib/puppet/agent.rb +5 -13
- data/lib/puppet/application.rb +1 -1
- data/lib/puppet/application/agent.rb +15 -1
- data/lib/puppet/application/apply.rb +2 -2
- data/lib/puppet/application/describe.rb +3 -9
- data/lib/puppet/application/device.rb +4 -4
- data/lib/puppet/application/doc.rb +1 -1
- data/lib/puppet/application/filebucket.rb +13 -0
- data/lib/puppet/application/lookup.rb +1 -1
- data/lib/puppet/application/resource.rb +4 -4
- data/lib/puppet/application/script.rb +2 -2
- data/lib/puppet/configurer.rb +86 -28
- data/lib/puppet/configurer/downloader.rb +2 -6
- data/lib/puppet/daemon.rb +1 -1
- data/lib/puppet/defaults.rb +82 -38
- data/lib/puppet/error.rb +9 -1
- data/lib/puppet/external/nagios/base.rb +1 -1
- data/lib/puppet/face/ca.rb +1 -1
- data/lib/puppet/face/config.rb +10 -48
- data/lib/puppet/face/facts.rb +1 -1
- data/lib/puppet/face/module/list.rb +5 -5
- data/lib/puppet/face/module/search.rb +1 -1
- data/lib/puppet/face/module/uninstall.rb +1 -1
- data/lib/puppet/face/module/upgrade.rb +1 -1
- data/lib/puppet/face/plugin.rb +9 -2
- data/lib/puppet/file_serving/http_metadata.rb +1 -1
- data/lib/puppet/file_system.rb +0 -8
- data/lib/puppet/file_system/memory_file.rb +1 -1
- data/lib/puppet/file_system/posix.rb +3 -2
- data/lib/puppet/file_system/uniquefile.rb +4 -0
- data/lib/puppet/forge.rb +3 -3
- data/lib/puppet/functions/epp.rb +4 -4
- data/lib/puppet/functions/inline_epp.rb +5 -5
- data/lib/puppet/functions/reduce.rb +2 -4
- data/lib/puppet/gettext/module_translations.rb +1 -1
- data/lib/puppet/graph/rb_tree_map.rb +2 -2
- data/lib/puppet/graph/simple_graph.rb +6 -5
- data/lib/puppet/indirector/catalog/compiler.rb +8 -0
- data/lib/puppet/indirector/file_bucket_file/file.rb +1 -1
- data/lib/puppet/indirector/hiera.rb +2 -0
- data/lib/puppet/indirector/resource/ral.rb +1 -3
- data/lib/puppet/indirector/resource/validator.rb +1 -1
- data/lib/puppet/interface.rb +2 -1
- data/lib/puppet/loaders.rb +0 -1
- data/lib/puppet/metatype/manager.rb +1 -1
- data/lib/puppet/module.rb +1 -1
- data/lib/puppet/module_tool/applications/builder.rb +1 -1
- data/lib/puppet/module_tool/applications/installer.rb +1 -1
- data/lib/puppet/module_tool/applications/uninstaller.rb +3 -3
- data/lib/puppet/module_tool/metadata.rb +1 -1
- data/lib/puppet/module_tool/shared_behaviors.rb +4 -4
- data/lib/puppet/module_tool/tar/mini.rb +12 -2
- data/lib/puppet/network/http/api/indirected_routes.rb +13 -12
- data/lib/puppet/network/http/api/master/v3/environment.rb +3 -0
- data/lib/puppet/network/http/connection.rb +14 -12
- data/lib/puppet/network/http/factory.rb +1 -11
- data/lib/puppet/network/http/pool.rb +7 -1
- data/lib/puppet/network/http/rack/rest.rb +2 -2
- data/lib/puppet/network/http/site.rb +1 -1
- data/lib/puppet/network/resolver.rb +2 -2
- data/lib/puppet/node/environment.rb +4 -2
- data/lib/puppet/parameter.rb +8 -0
- data/lib/puppet/parser/ast.rb +1 -1
- data/lib/puppet/parser/ast/resourceparam.rb +1 -1
- data/lib/puppet/parser/compiler/catalog_validator/env_relationship_validator.rb +2 -0
- data/lib/puppet/parser/compiler/catalog_validator/site_validator.rb +2 -0
- data/lib/puppet/parser/environment_compiler.rb +3 -0
- data/lib/puppet/parser/functions.rb +1 -1
- data/lib/puppet/parser/functions/epp.rb +3 -3
- data/lib/puppet/parser/functions/inline_epp.rb +5 -5
- data/lib/puppet/parser/resource.rb +3 -2
- data/lib/puppet/parser/resource/param.rb +6 -0
- data/lib/puppet/pops/evaluator/access_operator.rb +2 -2
- 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/evaluator_impl.rb +1 -1
- data/lib/puppet/pops/evaluator/external_syntax_support.rb +3 -2
- data/lib/puppet/pops/evaluator/runtime3_support.rb +4 -4
- data/lib/puppet/pops/issues.rb +5 -0
- data/lib/puppet/pops/loaders.rb +1 -1
- data/lib/puppet/pops/lookup/hiera_config.rb +1 -0
- data/lib/puppet/pops/lookup/sub_lookup.rb +1 -1
- data/lib/puppet/pops/merge_strategy.rb +22 -18
- data/lib/puppet/pops/parser/heredoc_support.rb +1 -1
- data/lib/puppet/pops/parser/interpolation_support.rb +4 -4
- data/lib/puppet/pops/parser/locator.rb +1 -1
- data/lib/puppet/pops/parser/pn_parser.rb +17 -16
- data/lib/puppet/pops/puppet_stack.rb +51 -48
- data/lib/puppet/pops/resource/resource_type_impl.rb +2 -0
- data/lib/puppet/pops/types/p_sensitive_type.rb +1 -1
- data/lib/puppet/pops/types/string_converter.rb +10 -10
- data/lib/puppet/pops/types/type_calculator.rb +24 -0
- data/lib/puppet/pops/types/types.rb +3 -3
- data/lib/puppet/pops/validation/checker4_0.rb +10 -0
- data/lib/puppet/pops/validation/validator_factory_4_0.rb +1 -0
- data/lib/puppet/property.rb +1 -1
- data/lib/puppet/property/ensure.rb +1 -1
- data/lib/puppet/provider/augeas/augeas.rb +1 -1
- data/lib/puppet/provider/cron/crontab.rb +1 -1
- data/lib/puppet/provider/exec.rb +6 -2
- data/lib/puppet/provider/file/posix.rb +5 -0
- data/lib/puppet/provider/group/groupadd.rb +19 -19
- data/lib/puppet/provider/group/windows_adsi.rb +3 -3
- data/lib/puppet/provider/mailalias/aliases.rb +1 -1
- data/lib/puppet/provider/mount.rb +1 -1
- data/lib/puppet/provider/mount/parsed.rb +8 -8
- data/lib/puppet/provider/nameservice.rb +10 -3
- data/lib/puppet/provider/nameservice/directoryservice.rb +1 -1
- data/lib/puppet/provider/nameservice/pw.rb +2 -2
- data/lib/puppet/provider/package/aix.rb +17 -2
- data/lib/puppet/provider/package/apt.rb +14 -3
- data/lib/puppet/provider/package/dnf.rb +1 -1
- data/lib/puppet/provider/package/dnfmodule.rb +141 -0
- data/lib/puppet/provider/package/dpkg.rb +16 -18
- data/lib/puppet/provider/package/fink.rb +20 -3
- data/lib/puppet/provider/package/openbsd.rb +14 -2
- data/lib/puppet/provider/package/pip.rb +37 -10
- data/lib/puppet/provider/package/pkg.rb +18 -5
- data/lib/puppet/provider/package/pkgdmg.rb +1 -1
- data/lib/puppet/provider/package/pkgng.rb +16 -4
- data/lib/puppet/provider/package/portage.rb +4 -4
- data/lib/puppet/provider/package/rpm.rb +57 -19
- data/lib/puppet/provider/package/windows/package.rb +1 -1
- data/lib/puppet/provider/package/yum.rb +35 -24
- data/lib/puppet/provider/package/zypper.rb +1 -0
- data/lib/puppet/provider/package_targetable.rb +5 -4
- data/lib/puppet/provider/parsedfile.rb +1 -1
- data/lib/puppet/provider/scheduled_task/win32_taskscheduler.rb +3 -3
- data/lib/puppet/provider/selmodule/semodule.rb +43 -26
- data/lib/puppet/provider/service/daemontools.rb +9 -9
- data/lib/puppet/provider/service/launchd.rb +20 -5
- 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 +2 -8
- data/lib/puppet/provider/service/systemd.rb +35 -22
- data/lib/puppet/provider/service/windows.rb +8 -0
- data/lib/puppet/provider/user/directoryservice.rb +31 -6
- data/lib/puppet/provider/user/hpux.rb +1 -1
- data/lib/puppet/provider/user/pw.rb +12 -3
- data/lib/puppet/provider/user/user_role_add.rb +5 -1
- data/lib/puppet/provider/user/useradd.rb +62 -27
- data/lib/puppet/provider/user/windows_adsi.rb +4 -5
- data/lib/puppet/provider/yumrepo/inifile.rb +2 -2
- data/lib/puppet/reference/indirection.rb +2 -2
- data/lib/puppet/reference/metaparameter.rb +1 -3
- data/lib/puppet/reference/providers.rb +1 -1
- data/lib/puppet/reference/type.rb +3 -9
- data/lib/puppet/reports.rb +1 -1
- data/lib/puppet/resource.rb +18 -1
- data/lib/puppet/resource/catalog.rb +1 -1
- data/lib/puppet/resource/type.rb +8 -0
- data/lib/puppet/settings.rb +43 -3
- data/lib/puppet/settings/environment_conf.rb +1 -0
- data/lib/puppet/ssl/certificate.rb +2 -1
- data/lib/puppet/ssl/certificate_authority.rb +6 -5
- data/lib/puppet/ssl/certificate_authority/interface.rb +1 -1
- data/lib/puppet/ssl/certificate_factory.rb +2 -2
- data/lib/puppet/ssl/host.rb +3 -3
- data/lib/puppet/ssl/oids.rb +1 -1
- data/lib/puppet/test/test_helper.rb +15 -10
- data/lib/puppet/transaction/report.rb +1 -1
- data/lib/puppet/transaction/resource_harness.rb +1 -1
- data/lib/puppet/type.rb +15 -4
- data/lib/puppet/type/cron.rb +1 -1
- data/lib/puppet/type/exec.rb +21 -9
- data/lib/puppet/type/file.rb +14 -2
- data/lib/puppet/type/file/data_sync.rb +5 -1
- data/lib/puppet/type/group.rb +4 -2
- data/lib/puppet/type/interface.rb +1 -1
- data/lib/puppet/type/notify.rb +3 -2
- data/lib/puppet/type/package.rb +107 -8
- data/lib/puppet/type/schedule.rb +1 -1
- data/lib/puppet/type/selboolean.rb +17 -3
- data/lib/puppet/type/service.rb +9 -10
- data/lib/puppet/type/user.rb +6 -24
- data/lib/puppet/type/yumrepo.rb +3 -7
- data/lib/puppet/util.rb +47 -25
- data/lib/puppet/util/command_line/trollop.rb +1 -1
- data/lib/puppet/util/execution.rb +4 -3
- data/lib/puppet/util/http_proxy.rb +24 -16
- data/lib/puppet/util/instance_loader.rb +1 -1
- data/lib/puppet/util/log.rb +1 -1
- data/lib/puppet/util/log/destinations.rb +3 -12
- data/lib/puppet/util/logging.rb +30 -18
- data/lib/puppet/util/metric.rb +2 -2
- data/lib/puppet/util/monkey_patches.rb +1 -1
- data/lib/puppet/util/nagios_maker.rb +2 -2
- data/lib/puppet/util/network_device/cisco/device.rb +1 -1
- data/lib/puppet/util/network_device/cisco/interface.rb +2 -2
- data/lib/puppet/util/network_device/transport/ssh.rb +1 -1
- data/lib/puppet/util/pidlock.rb +12 -6
- data/lib/puppet/util/plist.rb +6 -0
- data/lib/puppet/util/provider_features.rb +2 -4
- data/lib/puppet/util/rdoc.rb +1 -1
- data/lib/puppet/util/reference.rb +1 -1
- data/lib/puppet/util/resource_template.rb +1 -1
- data/lib/puppet/util/selinux.rb +8 -2
- data/lib/puppet/util/windows/adsi.rb +60 -30
- data/lib/puppet/util/windows/api_types.rb +45 -32
- data/lib/puppet/util/windows/eventlog.rb +1 -6
- data/lib/puppet/util/windows/principal.rb +8 -6
- data/lib/puppet/util/windows/process.rb +16 -15
- data/lib/puppet/util/windows/registry.rb +17 -15
- data/lib/puppet/util/windows/security.rb +3 -0
- data/lib/puppet/util/windows/service.rb +149 -4
- data/lib/puppet/util/windows/sid.rb +4 -3
- data/lib/puppet/vendor.rb +1 -1
- data/lib/puppet/version.rb +1 -1
- data/lib/puppet_pal.rb +2 -2
- data/locales/puppet.pot +479 -443
- data/man/man5/puppet.conf.5 +38 -8
- data/man/man8/puppet-agent.8 +2 -2
- data/man/man8/puppet-apply.8 +1 -1
- data/man/man8/puppet-ca.8 +1 -1
- data/man/man8/puppet-catalog.8 +1 -1
- data/man/man8/puppet-cert.8 +1 -1
- data/man/man8/puppet-certificate.8 +1 -1
- data/man/man8/puppet-certificate_request.8 +1 -1
- data/man/man8/puppet-certificate_revocation_list.8 +1 -1
- data/man/man8/puppet-config.8 +1 -1
- data/man/man8/puppet-describe.8 +1 -1
- data/man/man8/puppet-device.8 +1 -1
- 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 +16 -1
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-key.8 +1 -1
- data/man/man8/puppet-lookup.8 +1 -1
- data/man/man8/puppet-man.8 +1 -1
- data/man/man8/puppet-master.8 +1 -1
- data/man/man8/puppet-module.8 +1 -1
- data/man/man8/puppet-node.8 +1 -1
- 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-status.8 +1 -1
- data/man/man8/puppet.8 +2 -2
- data/spec/fixtures/integration/provider/mailalias/aliases/test1 +1 -0
- data/spec/fixtures/unit/provider/package/dnfmodule/dnf-module-list.txt +19 -0
- data/spec/fixtures/unit/provider/package/pkgng/pkg.version +2 -0
- data/spec/fixtures/unit/provider/package/yum/yum-check-update-subscription-manager.txt +9 -0
- data/spec/fixtures/unit/provider/service/systemd/list_unit_files_services +9 -0
- data/spec/integration/configurer_spec.rb +52 -0
- data/spec/integration/defaults_spec.rb +1 -2
- data/spec/integration/indirector/facts/facter_spec.rb +4 -0
- data/spec/integration/parser/compiler_spec.rb +11 -0
- data/spec/integration/provider/service/systemd_spec.rb +8 -5
- data/spec/integration/type/file_spec.rb +28 -0
- data/spec/integration/type/notify_spec.rb +46 -0
- data/spec/integration/util/execution_spec.rb +27 -0
- data/spec/integration/util/windows/adsi_spec.rb +6 -1
- data/spec/integration/util/windows/registry_spec.rb +7 -7
- data/spec/unit/agent_spec.rb +34 -26
- data/spec/unit/application/agent_spec.rb +18 -0
- data/spec/unit/application/apply_spec.rb +2 -12
- data/spec/unit/application/device_spec.rb +1 -1
- data/spec/unit/configurer/fact_handler_spec.rb +0 -4
- data/spec/unit/configurer_spec.rb +377 -397
- data/spec/unit/daemon_spec.rb +0 -1
- data/spec/unit/face/facts_spec.rb +9 -0
- data/spec/unit/face/plugin_spec.rb +8 -0
- data/spec/unit/file_system/uniquefile_spec.rb +11 -0
- data/spec/unit/forge/forge_spec.rb +1 -3
- data/spec/unit/forge/repository_spec.rb +1 -3
- data/spec/unit/indirector/catalog/compiler_spec.rb +45 -26
- data/spec/unit/indirector/resource/ral_spec.rb +4 -4
- data/spec/unit/module_tool/tar/mini_spec.rb +1 -1
- data/spec/unit/network/http/api/indirected_routes_spec.rb +28 -11
- data/spec/unit/network/http/connection_spec.rb +43 -1
- data/spec/unit/network/http/factory_spec.rb +27 -5
- data/spec/unit/network/http/pool_spec.rb +32 -0
- data/spec/unit/node_spec.rb +7 -4
- data/spec/unit/parser/environment_compiler_spec.rb +7 -0
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +8 -3
- data/spec/unit/pops/validator/validator_spec.rb +7 -0
- data/spec/unit/provider/exec_spec.rb +209 -0
- data/spec/unit/provider/group/groupadd_spec.rb +30 -1
- data/spec/unit/provider/group/windows_adsi_spec.rb +43 -10
- data/spec/unit/provider/package/aix_spec.rb +29 -0
- data/spec/unit/provider/package/apt_spec.rb +13 -2
- data/spec/unit/provider/package/aptitude_spec.rb +1 -0
- data/spec/unit/provider/package/aptrpm_spec.rb +1 -1
- data/spec/unit/provider/package/dnf_spec.rb +7 -0
- data/spec/unit/provider/package/dnfmodule_spec.rb +247 -0
- data/spec/unit/provider/package/dpkg_spec.rb +35 -7
- data/spec/unit/provider/package/openbsd_spec.rb +17 -0
- data/spec/unit/provider/package/pip_spec.rb +93 -22
- data/spec/unit/provider/package/pkg_spec.rb +13 -1
- data/spec/unit/provider/package/pkgdmg_spec.rb +1 -1
- data/spec/unit/provider/package/pkgng_spec.rb +36 -0
- data/spec/unit/provider/package/portage_spec.rb +4 -4
- data/spec/unit/provider/package/rpm_spec.rb +150 -16
- data/spec/unit/provider/package/yum_spec.rb +66 -0
- data/spec/unit/provider/package/zypper_spec.rb +13 -0
- data/spec/unit/provider/package_targetable_spec.rb +60 -0
- data/spec/unit/provider/selmodule_spec.rb +118 -47
- data/spec/unit/provider/service/daemontools_spec.rb +24 -0
- data/spec/unit/provider/service/launchd_spec.rb +28 -0
- data/spec/unit/provider/service/runit_spec.rb +24 -0
- data/spec/unit/provider/service/systemd_spec.rb +109 -36
- data/spec/unit/provider/service/windows_spec.rb +20 -0
- data/spec/unit/provider/user/directoryservice_spec.rb +41 -0
- data/spec/unit/provider/user/hpux_spec.rb +2 -2
- data/spec/unit/provider/user/openbsd_spec.rb +1 -0
- data/spec/unit/provider/user/pw_spec.rb +37 -0
- data/spec/unit/provider/user/useradd_spec.rb +122 -15
- data/spec/unit/provider/user/windows_adsi_spec.rb +3 -3
- data/spec/unit/puppet_pal_2pec.rb +3 -0
- data/spec/unit/resource_spec.rb +26 -1
- data/spec/unit/ssl/certificate_authority_spec.rb +2 -3
- data/spec/unit/ssl/certificate_spec.rb +7 -0
- data/spec/unit/test/test_helper_spec.rb +17 -0
- data/spec/unit/transaction_spec.rb +18 -0
- data/spec/unit/type/exec_spec.rb +15 -12
- data/spec/unit/type/file/content_spec.rb +9 -3
- data/spec/unit/type/file/source_spec.rb +4 -4
- data/spec/unit/type/file_spec.rb +9 -4
- data/spec/unit/type/package_spec.rb +8 -0
- data/spec/unit/type/schedule_spec.rb +3 -1
- data/spec/unit/type/selboolean_spec.rb +4 -6
- data/spec/unit/type/service_spec.rb +25 -8
- data/spec/unit/type/user_spec.rb +32 -26
- data/spec/unit/type/yumrepo_spec.rb +30 -0
- data/spec/unit/type_spec.rb +40 -0
- data/spec/unit/util/execution_spec.rb +16 -0
- data/spec/unit/util/http_proxy_spec.rb +121 -1
- data/spec/unit/util/log/destinations_spec.rb +2 -26
- data/spec/unit/util/log_spec.rb +0 -112
- data/spec/unit/util/logging_spec.rb +200 -0
- data/spec/unit/util/pidlock_spec.rb +67 -40
- data/spec/unit/util/plist_spec.rb +20 -0
- data/spec/unit/util/windows/adsi_spec.rb +55 -4
- data/spec/unit/util/windows/api_types_spec.rb +104 -40
- data/spec/unit/util/windows/service_spec.rb +9 -0
- data/spec/unit/util/windows/sid_spec.rb +2 -2
- data/tasks/manpages.rake +1 -0
- metadata +18 -13
- data/ext/windows/eventlog/Rakefile +0 -32
- data/ext/windows/eventlog/puppetres.dll +0 -0
- data/ext/windows/eventlog/puppetres.mc +0 -18
- data/lib/puppet/pops/loader/null_loader.rb +0 -60
- data/locales/ja/puppet.po +0 -12114
- data/spec/integration/test/test_helper_spec.rb +0 -31
| @@ -590,6 +590,24 @@ describe Puppet::Application::Agent do | |
| 590 590 | 
             
                end
         | 
| 591 591 | 
             
              end
         | 
| 592 592 |  | 
| 593 | 
            +
              describe "when starting in daemon mode on non-windows", :unless => Puppet.features.microsoft_windows? do
         | 
| 594 | 
            +
                before :each do
         | 
| 595 | 
            +
                  allow(Puppet).to receive(:notice)
         | 
| 596 | 
            +
                  Puppet[:daemonize] = true
         | 
| 597 | 
            +
                end
         | 
| 598 | 
            +
             | 
| 599 | 
            +
                it "should not print config in default mode" do
         | 
| 600 | 
            +
                  execute_agent
         | 
| 601 | 
            +
                  expect(@logs).to be_empty
         | 
| 602 | 
            +
                end
         | 
| 603 | 
            +
             | 
| 604 | 
            +
                it "should print config in debug mode" do
         | 
| 605 | 
            +
                  @puppetd.options[:debug] = true
         | 
| 606 | 
            +
                  execute_agent
         | 
| 607 | 
            +
                  expect(@logs).to include(an_object_having_attributes(level: :debug, message: /agent_catalog_run_lockfile=/))
         | 
| 608 | 
            +
                end
         | 
| 609 | 
            +
              end
         | 
| 610 | 
            +
             | 
| 593 611 | 
             
              def execute_agent
         | 
| 594 612 | 
             
                @puppetd.setup
         | 
| 595 613 | 
             
                @puppetd.run_command
         | 
| @@ -14,14 +14,6 @@ describe Puppet::Application::Apply do | |
| 14 14 | 
             
                Puppet[:reports] = "none"
         | 
| 15 15 | 
             
              end
         | 
| 16 16 |  | 
| 17 | 
            -
              after :each do
         | 
| 18 | 
            -
                Puppet::Node::Facts.indirection.reset_terminus_class
         | 
| 19 | 
            -
                Puppet::Node::Facts.indirection.cache_class = nil
         | 
| 20 | 
            -
             | 
| 21 | 
            -
                Puppet::Node.indirection.reset_terminus_class
         | 
| 22 | 
            -
                Puppet::Node.indirection.cache_class = nil
         | 
| 23 | 
            -
              end
         | 
| 24 | 
            -
             | 
| 25 17 | 
             
              [:debug,:loadclasses,:test,:verbose,:use_nodes,:detailed_exitcodes,:catalog, :write_catalog_summary].each do |option|
         | 
| 26 18 | 
             
                it "should declare handle_#{option} method" do
         | 
| 27 19 | 
             
                  expect(@apply).to respond_to("handle_#{option}".to_sym)
         | 
| @@ -182,13 +174,11 @@ describe Puppet::Application::Apply do | |
| 182 174 | 
             
                    Puppet[:prerun_command] = ''
         | 
| 183 175 | 
             
                    Puppet[:postrun_command] = ''
         | 
| 184 176 |  | 
| 185 | 
            -
                    Puppet::Node::Facts.indirection.terminus_class = :memory
         | 
| 186 | 
            -
                    Puppet::Node::Facts.indirection.cache_class = :memory
         | 
| 187 177 | 
             
                    Puppet::Node.indirection.terminus_class = :memory
         | 
| 188 178 | 
             
                    Puppet::Node.indirection.cache_class = :memory
         | 
| 189 179 |  | 
| 190 | 
            -
                     | 
| 191 | 
            -
                    Puppet::Node::Facts.indirection.save( | 
| 180 | 
            +
                    facts = Puppet::Node::Facts.new(Puppet[:node_name_value])
         | 
| 181 | 
            +
                    Puppet::Node::Facts.indirection.save(facts)
         | 
| 192 182 |  | 
| 193 183 | 
             
                    @node = Puppet::Node.new(Puppet[:node_name_value])
         | 
| 194 184 | 
             
                    Puppet::Node.indirection.save(@node)
         | 
| @@ -481,7 +481,7 @@ describe Puppet::Application::Device do | |
| 481 481 | 
             
                    allow(@device.options).to receive(:[]).with(:to_yaml).and_return(true)
         | 
| 482 482 | 
             
                    allow(@device.command_line).to receive(:args).and_return(['user'])
         | 
| 483 483 | 
             
                    expect(Puppet::Resource.indirection).to receive(:search).with('user/', {}).and_return(resources)
         | 
| 484 | 
            -
                    expect(@device).to receive(:puts).with(" | 
| 484 | 
            +
                    expect(@device).to receive(:puts).with("---\nuser:\n  title: {}\n")
         | 
| 485 485 | 
             
                    expect { @device.main }.to exit_with 0
         | 
| 486 486 | 
             
                  end
         | 
| 487 487 |  | 
| @@ -22,10 +22,6 @@ describe Puppet::Configurer::FactHandler do | |
| 22 22 |  | 
| 23 23 | 
             
              let(:facthandler) { FactHandlerTester.new('production') }
         | 
| 24 24 |  | 
| 25 | 
            -
              before :each do
         | 
| 26 | 
            -
                Puppet::Node::Facts.indirection.terminus_class = :memory
         | 
| 27 | 
            -
              end
         | 
| 28 | 
            -
             | 
| 29 25 | 
             
              describe "when finding facts" do
         | 
| 30 26 | 
             
                it "should use the node name value to retrieve the facts" do
         | 
| 31 27 | 
             
                  foo_facts = Puppet::Node::Facts.new('foo')
         | 
| @@ -1,108 +1,89 @@ | |
| 1 1 | 
             
            require 'spec_helper'
         | 
| 2 2 | 
             
            require 'puppet/configurer'
         | 
| 3 | 
            +
            require 'webmock/rspec'
         | 
| 3 4 |  | 
| 4 5 | 
             
            describe Puppet::Configurer do
         | 
| 5 6 | 
             
              before do
         | 
| 6 | 
            -
                allow(Puppet.settings).to receive(:use).and_return(true)
         | 
| 7 | 
            -
                @agent = Puppet::Configurer.new
         | 
| 8 | 
            -
                allow(@agent).to receive(:init_storage)
         | 
| 9 | 
            -
                allow(Puppet::Util::Storage).to receive(:store)
         | 
| 10 7 | 
             
                Puppet[:server] = "puppetmaster"
         | 
| 11 8 | 
             
                Puppet[:report] = true
         | 
| 12 | 
            -
              end
         | 
| 13 9 |  | 
| 14 | 
            -
             | 
| 15 | 
            -
             | 
| 10 | 
            +
                catalog.add_resource(resource)
         | 
| 11 | 
            +
             | 
| 12 | 
            +
                allow(Puppet::SSL::Host).to receive(:localhost).and_return(double('host'))
         | 
| 16 13 | 
             
              end
         | 
| 17 14 |  | 
| 15 | 
            +
              let(:configurer) { Puppet::Configurer.new }
         | 
| 16 | 
            +
              let(:report) { Puppet::Transaction::Report.new }
         | 
| 17 | 
            +
              let(:catalog) { Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote(Puppet[:environment].to_sym)) }
         | 
| 18 | 
            +
              let(:resource) { Puppet::Resource.new(:notice, 'a') }
         | 
| 19 | 
            +
              let(:facts) { Puppet::Node::Facts.new(Puppet[:node_name_value]) }
         | 
| 20 | 
            +
             | 
| 18 21 | 
             
              describe "when executing a pre-run hook" do
         | 
| 19 22 | 
             
                it "should do nothing if the hook is set to an empty string" do
         | 
| 20 23 | 
             
                  Puppet.settings[:prerun_command] = ""
         | 
| 21 | 
            -
                  expect(Puppet::Util).not_to receive(: | 
| 24 | 
            +
                  expect(Puppet::Util::Execution).not_to receive(:execute)
         | 
| 22 25 |  | 
| 23 | 
            -
                   | 
| 26 | 
            +
                  configurer.execute_prerun_command
         | 
| 24 27 | 
             
                end
         | 
| 25 28 |  | 
| 26 29 | 
             
                it "should execute any pre-run command provided via the 'prerun_command' setting" do
         | 
| 27 30 | 
             
                  Puppet.settings[:prerun_command] = "/my/command"
         | 
| 28 31 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 29 32 |  | 
| 30 | 
            -
                   | 
| 33 | 
            +
                  configurer.execute_prerun_command
         | 
| 31 34 | 
             
                end
         | 
| 32 35 |  | 
| 33 36 | 
             
                it "should fail if the command fails" do
         | 
| 34 37 | 
             
                  Puppet.settings[:prerun_command] = "/my/command"
         | 
| 35 38 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 36 39 |  | 
| 37 | 
            -
                  expect( | 
| 40 | 
            +
                  expect(configurer.execute_prerun_command).to be_falsey
         | 
| 38 41 | 
             
                end
         | 
| 39 42 | 
             
              end
         | 
| 40 43 |  | 
| 41 44 | 
             
              describe "when executing a post-run hook" do
         | 
| 42 45 | 
             
                it "should do nothing if the hook is set to an empty string" do
         | 
| 43 46 | 
             
                  Puppet.settings[:postrun_command] = ""
         | 
| 44 | 
            -
                  expect(Puppet::Util).not_to receive(: | 
| 47 | 
            +
                  expect(Puppet::Util::Execution).not_to receive(:execute)
         | 
| 45 48 |  | 
| 46 | 
            -
                   | 
| 49 | 
            +
                  configurer.execute_postrun_command
         | 
| 47 50 | 
             
                end
         | 
| 48 51 |  | 
| 49 52 | 
             
                it "should execute any post-run command provided via the 'postrun_command' setting" do
         | 
| 50 53 | 
             
                  Puppet.settings[:postrun_command] = "/my/command"
         | 
| 51 54 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 52 55 |  | 
| 53 | 
            -
                   | 
| 56 | 
            +
                  configurer.execute_postrun_command
         | 
| 54 57 | 
             
                end
         | 
| 55 58 |  | 
| 56 59 | 
             
                it "should fail if the command fails" do
         | 
| 57 60 | 
             
                  Puppet.settings[:postrun_command] = "/my/command"
         | 
| 58 61 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 59 62 |  | 
| 60 | 
            -
                  expect( | 
| 63 | 
            +
                  expect(configurer.execute_postrun_command).to be_falsey
         | 
| 61 64 | 
             
                end
         | 
| 62 65 | 
             
              end
         | 
| 63 66 |  | 
| 64 67 | 
             
              describe "when executing a catalog run" do
         | 
| 65 68 | 
             
                before do
         | 
| 66 | 
            -
                  allow(Puppet.settings).to receive(:use).and_return(true)
         | 
| 67 | 
            -
                  allow(@agent).to receive(:download_plugins)
         | 
| 68 | 
            -
                  Puppet::Node::Facts.indirection.terminus_class = :memory
         | 
| 69 | 
            -
                  @facts = Puppet::Node::Facts.new(Puppet[:node_name_value])
         | 
| 70 | 
            -
                  Puppet::Node::Facts.indirection.save(@facts)
         | 
| 71 | 
            -
             | 
| 72 | 
            -
                  @catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote(Puppet[:environment].to_sym))
         | 
| 73 | 
            -
                  allow(@catalog).to receive(:to_ral).and_return(@catalog)
         | 
| 74 69 | 
             
                  Puppet::Resource::Catalog.indirection.terminus_class = :rest
         | 
| 75 | 
            -
                  allow(Puppet::Resource::Catalog.indirection).to receive(:find).and_return( | 
| 76 | 
            -
                  allow(@agent).to receive(:send_report)
         | 
| 77 | 
            -
                  allow(@agent).to receive(:save_last_run_summary)
         | 
| 78 | 
            -
             | 
| 79 | 
            -
                  allow(Puppet::Util::Log).to receive(:close_all)
         | 
| 80 | 
            -
                end
         | 
| 81 | 
            -
             | 
| 82 | 
            -
                after :all do
         | 
| 83 | 
            -
                  Puppet::Node::Facts.indirection.reset_terminus_class
         | 
| 84 | 
            -
                  Puppet::Resource::Catalog.indirection.reset_terminus_class
         | 
| 85 | 
            -
                end
         | 
| 86 | 
            -
             | 
| 87 | 
            -
                it "should initialize storage" do
         | 
| 88 | 
            -
                  expect(Puppet::Util::Storage).to receive(:load)
         | 
| 89 | 
            -
                  @agent.run
         | 
| 70 | 
            +
                  allow(Puppet::Resource::Catalog.indirection).to receive(:find).and_return(catalog)
         | 
| 90 71 | 
             
                end
         | 
| 91 72 |  | 
| 92 73 | 
             
                it "downloads plugins when told" do
         | 
| 93 | 
            -
                  expect( | 
| 94 | 
            -
                   | 
| 74 | 
            +
                  expect(configurer).to receive(:download_plugins)
         | 
| 75 | 
            +
                  configurer.run(:pluginsync => true)
         | 
| 95 76 | 
             
                end
         | 
| 96 77 |  | 
| 97 78 | 
             
                it "does not download plugins when told" do
         | 
| 98 | 
            -
                  expect( | 
| 99 | 
            -
                   | 
| 79 | 
            +
                  expect(configurer).not_to receive(:download_plugins)
         | 
| 80 | 
            +
                  configurer.run(:pluginsync => false)
         | 
| 100 81 | 
             
                end
         | 
| 101 82 |  | 
| 102 83 | 
             
                it "should carry on when it can't fetch its node definition" do
         | 
| 103 84 | 
             
                  error = Net::HTTPError.new(400, 'dummy server communication error')
         | 
| 104 85 | 
             
                  expect(Puppet::Node.indirection).to receive(:find).and_raise(error)
         | 
| 105 | 
            -
                  expect( | 
| 86 | 
            +
                  expect(configurer.run).to eq(0)
         | 
| 106 87 | 
             
                end
         | 
| 107 88 |  | 
| 108 89 | 
             
                it "applies a cached catalog when it can't connect to the master" do
         | 
| @@ -110,200 +91,157 @@ describe Puppet::Configurer do | |
| 110 91 |  | 
| 111 92 | 
             
                  expect(Puppet::Node.indirection).to receive(:find).and_raise(error)
         | 
| 112 93 | 
             
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(:ignore_cache => true)).and_raise(error)
         | 
| 113 | 
            -
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(:ignore_terminus => true)).and_return( | 
| 94 | 
            +
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(:ignore_terminus => true)).and_return(catalog)
         | 
| 114 95 |  | 
| 115 | 
            -
                  expect( | 
| 96 | 
            +
                  expect(configurer.run).to eq(0)
         | 
| 116 97 | 
             
                end
         | 
| 117 98 |  | 
| 118 99 | 
             
                it "should initialize a transaction report if one is not provided" do
         | 
| 119 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 120 100 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 121 101 |  | 
| 122 | 
            -
                   | 
| 102 | 
            +
                  configurer.run
         | 
| 123 103 | 
             
                end
         | 
| 124 104 |  | 
| 125 105 | 
             
                it "should respect node_name_fact when setting the host on a report" do
         | 
| 126 106 | 
             
                  Puppet[:node_name_fact] = 'my_name_fact'
         | 
| 127 | 
            -
                   | 
| 107 | 
            +
                  facts.values = {'my_name_fact' => 'node_name_from_fact'}
         | 
| 108 | 
            +
                  Puppet::Node::Facts.indirection.save(facts)
         | 
| 128 109 |  | 
| 129 | 
            -
                  report  | 
| 130 | 
            -
             | 
| 131 | 
            -
                  @agent.run(:report => report)
         | 
| 110 | 
            +
                  configurer.run(:report => report)
         | 
| 132 111 | 
             
                  expect(report.host).to eq('node_name_from_fact')
         | 
| 133 112 | 
             
                end
         | 
| 134 113 |  | 
| 135 | 
            -
                it " | 
| 136 | 
            -
                   | 
| 137 | 
            -
                   | 
| 138 | 
            -
                  expect(@catalog).to receive(:apply).with(hash_including(report: report))
         | 
| 139 | 
            -
             | 
| 140 | 
            -
                  @agent.run
         | 
| 141 | 
            -
                end
         | 
| 142 | 
            -
             | 
| 143 | 
            -
                it "should use the provided report if it was passed one" do
         | 
| 144 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 145 | 
            -
                  expect(@catalog).to receive(:apply).with(hash_including(report: report))
         | 
| 146 | 
            -
             | 
| 147 | 
            -
                  @agent.run(:report => report)
         | 
| 148 | 
            -
                end
         | 
| 149 | 
            -
             | 
| 150 | 
            -
                it "should set the report as a log destination" do
         | 
| 151 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 152 | 
            -
             | 
| 153 | 
            -
                  expect(report).to receive(:<<).with(instance_of(Puppet::Util::Log)).at_least(:once)
         | 
| 114 | 
            +
                it "creates a new report when applying the catalog" do
         | 
| 115 | 
            +
                  options = {}
         | 
| 116 | 
            +
                  configurer.run(options)
         | 
| 154 117 |  | 
| 155 | 
            -
                   | 
| 118 | 
            +
                  expect(options[:report].metrics['time']['catalog_application']).to be_an_instance_of(Float)
         | 
| 156 119 | 
             
                end
         | 
| 157 120 |  | 
| 158 | 
            -
                it " | 
| 159 | 
            -
                   | 
| 121 | 
            +
                it "uses the provided report when applying the catalog" do
         | 
| 122 | 
            +
                  configurer.run(:report => report)
         | 
| 160 123 |  | 
| 161 | 
            -
                   | 
| 124 | 
            +
                  expect(report.metrics['time']['catalog_application']).to be_an_instance_of(Float)
         | 
| 162 125 | 
             
                end
         | 
| 163 126 |  | 
| 164 127 | 
             
                it "should log a failure and do nothing if no catalog can be retrieved" do
         | 
| 165 | 
            -
                  expect( | 
| 128 | 
            +
                  expect(configurer).to receive(:retrieve_catalog).and_return(nil)
         | 
| 166 129 |  | 
| 167 130 | 
             
                  expect(Puppet).to receive(:err).with("Could not retrieve catalog; skipping run")
         | 
| 168 131 |  | 
| 169 | 
            -
                   | 
| 170 | 
            -
                end
         | 
| 171 | 
            -
             | 
| 172 | 
            -
                it "should apply the catalog with all options to :run" do
         | 
| 173 | 
            -
                  expect(@agent).to receive(:retrieve_catalog).and_return(@catalog)
         | 
| 174 | 
            -
             | 
| 175 | 
            -
                  expect(@catalog).to receive(:apply).with(hash_including(one: true))
         | 
| 176 | 
            -
                  @agent.run :one => true
         | 
| 132 | 
            +
                  configurer.run
         | 
| 177 133 | 
             
                end
         | 
| 178 134 |  | 
| 179 | 
            -
                it " | 
| 180 | 
            -
                  expect( | 
| 135 | 
            +
                it "passes arbitrary options when applying the catalog" do
         | 
| 136 | 
            +
                  expect(catalog).to receive(:apply).with(hash_including(one: true))
         | 
| 181 137 |  | 
| 182 | 
            -
                   | 
| 183 | 
            -
                  @agent.run :one => true, :catalog => @catalog
         | 
| 138 | 
            +
                  configurer.run(catalog: catalog, one: true)
         | 
| 184 139 | 
             
                end
         | 
| 185 140 |  | 
| 186 141 | 
             
                it "should benchmark how long it takes to apply the catalog" do
         | 
| 187 | 
            -
                   | 
| 188 | 
            -
             | 
| 189 | 
            -
                  expect(@agent).to receive(:retrieve_catalog).and_return(@catalog)
         | 
| 190 | 
            -
             | 
| 191 | 
            -
                  expect(@catalog).not_to receive(:apply) # because we're not yielding
         | 
| 192 | 
            -
                  @agent.run
         | 
| 193 | 
            -
                end
         | 
| 194 | 
            -
             | 
| 195 | 
            -
                it "should execute post-run hooks after the run" do
         | 
| 196 | 
            -
                  expect(@agent).to receive(:execute_postrun_command)
         | 
| 142 | 
            +
                  configurer.run(report: report)
         | 
| 197 143 |  | 
| 198 | 
            -
                   | 
| 144 | 
            +
                  expect(report.logs).to include(an_object_having_attributes(level: :notice, message: /Applied catalog in .* seconds/))
         | 
| 199 145 | 
             
                end
         | 
| 200 146 |  | 
| 201 147 | 
             
                it "should create report with passed transaction_uuid and job_id" do
         | 
| 202 | 
            -
                   | 
| 203 | 
            -
                  allow(@agent).to receive(:init_storage)
         | 
| 148 | 
            +
                  configurer = Puppet::Configurer.new("test_tuuid", "test_jid")
         | 
| 204 149 |  | 
| 205 150 | 
             
                  report = Puppet::Transaction::Report.new(nil, "test", "aaaa")
         | 
| 206 151 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).with(anything, anything, 'test_tuuid', 'test_jid').and_return(report)
         | 
| 207 | 
            -
                  expect( | 
| 152 | 
            +
                  expect(configurer).to receive(:send_report).with(report)
         | 
| 208 153 |  | 
| 209 | 
            -
                   | 
| 154 | 
            +
                  configurer.run
         | 
| 210 155 | 
             
                end
         | 
| 211 156 |  | 
| 212 157 | 
             
                it "should send the report" do
         | 
| 213 158 | 
             
                  report = Puppet::Transaction::Report.new(nil, "test", "aaaa")
         | 
| 214 159 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 215 | 
            -
                  expect( | 
| 160 | 
            +
                  expect(configurer).to receive(:send_report).with(report)
         | 
| 216 161 |  | 
| 217 162 | 
             
                  expect(report.environment).to eq("test")
         | 
| 218 163 | 
             
                  expect(report.transaction_uuid).to eq("aaaa")
         | 
| 219 164 |  | 
| 220 | 
            -
                   | 
| 165 | 
            +
                  configurer.run
         | 
| 221 166 | 
             
                end
         | 
| 222 167 |  | 
| 223 168 | 
             
                it "should send the transaction report even if the catalog could not be retrieved" do
         | 
| 224 | 
            -
                  expect( | 
| 169 | 
            +
                  expect(configurer).to receive(:retrieve_catalog).and_return(nil)
         | 
| 225 170 |  | 
| 226 171 | 
             
                  report = Puppet::Transaction::Report.new(nil, "test", "aaaa")
         | 
| 227 172 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 228 | 
            -
                  expect( | 
| 173 | 
            +
                  expect(configurer).to receive(:send_report).with(report)
         | 
| 229 174 |  | 
| 230 175 | 
             
                  expect(report.environment).to eq("test")
         | 
| 231 176 | 
             
                  expect(report.transaction_uuid).to eq("aaaa")
         | 
| 232 177 |  | 
| 233 | 
            -
                   | 
| 178 | 
            +
                  configurer.run
         | 
| 234 179 | 
             
                end
         | 
| 235 180 |  | 
| 236 181 | 
             
                it "should send the transaction report even if there is a failure" do
         | 
| 237 | 
            -
                  expect( | 
| 182 | 
            +
                  expect(configurer).to receive(:retrieve_catalog).and_raise("whatever")
         | 
| 238 183 |  | 
| 239 184 | 
             
                  report = Puppet::Transaction::Report.new(nil, "test", "aaaa")
         | 
| 240 185 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 241 | 
            -
                  expect( | 
| 186 | 
            +
                  expect(configurer).to receive(:send_report).with(report)
         | 
| 242 187 |  | 
| 243 188 | 
             
                  expect(report.environment).to eq("test")
         | 
| 244 189 | 
             
                  expect(report.transaction_uuid).to eq("aaaa")
         | 
| 245 190 |  | 
| 246 | 
            -
                  expect( | 
| 191 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 247 192 | 
             
                end
         | 
| 248 193 |  | 
| 249 194 | 
             
                it "should remove the report as a log destination when the run is finished" do
         | 
| 250 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 251 195 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 252 196 |  | 
| 253 | 
            -
                   | 
| 197 | 
            +
                  configurer.run
         | 
| 254 198 |  | 
| 255 199 | 
             
                  expect(Puppet::Util::Log.destinations).not_to include(report)
         | 
| 256 200 | 
             
                end
         | 
| 257 201 |  | 
| 258 202 | 
             
                it "should return the report exit_status as the result of the run" do
         | 
| 259 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 260 203 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 261 204 | 
             
                  expect(report).to receive(:exit_status).and_return(1234)
         | 
| 262 205 |  | 
| 263 | 
            -
                  expect( | 
| 206 | 
            +
                  expect(configurer.run).to eq(1234)
         | 
| 264 207 | 
             
                end
         | 
| 265 208 |  | 
| 266 209 | 
             
                it "should return nil if catalog application fails" do
         | 
| 267 | 
            -
                   | 
| 268 | 
            -
                  report  | 
| 269 | 
            -
                  expect(@agent.run(catalog: @catalog, report: report)).to be_nil
         | 
| 210 | 
            +
                  expect_any_instance_of(Puppet::Resource::Catalog).to receive(:apply).and_raise(Puppet::Error, 'One or more resource dependency cycles detected in graph')
         | 
| 211 | 
            +
                  expect(configurer.run(catalog: catalog, report: report)).to be_nil
         | 
| 270 212 | 
             
                end
         | 
| 271 213 |  | 
| 272 214 | 
             
                it "should send the transaction report even if the pre-run command fails" do
         | 
| 273 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 274 215 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 275 216 |  | 
| 276 217 | 
             
                  Puppet.settings[:prerun_command] = "/my/command"
         | 
| 277 218 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 278 | 
            -
                  expect( | 
| 219 | 
            +
                  expect(configurer).to receive(:send_report).with(report)
         | 
| 279 220 |  | 
| 280 | 
            -
                  expect( | 
| 221 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 281 222 | 
             
                end
         | 
| 282 223 |  | 
| 283 224 | 
             
                it "should include the pre-run command failure in the report" do
         | 
| 284 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 285 225 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 286 226 |  | 
| 287 227 | 
             
                  Puppet.settings[:prerun_command] = "/my/command"
         | 
| 288 228 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 289 229 |  | 
| 290 | 
            -
                  expect( | 
| 230 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 291 231 | 
             
                  expect(report.logs.find { |x| x.message =~ /Could not run command from prerun_command/ }).to be
         | 
| 292 232 | 
             
                end
         | 
| 293 233 |  | 
| 294 234 | 
             
                it "should send the transaction report even if the post-run command fails" do
         | 
| 295 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 296 235 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 297 236 |  | 
| 298 237 | 
             
                  Puppet.settings[:postrun_command] = "/my/command"
         | 
| 299 238 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 300 | 
            -
                  expect( | 
| 239 | 
            +
                  expect(configurer).to receive(:send_report).with(report)
         | 
| 301 240 |  | 
| 302 | 
            -
                  expect( | 
| 241 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 303 242 | 
             
                end
         | 
| 304 243 |  | 
| 305 244 | 
             
                it "should include the post-run command failure in the report" do
         | 
| 306 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 307 245 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 308 246 |  | 
| 309 247 | 
             
                  Puppet.settings[:postrun_command] = "/my/command"
         | 
| @@ -311,7 +249,7 @@ describe Puppet::Configurer do | |
| 311 249 |  | 
| 312 250 | 
             
                  expect(report).to receive(:<<) { |log, _| expect(log.message).to match(/Could not run command from postrun_command/) }.at_least(:once)
         | 
| 313 251 |  | 
| 314 | 
            -
                  expect( | 
| 252 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 315 253 | 
             
                end
         | 
| 316 254 |  | 
| 317 255 | 
             
                it "should execute post-run command even if the pre-run command fails" do
         | 
| @@ -320,47 +258,42 @@ describe Puppet::Configurer do | |
| 320 258 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/precommand"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 321 259 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/postcommand"])
         | 
| 322 260 |  | 
| 323 | 
            -
                  expect( | 
| 261 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 324 262 | 
             
                end
         | 
| 325 263 |  | 
| 326 264 | 
             
                it "should finalize the report" do
         | 
| 327 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 328 265 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 329 266 |  | 
| 330 267 | 
             
                  expect(report).to receive(:finalize_report)
         | 
| 331 | 
            -
                   | 
| 268 | 
            +
                  configurer.run
         | 
| 332 269 | 
             
                end
         | 
| 333 270 |  | 
| 334 271 | 
             
                it "should not apply the catalog if the pre-run command fails" do
         | 
| 335 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 336 272 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 337 273 |  | 
| 338 274 | 
             
                  Puppet.settings[:prerun_command] = "/my/command"
         | 
| 339 275 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 340 276 |  | 
| 341 | 
            -
                   | 
| 342 | 
            -
                  expect( | 
| 277 | 
            +
                  expect_any_instance_of(Puppet::Resource::Catalog).not_to receive(:apply)
         | 
| 278 | 
            +
                  expect(configurer).to receive(:send_report)
         | 
| 343 279 |  | 
| 344 | 
            -
                  expect( | 
| 280 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 345 281 | 
             
                end
         | 
| 346 282 |  | 
| 347 283 | 
             
                it "should apply the catalog, send the report, and return nil if the post-run command fails" do
         | 
| 348 | 
            -
                  report = Puppet::Transaction::Report.new
         | 
| 349 284 | 
             
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 350 285 |  | 
| 351 286 | 
             
                  Puppet.settings[:postrun_command] = "/my/command"
         | 
| 352 287 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 353 288 |  | 
| 354 | 
            -
                   | 
| 355 | 
            -
                  expect( | 
| 289 | 
            +
                  expect_any_instance_of(Puppet::Resource::Catalog).to receive(:apply)
         | 
| 290 | 
            +
                  expect(configurer).to receive(:send_report)
         | 
| 356 291 |  | 
| 357 | 
            -
                  expect( | 
| 292 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 358 293 | 
             
                end
         | 
| 359 294 |  | 
| 360 295 | 
             
                it 'includes total time metrics in the report after successfully applying the catalog' do
         | 
| 361 | 
            -
                  report  | 
| 362 | 
            -
                  allow(@catalog).to receive(:apply).with(:report => report)
         | 
| 363 | 
            -
                  @agent.run(report: report)
         | 
| 296 | 
            +
                  configurer.run(report: report)
         | 
| 364 297 |  | 
| 365 298 | 
             
                  expect(report.metrics['time']).to be
         | 
| 366 299 | 
             
                  expect(report.metrics['time']['total']).to be_a_kind_of(Numeric)
         | 
| @@ -370,17 +303,15 @@ describe Puppet::Configurer do | |
| 370 303 | 
             
                  Puppet.settings[:prerun_command] = "/my/command"
         | 
| 371 304 | 
             
                  expect(Puppet::Util::Execution).to receive(:execute).with(["/my/command"]).and_raise(Puppet::ExecutionFailure, "Failed")
         | 
| 372 305 |  | 
| 373 | 
            -
                  report  | 
| 374 | 
            -
                  @agent.run(report: report)
         | 
| 306 | 
            +
                  configurer.run(report: report)
         | 
| 375 307 |  | 
| 376 308 | 
             
                  expect(report.metrics['time']).to be
         | 
| 377 309 | 
             
                  expect(report.metrics['time']['total']).to be_a_kind_of(Numeric)
         | 
| 378 310 | 
             
                end
         | 
| 379 311 |  | 
| 380 312 | 
             
                it 'includes total time metrics in the report even if catalog retrieval fails' do
         | 
| 381 | 
            -
                   | 
| 382 | 
            -
                   | 
| 383 | 
            -
                  @agent.run(:report => report)
         | 
| 313 | 
            +
                  allow(configurer).to receive(:prepare_and_retrieve_catalog_from_cache).and_raise
         | 
| 314 | 
            +
                  configurer.run(:report => report)
         | 
| 384 315 |  | 
| 385 316 | 
             
                  expect(report.metrics['time']).to be
         | 
| 386 317 | 
             
                  expect(report.metrics['time']['total']).to be_a_kind_of(Numeric)
         | 
| @@ -388,96 +319,93 @@ describe Puppet::Configurer do | |
| 388 319 |  | 
| 389 320 | 
             
                it "should refetch the catalog if the server specifies a new environment in the catalog" do
         | 
| 390 321 | 
             
                  catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote('second_env'))
         | 
| 391 | 
            -
                  expect( | 
| 322 | 
            +
                  expect(configurer).to receive(:retrieve_catalog).and_return(catalog).twice
         | 
| 392 323 |  | 
| 393 | 
            -
                   | 
| 324 | 
            +
                  configurer.run
         | 
| 394 325 | 
             
                end
         | 
| 395 326 |  | 
| 396 | 
            -
                it " | 
| 397 | 
            -
                   | 
| 327 | 
            +
                it "changes the configurer's environment if the server specifies a new environment in the catalog" do
         | 
| 328 | 
            +
                  allow_any_instance_of(Puppet::Resource::Catalog).to receive(:environment).and_return("second_env")
         | 
| 398 329 |  | 
| 399 | 
            -
                   | 
| 330 | 
            +
                  configurer.run
         | 
| 400 331 |  | 
| 401 | 
            -
                  expect( | 
| 332 | 
            +
                  expect(configurer.environment).to eq("second_env")
         | 
| 402 333 | 
             
                end
         | 
| 403 334 |  | 
| 404 | 
            -
                it " | 
| 405 | 
            -
                   | 
| 406 | 
            -
                  expect(Puppet::Transaction::Report).to receive(:new).and_return(report)
         | 
| 407 | 
            -
                  expect(@agent).to receive(:send_report).with(report)
         | 
| 335 | 
            +
                it "changes the report's environment if the server specifies a new environment in the catalog" do
         | 
| 336 | 
            +
                  allow_any_instance_of(Puppet::Resource::Catalog).to receive(:environment).and_return("second_env")
         | 
| 408 337 |  | 
| 409 | 
            -
                   | 
| 410 | 
            -
                  allow(@agent).to receive(:retrieve_catalog).and_return(@catalog)
         | 
| 411 | 
            -
             | 
| 412 | 
            -
                  @agent.run
         | 
| 338 | 
            +
                  configurer.run(report: report)
         | 
| 413 339 |  | 
| 414 340 | 
             
                  expect(report.environment).to eq("second_env")
         | 
| 415 341 | 
             
                end
         | 
| 416 342 |  | 
| 417 343 | 
             
                it "sends the transaction uuid in a catalog request" do
         | 
| 418 | 
            -
                   | 
| 344 | 
            +
                  configurer = Puppet::Configurer.new('aaa')
         | 
| 419 345 | 
             
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(transaction_uuid: 'aaa'))
         | 
| 420 | 
            -
                   | 
| 346 | 
            +
                  configurer.run
         | 
| 421 347 | 
             
                end
         | 
| 422 348 |  | 
| 423 349 | 
             
                it "sends the transaction uuid in a catalog request" do
         | 
| 424 | 
            -
                   | 
| 350 | 
            +
                  configurer = Puppet::Configurer.new('b', 'aaa')
         | 
| 425 351 | 
             
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(job_id: 'aaa'))
         | 
| 426 | 
            -
                   | 
| 352 | 
            +
                  configurer.run
         | 
| 427 353 | 
             
                end
         | 
| 428 354 |  | 
| 429 355 | 
             
                it "sets the static_catalog query param to true in a catalog request" do
         | 
| 430 356 | 
             
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(static_catalog: true))
         | 
| 431 | 
            -
                   | 
| 357 | 
            +
                  configurer.run
         | 
| 432 358 | 
             
                end
         | 
| 433 359 |  | 
| 434 360 | 
             
                it "sets the checksum_type query param to the default supported_checksum_types in a catalog request" do
         | 
| 435 361 | 
             
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything,
         | 
| 436 362 | 
             
                    hash_including(checksum_type: 'md5.sha256.sha384.sha512.sha224'))
         | 
| 437 | 
            -
                   | 
| 363 | 
            +
                  configurer.run
         | 
| 438 364 | 
             
                end
         | 
| 439 365 |  | 
| 440 366 | 
             
                it "sets the checksum_type query param to the supported_checksum_types setting in a catalog request" do
         | 
| 441 | 
            -
                  # Regenerate the agent to pick up the new setting
         | 
| 442 367 | 
             
                  Puppet[:supported_checksum_types] = ['sha256']
         | 
| 443 | 
            -
                   | 
| 444 | 
            -
                   | 
| 445 | 
            -
                  allow(@agent).to receive(:download_plugins)
         | 
| 446 | 
            -
                  allow(@agent).to receive(:send_report)
         | 
| 447 | 
            -
                  allow(@agent).to receive(:save_last_run_summary)
         | 
| 368 | 
            +
                  # Regenerate the agent to pick up the new setting
         | 
| 369 | 
            +
                  configurer = Puppet::Configurer.new
         | 
| 448 370 |  | 
| 449 371 | 
             
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(checksum_type: 'sha256'))
         | 
| 450 | 
            -
                   | 
| 372 | 
            +
                  configurer.run
         | 
| 451 373 | 
             
                end
         | 
| 452 374 |  | 
| 453 375 | 
             
                describe "when not using a REST terminus for catalogs" do
         | 
| 454 376 | 
             
                  it "should not pass any facts when retrieving the catalog" do
         | 
| 377 | 
            +
                    # This is weird, we collect facts when constructing the node,
         | 
| 378 | 
            +
                    # but we don't send them in the indirector request. Then the compiler
         | 
| 379 | 
            +
                    # looks up the node, and collects its facts, which we could have sent
         | 
| 380 | 
            +
                    # in the first place. This seems like a bug.
         | 
| 455 381 | 
             
                    Puppet::Resource::Catalog.indirection.terminus_class = :compiler
         | 
| 456 | 
            -
             | 
| 382 | 
            +
             | 
| 457 383 | 
             
                    expect(Puppet::Resource::Catalog.indirection).to receive(:find) do |name, options|
         | 
| 458 | 
            -
                      options[:facts]. | 
| 459 | 
            -
                    end.and_return( | 
| 384 | 
            +
                      expect(options[:facts]).to be_nil
         | 
| 385 | 
            +
                    end.and_return(catalog)
         | 
| 460 386 |  | 
| 461 | 
            -
                     | 
| 387 | 
            +
                    configurer.run
         | 
| 462 388 | 
             
                  end
         | 
| 463 389 | 
             
                end
         | 
| 464 390 |  | 
| 465 391 | 
             
                describe "when using a REST terminus for catalogs" do
         | 
| 466 | 
            -
                  it "should pass the  | 
| 392 | 
            +
                  it "should pass the url encoded facts and facts format as arguments when retrieving the catalog" do
         | 
| 467 393 | 
             
                    Puppet::Resource::Catalog.indirection.terminus_class = :rest
         | 
| 468 | 
            -
                    expect(@agent).to receive(:facts_for_uploading).and_return(:facts => "myfacts", :facts_format => :foo)
         | 
| 469 | 
            -
                    expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(facts: "myfacts", facts_format: :foo)).and_return(@catalog)
         | 
| 470 394 |  | 
| 471 | 
            -
                     | 
| 472 | 
            -
             | 
| 473 | 
            -
             | 
| 474 | 
            -
             | 
| 395 | 
            +
                    facts.values = { 'foo' => 'bar' }
         | 
| 396 | 
            +
                    Puppet::Node::Facts.indirection.save(facts)
         | 
| 397 | 
            +
             | 
| 398 | 
            +
                    expect(
         | 
| 399 | 
            +
                      Puppet::Resource::Catalog.indirection
         | 
| 400 | 
            +
                    ).to receive(:find) do |_, options|
         | 
| 401 | 
            +
                      expect(options[:facts_format]).to eq("application/json")
         | 
| 475 402 |  | 
| 476 | 
            -
             | 
| 477 | 
            -
             | 
| 478 | 
            -
             | 
| 479 | 
            -
             | 
| 480 | 
            -
             | 
| 403 | 
            +
                      unescaped = JSON.parse(CGI.unescape(options[:facts]))
         | 
| 404 | 
            +
                      expect(unescaped).to include("values" => {"foo" => "bar"})
         | 
| 405 | 
            +
                    end.and_return(catalog)
         | 
| 406 | 
            +
             | 
| 407 | 
            +
                    configurer.run
         | 
| 408 | 
            +
                  end
         | 
| 481 409 | 
             
                end
         | 
| 482 410 | 
             
              end
         | 
| 483 411 |  | 
| @@ -485,56 +413,52 @@ describe Puppet::Configurer do | |
| 485 413 | 
             
                include PuppetSpec::Files
         | 
| 486 414 |  | 
| 487 415 | 
             
                before do
         | 
| 488 | 
            -
                  allow(Puppet.settings).to receive(:use).and_return(true)
         | 
| 489 | 
            -
                  @configurer = Puppet::Configurer.new
         | 
| 490 416 | 
             
                  Puppet[:lastrunfile] = tmpfile('last_run_file')
         | 
| 491 | 
            -
             | 
| 492 | 
            -
                  @report = Puppet::Transaction::Report.new
         | 
| 493 417 | 
             
                  Puppet[:reports] = "none"
         | 
| 494 418 | 
             
                end
         | 
| 495 419 |  | 
| 496 420 | 
             
                it "should print a report summary if configured to do so" do
         | 
| 497 421 | 
             
                  Puppet.settings[:summarize] = true
         | 
| 498 422 |  | 
| 499 | 
            -
                  expect( | 
| 423 | 
            +
                  expect(report).to receive(:summary).and_return("stuff")
         | 
| 500 424 |  | 
| 501 | 
            -
                  expect( | 
| 502 | 
            -
                   | 
| 425 | 
            +
                  expect(configurer).to receive(:puts).with("stuff")
         | 
| 426 | 
            +
                  configurer.send_report(report)
         | 
| 503 427 | 
             
                end
         | 
| 504 428 |  | 
| 505 429 | 
             
                it "should not print a report summary if not configured to do so" do
         | 
| 506 430 | 
             
                  Puppet.settings[:summarize] = false
         | 
| 507 431 |  | 
| 508 | 
            -
                  expect( | 
| 509 | 
            -
                   | 
| 432 | 
            +
                  expect(configurer).not_to receive(:puts)
         | 
| 433 | 
            +
                  configurer.send_report(report)
         | 
| 510 434 | 
             
                end
         | 
| 511 435 |  | 
| 512 436 | 
             
                it "should save the report if reporting is enabled" do
         | 
| 513 437 | 
             
                  Puppet.settings[:report] = true
         | 
| 514 438 |  | 
| 515 | 
            -
                  expect(Puppet::Transaction::Report.indirection).to receive(:save).with( | 
| 516 | 
            -
                   | 
| 439 | 
            +
                  expect(Puppet::Transaction::Report.indirection).to receive(:save).with(report, nil, instance_of(Hash))
         | 
| 440 | 
            +
                  configurer.send_report(report)
         | 
| 517 441 | 
             
                end
         | 
| 518 442 |  | 
| 519 443 | 
             
                it "should not save the report if reporting is disabled" do
         | 
| 520 444 | 
             
                  Puppet.settings[:report] = false
         | 
| 521 445 |  | 
| 522 | 
            -
                  expect(Puppet::Transaction::Report.indirection).not_to receive(:save).with( | 
| 523 | 
            -
                   | 
| 446 | 
            +
                  expect(Puppet::Transaction::Report.indirection).not_to receive(:save).with(report, nil, instance_of(Hash))
         | 
| 447 | 
            +
                  configurer.send_report(report)
         | 
| 524 448 | 
             
                end
         | 
| 525 449 |  | 
| 526 450 | 
             
                it "should save the last run summary if reporting is enabled" do
         | 
| 527 451 | 
             
                  Puppet.settings[:report] = true
         | 
| 528 452 |  | 
| 529 | 
            -
                  expect( | 
| 530 | 
            -
                   | 
| 453 | 
            +
                  expect(configurer).to receive(:save_last_run_summary).with(report)
         | 
| 454 | 
            +
                  configurer.send_report(report)
         | 
| 531 455 | 
             
                end
         | 
| 532 456 |  | 
| 533 457 | 
             
                it "should save the last run summary if reporting is disabled" do
         | 
| 534 458 | 
             
                  Puppet.settings[:report] = false
         | 
| 535 459 |  | 
| 536 | 
            -
                  expect( | 
| 537 | 
            -
                   | 
| 460 | 
            +
                  expect(configurer).to receive(:save_last_run_summary).with(report)
         | 
| 461 | 
            +
                  configurer.send_report(report)
         | 
| 538 462 | 
             
                end
         | 
| 539 463 |  | 
| 540 464 | 
             
                it "should log but not fail if saving the report fails" do
         | 
| @@ -543,7 +467,7 @@ describe Puppet::Configurer do | |
| 543 467 | 
             
                  expect(Puppet::Transaction::Report.indirection).to receive(:save).and_raise("whatever")
         | 
| 544 468 |  | 
| 545 469 | 
             
                  expect(Puppet).to receive(:err)
         | 
| 546 | 
            -
                  expect {  | 
| 470 | 
            +
                  expect { configurer.send_report(report) }.not_to raise_error
         | 
| 547 471 | 
             
                end
         | 
| 548 472 | 
             
              end
         | 
| 549 473 |  | 
| @@ -551,22 +475,17 @@ describe Puppet::Configurer do | |
| 551 475 | 
             
                include PuppetSpec::Files
         | 
| 552 476 |  | 
| 553 477 | 
             
                before do
         | 
| 554 | 
            -
                  allow(Puppet.settings).to receive(:use).and_return(true)
         | 
| 555 | 
            -
                  @configurer = Puppet::Configurer.new
         | 
| 556 | 
            -
             | 
| 557 | 
            -
                  @report = double('report', :raw_summary => {})
         | 
| 558 | 
            -
             | 
| 559 478 | 
             
                  Puppet[:lastrunfile] = tmpfile('last_run_file')
         | 
| 560 479 | 
             
                end
         | 
| 561 480 |  | 
| 562 481 | 
             
                it "should write the last run file" do
         | 
| 563 | 
            -
                   | 
| 482 | 
            +
                  configurer.save_last_run_summary(report)
         | 
| 564 483 | 
             
                  expect(Puppet::FileSystem.exist?(Puppet[:lastrunfile])).to be_truthy
         | 
| 565 484 | 
             
                end
         | 
| 566 485 |  | 
| 567 486 | 
             
                it "should write the raw summary as yaml" do
         | 
| 568 | 
            -
                  expect( | 
| 569 | 
            -
                   | 
| 487 | 
            +
                  expect(report).to receive(:raw_summary).and_return("summary")
         | 
| 488 | 
            +
                  configurer.save_last_run_summary(report)
         | 
| 570 489 | 
             
                  expect(File.read(Puppet[:lastrunfile])).to eq(YAML.dump("summary"))
         | 
| 571 490 | 
             
                end
         | 
| 572 491 |  | 
| @@ -582,12 +501,12 @@ describe Puppet::Configurer do | |
| 582 501 | 
             
                  expect(Puppet::Util).to receive(:replace_file).and_yield(fh)
         | 
| 583 502 |  | 
| 584 503 | 
             
                  expect(Puppet).to receive(:err)
         | 
| 585 | 
            -
                  expect {  | 
| 504 | 
            +
                  expect { configurer.save_last_run_summary(report) }.to_not raise_error
         | 
| 586 505 | 
             
                end
         | 
| 587 506 |  | 
| 588 507 | 
             
                it "should create the last run file with the correct mode" do
         | 
| 589 508 | 
             
                  expect(Puppet.settings.setting(:lastrunfile)).to receive(:mode).and_return('664')
         | 
| 590 | 
            -
                   | 
| 509 | 
            +
                  configurer.save_last_run_summary(report)
         | 
| 591 510 |  | 
| 592 511 | 
             
                  if Puppet::Util::Platform.windows?
         | 
| 593 512 | 
             
                    require 'puppet/util/windows/security'
         | 
| @@ -601,25 +520,25 @@ describe Puppet::Configurer do | |
| 601 520 | 
             
                it "should report invalid last run file permissions" do
         | 
| 602 521 | 
             
                  expect(Puppet.settings.setting(:lastrunfile)).to receive(:mode).and_return('892')
         | 
| 603 522 | 
             
                  expect(Puppet).to receive(:err).with(/Could not save last run local report.*892 is invalid/)
         | 
| 604 | 
            -
                   | 
| 523 | 
            +
                  configurer.save_last_run_summary(report)
         | 
| 605 524 | 
             
                end
         | 
| 606 525 | 
             
              end
         | 
| 607 526 |  | 
| 608 527 | 
             
              describe "when requesting a node" do
         | 
| 609 528 | 
             
                it "uses the transaction uuid in the request" do
         | 
| 610 529 | 
             
                  expect(Puppet::Node.indirection).to receive(:find).with(anything, hash_including(transaction_uuid: anything)).twice
         | 
| 611 | 
            -
                   | 
| 530 | 
            +
                  configurer.run
         | 
| 612 531 | 
             
                end
         | 
| 613 532 |  | 
| 614 533 | 
             
                it "sends an explicitly configured environment request" do
         | 
| 615 534 | 
             
                  expect(Puppet.settings).to receive(:set_by_config?).with(:environment).and_return(true)
         | 
| 616 535 | 
             
                  expect(Puppet::Node.indirection).to receive(:find).with(anything, hash_including(configured_environment: Puppet[:environment])).twice
         | 
| 617 | 
            -
                   | 
| 536 | 
            +
                  configurer.run
         | 
| 618 537 | 
             
                end
         | 
| 619 538 |  | 
| 620 539 | 
             
                it "does not send a configured_environment when using the default" do
         | 
| 621 540 | 
             
                  expect(Puppet::Node.indirection).to receive(:find).with(anything, hash_including(configured_environment: nil)).twice
         | 
| 622 | 
            -
                   | 
| 541 | 
            +
                  configurer.run
         | 
| 623 542 | 
             
                end
         | 
| 624 543 | 
             
              end
         | 
| 625 544 |  | 
| @@ -650,14 +569,6 @@ describe Puppet::Configurer do | |
| 650 569 |  | 
| 651 570 | 
             
              describe "when retrieving a catalog" do
         | 
| 652 571 | 
             
                before do
         | 
| 653 | 
            -
                  allow(Puppet.settings).to receive(:use).and_return(true)
         | 
| 654 | 
            -
                  allow(@agent).to receive(:facts_for_uploading).and_return({})
         | 
| 655 | 
            -
                  allow(@agent).to receive(:download_plugins)
         | 
| 656 | 
            -
             | 
| 657 | 
            -
                  # retrieve a catalog in the current environment, so we don't try to converge unexpectedly
         | 
| 658 | 
            -
                  @catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote(Puppet[:environment].to_sym))
         | 
| 659 | 
            -
             | 
| 660 | 
            -
                  # this is the default when using a Configurer instance
         | 
| 661 572 | 
             
                  allow(Puppet::Resource::Catalog.indirection).to receive(:terminus_class).and_return(:rest)
         | 
| 662 573 | 
             
                end
         | 
| 663 574 |  | 
| @@ -667,100 +578,128 @@ describe Puppet::Configurer do | |
| 667 578 | 
             
                  end
         | 
| 668 579 |  | 
| 669 580 | 
             
                  it "should first look in the cache for a catalog" do
         | 
| 670 | 
            -
                    expects_cached_catalog_only( | 
| 581 | 
            +
                    expects_cached_catalog_only(catalog)
         | 
| 671 582 |  | 
| 672 | 
            -
                     | 
| 583 | 
            +
                    configurer.run
         | 
| 673 584 | 
             
                  end
         | 
| 674 585 |  | 
| 675 586 | 
             
                  it "should not make a node request or pluginsync when a cached catalog is successfully retrieved" do
         | 
| 676 587 | 
             
                    expect(Puppet::Node.indirection).not_to receive(:find)
         | 
| 677 | 
            -
                    expects_cached_catalog_only( | 
| 678 | 
            -
                    expect( | 
| 588 | 
            +
                    expects_cached_catalog_only(catalog)
         | 
| 589 | 
            +
                    expect(configurer).not_to receive(:download_plugins)
         | 
| 679 590 |  | 
| 680 | 
            -
                     | 
| 591 | 
            +
                    configurer.run
         | 
| 681 592 | 
             
                  end
         | 
| 682 593 |  | 
| 683 594 | 
             
                  it "should make a node request and pluginsync when a cached catalog cannot be retrieved" do
         | 
| 684 595 | 
             
                    expect(Puppet::Node.indirection).to receive(:find).and_return(nil)
         | 
| 685 | 
            -
                    expects_fallback_to_new_catalog( | 
| 686 | 
            -
                    expect( | 
| 596 | 
            +
                    expects_fallback_to_new_catalog(catalog)
         | 
| 597 | 
            +
                    expect(configurer).to receive(:download_plugins)
         | 
| 687 598 |  | 
| 688 | 
            -
                     | 
| 599 | 
            +
                    configurer.run
         | 
| 689 600 | 
             
                  end
         | 
| 690 601 |  | 
| 691 602 | 
             
                  it "should set its cached_catalog_status to 'explicitly_requested'" do
         | 
| 692 | 
            -
                    expects_cached_catalog_only( | 
| 603 | 
            +
                    expects_cached_catalog_only(catalog)
         | 
| 604 | 
            +
             | 
| 605 | 
            +
                    options = {}
         | 
| 606 | 
            +
                    configurer.run(options)
         | 
| 693 607 |  | 
| 694 | 
            -
                     | 
| 695 | 
            -
                    expect(@agent.instance_variable_get(:@cached_catalog_status)).to eq('explicitly_requested')
         | 
| 608 | 
            +
                    expect(options[:report].cached_catalog_status).to eq('explicitly_requested')
         | 
| 696 609 | 
             
                  end
         | 
| 697 610 |  | 
| 698 611 | 
             
                  it "should set its cached_catalog_status to 'explicitly requested' if the cached catalog is from a different environment" do
         | 
| 699 612 | 
             
                    cached_catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote('second_env'))
         | 
| 700 613 | 
             
                    expects_cached_catalog_only(cached_catalog)
         | 
| 701 614 |  | 
| 702 | 
            -
                     | 
| 703 | 
            -
                     | 
| 615 | 
            +
                    options = {}
         | 
| 616 | 
            +
                    configurer.run(options)
         | 
| 617 | 
            +
             | 
| 618 | 
            +
                    expect(options[:report].cached_catalog_status).to eq('explicitly_requested')
         | 
| 704 619 | 
             
                  end
         | 
| 705 620 |  | 
| 706 621 | 
             
                  it "should compile a new catalog if none is found in the cache" do
         | 
| 707 | 
            -
                    expects_fallback_to_new_catalog( | 
| 708 | 
            -
             | 
| 709 | 
            -
                    expect(@agent.retrieve_catalog({})).to eq(@catalog)
         | 
| 710 | 
            -
                  end
         | 
| 622 | 
            +
                    expects_fallback_to_new_catalog(catalog)
         | 
| 711 623 |  | 
| 712 | 
            -
             | 
| 713 | 
            -
                     | 
| 624 | 
            +
                    options = {}
         | 
| 625 | 
            +
                    configurer.run(options)
         | 
| 714 626 |  | 
| 715 | 
            -
                     | 
| 716 | 
            -
                    expect(@agent.instance_variable_get(:@cached_catalog_status)).to eq('not_used')
         | 
| 627 | 
            +
                    expect(options[:report].cached_catalog_status).to eq('not_used')
         | 
| 717 628 | 
             
                  end
         | 
| 718 629 |  | 
| 719 630 | 
             
                  it "should not attempt to retrieve a cached catalog again if the first attempt failed" do
         | 
| 720 631 | 
             
                    expect(Puppet::Node.indirection).to receive(:find).and_return(nil)
         | 
| 721 632 | 
             
                    expects_neither_new_or_cached_catalog
         | 
| 722 633 |  | 
| 723 | 
            -
                     | 
| 634 | 
            +
                    configurer.run
         | 
| 724 635 | 
             
                  end
         | 
| 725 636 |  | 
| 726 637 | 
             
                  it "should return the cached catalog when the environment doesn't match" do
         | 
| 727 638 | 
             
                    cached_catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote('second_env'))
         | 
| 728 639 | 
             
                    expects_cached_catalog_only(cached_catalog)
         | 
| 729 640 |  | 
| 641 | 
            +
                    allow(Puppet).to receive(:info)
         | 
| 730 642 | 
             
                    expect(Puppet).to receive(:info).with("Using cached catalog from environment 'second_env'")
         | 
| 731 | 
            -
             | 
| 643 | 
            +
             | 
| 644 | 
            +
                    configurer.run
         | 
| 645 | 
            +
                  end
         | 
| 646 | 
            +
             | 
| 647 | 
            +
                  it "applies the catalog passed as options when the catalog cache terminus is not set" do
         | 
| 648 | 
            +
                    stub_request(:get, %r{/puppet/v3/file_metadatas?/plugins}).to_return(:status => 404)
         | 
| 649 | 
            +
                    stub_request(:get, %r{/puppet/v3/file_metadatas?/pluginfacts}).to_return(:status => 404)
         | 
| 650 | 
            +
             | 
| 651 | 
            +
                    catalog.add_resource(Puppet::Resource.new('notify', 'from apply'))
         | 
| 652 | 
            +
                    configurer.run(catalog: catalog.to_ral)
         | 
| 653 | 
            +
             | 
| 654 | 
            +
                    # make sure cache class is not set to avoid surprises later
         | 
| 655 | 
            +
                    expect(Puppet::Resource::Catalog.indirection).to_not be_cache
         | 
| 656 | 
            +
                    expect(@logs).to include(an_object_having_attributes(level: :notice, message: /defined 'message' as 'from apply'/))
         | 
| 657 | 
            +
                  end
         | 
| 658 | 
            +
             | 
| 659 | 
            +
                  it "applies the cached catalog when the catalog cache terminus is set, ignoring the catalog passed as options" do
         | 
| 660 | 
            +
                    Puppet::Resource::Catalog.indirection.cache_class = :json
         | 
| 661 | 
            +
             | 
| 662 | 
            +
                    cached_catalog = Puppet::Resource::Catalog.new(Puppet[:node_name_value], Puppet[:environment])
         | 
| 663 | 
            +
                    cached_catalog.add_resource(Puppet::Resource.new('notify', 'from cache'))
         | 
| 664 | 
            +
             | 
| 665 | 
            +
                    # update cached catalog
         | 
| 666 | 
            +
                    Puppet.settings.use(:main, :agent)
         | 
| 667 | 
            +
                    path = Puppet::Resource::Catalog.indirection.cache.path(cached_catalog.name)
         | 
| 668 | 
            +
                    FileUtils.mkdir(File.dirname(path))
         | 
| 669 | 
            +
                    File.write(path, cached_catalog.render(:json))
         | 
| 670 | 
            +
             | 
| 671 | 
            +
                    configurer.run(catalog: catalog.to_ral)
         | 
| 672 | 
            +
             | 
| 673 | 
            +
                    expect(@logs).to include(an_object_having_attributes(level: :notice, message: /defined 'message' as 'from cache'/))
         | 
| 732 674 | 
             
                  end
         | 
| 733 675 | 
             
                end
         | 
| 734 676 |  | 
| 735 677 | 
             
                describe "and strict environment mode is set" do
         | 
| 736 678 | 
             
                  before do
         | 
| 737 | 
            -
                    allow(@catalog).to receive(:to_ral).and_return(@catalog)
         | 
| 738 | 
            -
                    allow(@catalog).to receive(:write_class_file)
         | 
| 739 | 
            -
                    allow(@catalog).to receive(:write_resource_file)
         | 
| 740 | 
            -
                    allow(@agent).to receive(:send_report)
         | 
| 741 | 
            -
                    allow(@agent).to receive(:save_last_run_summary)
         | 
| 742 679 | 
             
                    Puppet.settings[:strict_environment_mode] = true
         | 
| 743 680 | 
             
                  end
         | 
| 744 681 |  | 
| 745 682 | 
             
                  it "should not make a node request" do
         | 
| 746 683 | 
             
                    expect(Puppet::Node.indirection).not_to receive(:find)
         | 
| 747 684 |  | 
| 748 | 
            -
                     | 
| 685 | 
            +
                    configurer.run
         | 
| 749 686 | 
             
                  end
         | 
| 750 687 |  | 
| 751 688 | 
             
                  it "should return nil when the catalog's environment doesn't match the agent specified environment" do
         | 
| 752 | 
            -
                     | 
| 753 | 
            -
                     | 
| 689 | 
            +
                    Puppet[:environment] = 'second_env'
         | 
| 690 | 
            +
                    configurer = Puppet::Configurer.new
         | 
| 691 | 
            +
             | 
| 692 | 
            +
                    catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote("production"))
         | 
| 693 | 
            +
                    expects_new_catalog_only(catalog)
         | 
| 754 694 |  | 
| 755 695 | 
             
                    expect(Puppet).to receive(:err).with("Not using catalog because its environment 'production' does not match agent specified environment 'second_env' and strict_environment_mode is set")
         | 
| 756 | 
            -
                    expect( | 
| 696 | 
            +
                    expect(configurer.run).to be_nil
         | 
| 757 697 | 
             
                  end
         | 
| 758 698 |  | 
| 759 | 
            -
                  it "should  | 
| 760 | 
            -
                     | 
| 761 | 
            -
                    expects_new_catalog_only(@catalog)
         | 
| 699 | 
            +
                  it "should return 0 when the catalog's environment matches the agent specified environment" do
         | 
| 700 | 
            +
                    expects_new_catalog_only(catalog)
         | 
| 762 701 |  | 
| 763 | 
            -
                    expect( | 
| 702 | 
            +
                    expect(configurer.run).to eq(0)
         | 
| 764 703 | 
             
                  end
         | 
| 765 704 |  | 
| 766 705 | 
             
                  describe "and a cached catalog is explicitly requested" do
         | 
| @@ -769,83 +708,81 @@ describe Puppet::Configurer do | |
| 769 708 | 
             
                    end
         | 
| 770 709 |  | 
| 771 710 | 
             
                    it "should return nil when the cached catalog's environment doesn't match the agent specified environment" do
         | 
| 772 | 
            -
                       | 
| 773 | 
            -
                       | 
| 711 | 
            +
                      Puppet[:environment] = 'second_env'
         | 
| 712 | 
            +
                      configurer = Puppet::Configurer.new
         | 
| 713 | 
            +
             | 
| 714 | 
            +
                      catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote("production"))
         | 
| 715 | 
            +
                      expects_cached_catalog_only(catalog)
         | 
| 774 716 |  | 
| 775 717 | 
             
                      expect(Puppet).to receive(:err).with("Not using catalog because its environment 'production' does not match agent specified environment 'second_env' and strict_environment_mode is set")
         | 
| 776 | 
            -
                      expect( | 
| 718 | 
            +
                      expect(configurer.run).to be_nil
         | 
| 777 719 | 
             
                    end
         | 
| 778 720 |  | 
| 779 721 | 
             
                    it "should proceed with the cached catalog if its environment matchs the local environment" do
         | 
| 780 | 
            -
                       | 
| 781 | 
            -
                      @agent.instance_variable_set(:@environment, 'production')
         | 
| 782 | 
            -
                      expects_cached_catalog_only(@catalog)
         | 
| 722 | 
            +
                      expects_cached_catalog_only(catalog)
         | 
| 783 723 |  | 
| 784 | 
            -
                      expect( | 
| 724 | 
            +
                      expect(configurer.run).to eq(0)
         | 
| 785 725 | 
             
                    end
         | 
| 786 726 | 
             
                  end
         | 
| 787 727 | 
             
                end
         | 
| 788 728 |  | 
| 789 | 
            -
                it "should use the Catalog class to get its catalog" do
         | 
| 790 | 
            -
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).and_return(@catalog)
         | 
| 791 | 
            -
             | 
| 792 | 
            -
                  @agent.retrieve_catalog({})
         | 
| 793 | 
            -
                end
         | 
| 794 | 
            -
             | 
| 795 729 | 
             
                it "should set its cached_catalog_status to 'not_used' when downloading a new catalog" do
         | 
| 796 | 
            -
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_cache: true)).and_return( | 
| 730 | 
            +
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_cache: true)).and_return(catalog)
         | 
| 731 | 
            +
             | 
| 732 | 
            +
                  options = {}
         | 
| 733 | 
            +
                  configurer.run(options)
         | 
| 797 734 |  | 
| 798 | 
            -
                   | 
| 799 | 
            -
                  expect(@agent.instance_variable_get(:@cached_catalog_status)).to eq('not_used')
         | 
| 735 | 
            +
                  expect(options[:report].cached_catalog_status).to eq('not_used')
         | 
| 800 736 | 
             
                end
         | 
| 801 737 |  | 
| 802 738 | 
             
                it "should use its node_name_value to retrieve the catalog" do
         | 
| 803 | 
            -
                   | 
| 804 | 
            -
                  Puppet. | 
| 805 | 
            -
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with("myhost.domain.com", anything).and_return(@catalog)
         | 
| 806 | 
            -
             | 
| 807 | 
            -
                  @agent.retrieve_catalog({})
         | 
| 808 | 
            -
                end
         | 
| 739 | 
            +
                  myhost_facts = Puppet::Node::Facts.new("myhost.domain.com")
         | 
| 740 | 
            +
                  Puppet::Node::Facts.indirection.save(myhost_facts)
         | 
| 809 741 |  | 
| 810 | 
            -
             | 
| 811 | 
            -
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with( | 
| 742 | 
            +
                  Puppet.settings[:node_name_value] = "myhost.domain.com"
         | 
| 743 | 
            +
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with("myhost.domain.com", anything).and_return(catalog)
         | 
| 812 744 |  | 
| 813 | 
            -
                   | 
| 745 | 
            +
                  configurer.run
         | 
| 814 746 | 
             
                end
         | 
| 815 747 |  | 
| 816 | 
            -
                it "should log  | 
| 817 | 
            -
                  expects_fallback_to_cached_catalog( | 
| 748 | 
            +
                it "should log when no catalog can be retrieved from the server" do
         | 
| 749 | 
            +
                  expects_fallback_to_cached_catalog(catalog)
         | 
| 818 750 |  | 
| 751 | 
            +
                  allow(Puppet).to receive(:info)
         | 
| 819 752 | 
             
                  expect(Puppet).to receive(:info).with("Using cached catalog from environment 'production'")
         | 
| 820 | 
            -
                   | 
| 753 | 
            +
                  configurer.run
         | 
| 821 754 | 
             
                end
         | 
| 822 755 |  | 
| 823 756 | 
             
                it "should set its cached_catalog_status to 'on_failure' when no catalog can be retrieved from the server" do
         | 
| 824 | 
            -
                  expects_fallback_to_cached_catalog( | 
| 757 | 
            +
                  expects_fallback_to_cached_catalog(catalog)
         | 
| 758 | 
            +
             | 
| 759 | 
            +
                  options = {}
         | 
| 760 | 
            +
                  configurer.run(options)
         | 
| 825 761 |  | 
| 826 | 
            -
                   | 
| 827 | 
            -
                  expect(@agent.instance_variable_get(:@cached_catalog_status)).to eq('on_failure')
         | 
| 762 | 
            +
                  expect(options[:report].cached_catalog_status).to eq('on_failure')
         | 
| 828 763 | 
             
                end
         | 
| 829 764 |  | 
| 830 765 | 
             
                it "should not look in the cache for a catalog if one is returned from the server" do
         | 
| 831 | 
            -
                  expects_new_catalog_only( | 
| 766 | 
            +
                  expects_new_catalog_only(catalog)
         | 
| 832 767 |  | 
| 833 | 
            -
                   | 
| 768 | 
            +
                  configurer.run
         | 
| 834 769 | 
             
                end
         | 
| 835 770 |  | 
| 836 771 | 
             
                it "should return the cached catalog when retrieving the remote catalog throws an exception" do
         | 
| 837 772 | 
             
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_cache: true)).and_raise("eh")
         | 
| 838 | 
            -
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_terminus: true)).and_return( | 
| 773 | 
            +
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_terminus: true)).and_return(catalog)
         | 
| 839 774 |  | 
| 840 | 
            -
                   | 
| 775 | 
            +
                  configurer.run
         | 
| 841 776 | 
             
                end
         | 
| 842 777 |  | 
| 843 778 | 
             
                it "should set its cached_catalog_status to 'on_failure' when retrieving the remote catalog throws an exception" do
         | 
| 844 779 | 
             
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_cache: true)).and_raise("eh")
         | 
| 845 | 
            -
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_terminus: true)).and_return( | 
| 780 | 
            +
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_terminus: true)).and_return(catalog)
         | 
| 781 | 
            +
             | 
| 782 | 
            +
                  options = {}
         | 
| 783 | 
            +
                  configurer.run(options)
         | 
| 846 784 |  | 
| 847 | 
            -
                   | 
| 848 | 
            -
                  expect(@agent.instance_variable_get(:@cached_catalog_status)).to eq('on_failure')
         | 
| 785 | 
            +
                  expect(options[:report].cached_catalog_status).to eq('on_failure')
         | 
| 849 786 | 
             
                end
         | 
| 850 787 |  | 
| 851 788 | 
             
                it "should log and return nil if no catalog can be retrieved from the server and :usecacheonfailure is disabled" do
         | 
| @@ -854,120 +791,173 @@ describe Puppet::Configurer do | |
| 854 791 |  | 
| 855 792 | 
             
                  expect(Puppet).to receive(:warning).with('Not using cache on failed catalog')
         | 
| 856 793 |  | 
| 857 | 
            -
                  expect( | 
| 794 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 858 795 | 
             
                end
         | 
| 859 796 |  | 
| 860 797 | 
             
                it "should set its cached_catalog_status to 'not_used' if no catalog can be retrieved from the server and :usecacheonfailure is disabled or fails to retrieve a catalog" do
         | 
| 861 798 | 
             
                  Puppet[:usecacheonfailure] = false
         | 
| 862 799 | 
             
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_cache: true)).and_return(nil)
         | 
| 863 800 |  | 
| 864 | 
            -
                   | 
| 865 | 
            -
                   | 
| 801 | 
            +
                  options = {}
         | 
| 802 | 
            +
                  configurer.run(options)
         | 
| 803 | 
            +
             | 
| 804 | 
            +
                  expect(options[:report].cached_catalog_status).to eq('not_used')
         | 
| 866 805 | 
             
                end
         | 
| 867 806 |  | 
| 868 807 | 
             
                it "should return nil if no cached catalog is available and no catalog can be retrieved from the server" do
         | 
| 869 808 | 
             
                  expects_neither_new_or_cached_catalog
         | 
| 870 809 |  | 
| 871 | 
            -
                  expect( | 
| 810 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 872 811 | 
             
                end
         | 
| 873 812 |  | 
| 874 813 | 
             
                it "should return nil if its cached catalog environment doesn't match server-specified environment" do
         | 
| 875 814 | 
             
                  cached_catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote('second_env'))
         | 
| 876 | 
            -
                  @agent.instance_variable_set(:@node_environment, 'production')
         | 
| 877 815 |  | 
| 878 816 | 
             
                  expects_fallback_to_cached_catalog(cached_catalog)
         | 
| 879 817 |  | 
| 818 | 
            +
                  allow(Puppet).to receive(:err)
         | 
| 880 819 | 
             
                  expect(Puppet).to receive(:err).with("Not using cached catalog because its environment 'second_env' does not match 'production'")
         | 
| 881 | 
            -
                  expect( | 
| 820 | 
            +
                  expect(configurer.run).to be_nil
         | 
| 882 821 | 
             
                end
         | 
| 883 822 |  | 
| 884 823 | 
             
                it "should set its cached_catalog_status to 'not_used' if the cached catalog environment doesn't match server-specified environment" do
         | 
| 885 824 | 
             
                  cached_catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote('second_env'))
         | 
| 886 | 
            -
                  @agent.instance_variable_set(:@node_environment, 'production')
         | 
| 887 | 
            -
             | 
| 888 | 
            -
                  expects_fallback_to_cached_catalog(cached_catalog)
         | 
| 889 | 
            -
             | 
| 890 | 
            -
                  @agent.retrieve_catalog({})
         | 
| 891 | 
            -
                  expect(@agent.instance_variable_get(:@cached_catalog_status)).to eq('not_used')
         | 
| 892 | 
            -
                end
         | 
| 893 | 
            -
             | 
| 894 | 
            -
                it "should return its cached catalog if the environment matches the server-specified environment" do
         | 
| 895 | 
            -
                  cached_catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote(Puppet[:environment]))
         | 
| 896 | 
            -
                  @agent.instance_variable_set(:@node_environment, cached_catalog.environment)
         | 
| 897 825 |  | 
| 898 826 | 
             
                  expects_fallback_to_cached_catalog(cached_catalog)
         | 
| 899 827 |  | 
| 900 | 
            -
                   | 
| 828 | 
            +
                  options = {}
         | 
| 829 | 
            +
                  configurer.run(options)
         | 
| 830 | 
            +
                  expect(options[:report].cached_catalog_status).to eq('not_used')
         | 
| 901 831 | 
             
                end
         | 
| 902 832 |  | 
| 903 833 | 
             
                it "should set its cached_catalog_status to 'on_failure' if the cached catalog environment matches server-specified environment" do
         | 
| 904 | 
            -
                   | 
| 905 | 
            -
                  @agent.instance_variable_set(:@node_environment, cached_catalog.environment)
         | 
| 906 | 
            -
             | 
| 907 | 
            -
                  expects_fallback_to_cached_catalog(cached_catalog)
         | 
| 834 | 
            +
                  expects_fallback_to_cached_catalog(catalog)
         | 
| 908 835 |  | 
| 909 | 
            -
                   | 
| 910 | 
            -
                   | 
| 836 | 
            +
                  options = {}
         | 
| 837 | 
            +
                  configurer.run(options)
         | 
| 838 | 
            +
                  expect(options[:report].cached_catalog_status).to eq('on_failure')
         | 
| 911 839 | 
             
                end
         | 
| 912 840 |  | 
| 913 841 | 
             
                it "should not update the cached catalog in noop mode" do
         | 
| 914 842 | 
             
                  Puppet[:noop] = true
         | 
| 915 | 
            -
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).with(anything, hash_including(ignore_cache: true, ignore_cache_save: true)).and_return(@catalog)
         | 
| 916 843 |  | 
| 917 | 
            -
                   | 
| 844 | 
            +
                  stub_request(:get, %r{/puppet/v3/catalog}).to_return(:status => 200, :body => catalog.render(:json), :headers => {'Content-Type' => 'application/json'})
         | 
| 845 | 
            +
             | 
| 846 | 
            +
                  Puppet::Resource::Catalog.indirection.cache_class = :json
         | 
| 847 | 
            +
                  path = Puppet::Resource::Catalog.indirection.cache.path(catalog.name)
         | 
| 848 | 
            +
             | 
| 849 | 
            +
                  expect(File).to_not be_exist(path)
         | 
| 850 | 
            +
                  configurer.run
         | 
| 851 | 
            +
                  expect(File).to_not be_exist(path)
         | 
| 918 852 | 
             
                end
         | 
| 919 853 |  | 
| 920 854 | 
             
                it "should update the cached catalog when not in noop mode" do
         | 
| 921 855 | 
             
                  Puppet[:noop] = false
         | 
| 922 | 
            -
                   | 
| 856 | 
            +
                  Puppet[:log_level] = 'info'
         | 
| 857 | 
            +
             | 
| 858 | 
            +
                  stub_request(:get, %r{/puppet/v3/catalog}).to_return(:status => 200, :body => catalog.render(:json), :headers => {'Content-Type' => 'application/json'})
         | 
| 859 | 
            +
             | 
| 860 | 
            +
                  Puppet::Resource::Catalog.indirection.cache_class = :json
         | 
| 861 | 
            +
                  cache_path = Puppet::Resource::Catalog.indirection.cache.path(Puppet[:node_name_value])
         | 
| 862 | 
            +
             | 
| 863 | 
            +
                  expect(File).to_not be_exist(cache_path)
         | 
| 864 | 
            +
                  configurer.run
         | 
| 865 | 
            +
                  expect(File).to be_exist(cache_path)
         | 
| 866 | 
            +
             | 
| 867 | 
            +
                  expect(@logs).to include(an_object_having_attributes(level: :info, message: "Caching catalog for #{Puppet[:node_name_value]}"))
         | 
| 868 | 
            +
                end
         | 
| 869 | 
            +
             | 
| 870 | 
            +
                it "successfully applies the catalog without a cache" do
         | 
| 871 | 
            +
                  stub_request(:get, %r{/puppet/v3/catalog}).to_return(:status => 200, :body => catalog.render(:json), :headers => {'Content-Type' => 'application/json'})
         | 
| 872 | 
            +
             | 
| 873 | 
            +
                  Puppet::Resource::Catalog.indirection.cache_class = nil
         | 
| 874 | 
            +
             | 
| 875 | 
            +
                  expect(configurer.run).to eq(0)
         | 
| 876 | 
            +
                end
         | 
| 877 | 
            +
             | 
| 878 | 
            +
                it "should not update the cached catalog when running puppet apply" do
         | 
| 879 | 
            +
                  Puppet::Resource::Catalog.indirection.cache_class = :json
         | 
| 880 | 
            +
                  path = Puppet::Resource::Catalog.indirection.cache.path(catalog.name)
         | 
| 923 881 |  | 
| 924 | 
            -
                   | 
| 882 | 
            +
                  expect(File).to_not be_exist(path)
         | 
| 883 | 
            +
                  configurer.run(catalog: catalog)
         | 
| 884 | 
            +
                  expect(File).to_not be_exist(path)
         | 
| 925 885 | 
             
                end
         | 
| 926 886 | 
             
              end
         | 
| 927 887 |  | 
| 928 | 
            -
              describe "when  | 
| 929 | 
            -
                 | 
| 930 | 
            -
             | 
| 888 | 
            +
              describe "when converging the environment" do
         | 
| 889 | 
            +
                let(:apple) { Puppet::Resource::Catalog.new(Puppet[:node_name_value], Puppet::Node::Environment.remote('apple')) }
         | 
| 890 | 
            +
                let(:banana) { Puppet::Resource::Catalog.new(Puppet[:node_name_value], Puppet::Node::Environment.remote('banana')) }
         | 
| 891 | 
            +
             | 
| 892 | 
            +
                before :each do
         | 
| 893 | 
            +
                  apple.add_resource(resource)
         | 
| 894 | 
            +
                  banana.add_resource(resource)
         | 
| 895 | 
            +
                end
         | 
| 931 896 |  | 
| 932 | 
            -
             | 
| 897 | 
            +
                it "converges after multiple attempts" do
         | 
| 898 | 
            +
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).and_return(apple, banana, banana)
         | 
| 899 | 
            +
             | 
| 900 | 
            +
                  allow(Puppet).to receive(:notice)
         | 
| 901 | 
            +
                  expect(Puppet).to receive(:notice).with("Local environment: 'production' doesn't match server specified environment 'apple', restarting agent run with environment 'apple'")
         | 
| 902 | 
            +
                  expect(Puppet).to receive(:notice).with("Local environment: 'apple' doesn't match server specified environment 'banana', restarting agent run with environment 'banana'")
         | 
| 903 | 
            +
             | 
| 904 | 
            +
                  configurer.run
         | 
| 933 905 | 
             
                end
         | 
| 934 906 |  | 
| 935 | 
            -
                 | 
| 936 | 
            -
             | 
| 907 | 
            +
                it "raises if it can't converge after 4 tries after the initial catalog request" do
         | 
| 908 | 
            +
                  expect(Puppet::Resource::Catalog.indirection).to receive(:find).and_return(apple, banana, apple, banana, apple)
         | 
| 937 909 |  | 
| 938 | 
            -
             | 
| 939 | 
            -
             | 
| 910 | 
            +
                  expect(Puppet).to receive(:err).with("Failed to apply catalog: Catalog environment didn't stabilize after 4 fetches, aborting run")
         | 
| 911 | 
            +
             | 
| 912 | 
            +
                  configurer.run
         | 
| 940 913 | 
             
                end
         | 
| 914 | 
            +
              end
         | 
| 941 915 |  | 
| 942 | 
            -
             | 
| 943 | 
            -
             | 
| 916 | 
            +
              describe "when converting the catalog" do
         | 
| 917 | 
            +
                it "converts Puppet::Resource into Puppet::Type::Notify" do
         | 
| 918 | 
            +
                  expect(configurer).to receive(:apply_catalog) do |ral, _|
         | 
| 919 | 
            +
                    expect(ral.resources).to contain(an_instance_of(Puppet::Type::Notify))
         | 
| 920 | 
            +
                  end
         | 
| 944 921 |  | 
| 945 | 
            -
                   | 
| 922 | 
            +
                  configurer.run(catalog: catalog)
         | 
| 946 923 | 
             
                end
         | 
| 947 924 |  | 
| 948 | 
            -
                it " | 
| 949 | 
            -
                  expect( | 
| 925 | 
            +
                it "adds default schedules" do
         | 
| 926 | 
            +
                  expect(configurer).to receive(:apply_catalog) do |ral, _|
         | 
| 927 | 
            +
                    expect(ral.resources.map(&:to_ref)).to contain(%w{Schedule[puppet] Schedule[hourly] Schedule[daily] Schedule[weekly] Schedule[monthly] Schedule[never]})
         | 
| 928 | 
            +
                  end
         | 
| 950 929 |  | 
| 951 | 
            -
                   | 
| 930 | 
            +
                  configurer.run
         | 
| 952 931 | 
             
                end
         | 
| 953 932 |  | 
| 954 | 
            -
                it " | 
| 955 | 
            -
                  expect( | 
| 933 | 
            +
                it "records the retrieval duration to the catalog" do
         | 
| 934 | 
            +
                  expect(configurer).to receive(:apply_catalog) do |ral, _|
         | 
| 935 | 
            +
                    expect(ral.retrieval_duration).to be_an_instance_of(Float)
         | 
| 936 | 
            +
                  end
         | 
| 956 937 |  | 
| 957 | 
            -
                   | 
| 938 | 
            +
                  configurer.run
         | 
| 958 939 | 
             
                end
         | 
| 959 940 |  | 
| 960 | 
            -
                it " | 
| 961 | 
            -
                  expect( | 
| 941 | 
            +
                it "writes the class file containing applied settings classes" do
         | 
| 942 | 
            +
                  expect(File).to_not be_exist(Puppet[:classfile])
         | 
| 962 943 |  | 
| 963 | 
            -
                   | 
| 944 | 
            +
                  configurer.run
         | 
| 945 | 
            +
             | 
| 946 | 
            +
                  expect(File.read(Puppet[:classfile]).chomp).to eq('settings')
         | 
| 964 947 | 
             
                end
         | 
| 965 948 |  | 
| 966 | 
            -
                it " | 
| 967 | 
            -
                   | 
| 949 | 
            +
                it "writes an empty resource file since no resources are 'managed'" do
         | 
| 950 | 
            +
                  expect(File).to_not be_exist(Puppet[:resourcefile])
         | 
| 951 | 
            +
             | 
| 952 | 
            +
                  configurer.run
         | 
| 968 953 |  | 
| 969 | 
            -
                  expect( | 
| 970 | 
            -
             | 
| 954 | 
            +
                  expect(File.read(Puppet[:resourcefile]).chomp).to eq("")
         | 
| 955 | 
            +
                end
         | 
| 956 | 
            +
             | 
| 957 | 
            +
                it "adds the conversion time to the report" do
         | 
| 958 | 
            +
                  configurer.run(report: report)
         | 
| 959 | 
            +
             | 
| 960 | 
            +
                  expect(report.metrics['time']['convert_catalog']).to be_an_instance_of(Float)
         | 
| 971 961 | 
             
                end
         | 
| 972 962 | 
             
              end
         | 
| 973 963 |  | 
| @@ -1002,80 +992,70 @@ describe Puppet::Configurer do | |
| 1002 992 | 
             
              describe "when attempting failover" do
         | 
| 1003 993 | 
             
                it "should not failover if server_list is not set" do
         | 
| 1004 994 | 
             
                  Puppet.settings[:server_list] = []
         | 
| 1005 | 
            -
                   | 
| 1006 | 
            -
                  @agent.run
         | 
| 995 | 
            +
                  configurer.run
         | 
| 1007 996 | 
             
                end
         | 
| 1008 997 |  | 
| 1009 998 | 
             
                it "should not failover during an apply run" do
         | 
| 1010 999 | 
             
                  Puppet.settings[:server_list] = ["myserver:123"]
         | 
| 1011 | 
            -
                  expect(@agent).not_to receive(:find_functional_server)
         | 
| 1012 1000 | 
             
                  catalog = Puppet::Resource::Catalog.new("tester", Puppet::Node::Environment.remote(Puppet[:environment].to_sym))
         | 
| 1013 | 
            -
                   | 
| 1001 | 
            +
                  configurer.run(catalog: catalog)
         | 
| 1014 1002 | 
             
                end
         | 
| 1015 1003 |  | 
| 1016 1004 | 
             
                it "should select a server when it receives 200 OK response" do
         | 
| 1017 1005 | 
             
                  Puppet.settings[:server_list] = ["myserver:123"]
         | 
| 1018 | 
            -
             | 
| 1019 | 
            -
                   | 
| 1020 | 
            -
                  allow(@agent).to receive(:run_internal)
         | 
| 1006 | 
            +
             | 
| 1007 | 
            +
                  stub_request(:get, 'https://myserver:123/status/v1/simple/master').to_return(status: 200)
         | 
| 1021 1008 |  | 
| 1022 1009 | 
             
                  options = {}
         | 
| 1023 | 
            -
                   | 
| 1010 | 
            +
                  configurer.run(options)
         | 
| 1024 1011 | 
             
                  expect(options[:report].master_used).to eq('myserver:123')
         | 
| 1025 1012 | 
             
                end
         | 
| 1026 1013 |  | 
| 1027 1014 | 
             
                it "should select a server when it receives 403 Forbidden" do
         | 
| 1028 1015 | 
             
                  Puppet.settings[:server_list] = ["myserver:123"]
         | 
| 1029 | 
            -
             | 
| 1030 | 
            -
                   | 
| 1031 | 
            -
                  allow(@agent).to receive(:run_internal)
         | 
| 1016 | 
            +
             | 
| 1017 | 
            +
                  stub_request(:get, 'https://myserver:123/status/v1/simple/master').to_return(status: 403)
         | 
| 1032 1018 |  | 
| 1033 1019 | 
             
                  options = {}
         | 
| 1034 | 
            -
                   | 
| 1020 | 
            +
                  configurer.run(options)
         | 
| 1035 1021 | 
             
                  expect(options[:report].master_used).to eq('myserver:123')
         | 
| 1036 1022 | 
             
                end
         | 
| 1037 1023 |  | 
| 1038 | 
            -
                it "queries the simple status for the 'master' service" do
         | 
| 1039 | 
            -
                  Puppet.settings[:server_list] = ["myserver:123"]
         | 
| 1040 | 
            -
                  response = Net::HTTPOK.new(nil, 200, 'OK')
         | 
| 1041 | 
            -
                  http = double('request')
         | 
| 1042 | 
            -
                  expect(http).to receive(:get).with('/status/v1/simple/master').and_return(response)
         | 
| 1043 | 
            -
                  allow(Puppet::Network::HttpPool).to receive(:http_ssl_instance).with('myserver', '123').and_return(http)
         | 
| 1044 | 
            -
                  allow(@agent).to receive(:run_internal)
         | 
| 1045 | 
            -
             | 
| 1046 | 
            -
                  @agent.run
         | 
| 1047 | 
            -
                end
         | 
| 1048 | 
            -
             | 
| 1049 1024 | 
             
                it "should report when a server is unavailable" do
         | 
| 1050 1025 | 
             
                  Puppet.settings[:server_list] = ["myserver:123"]
         | 
| 1051 | 
            -
                  response = Net::HTTPInternalServerError.new(nil, 500, 'Internal Server Error')
         | 
| 1052 | 
            -
                  allow(Puppet::Network::HttpPool).to receive(:http_ssl_instance).with('myserver', '123').and_return(double('request', get: response))
         | 
| 1053 | 
            -
                  allow(@agent).to receive(:run_internal)
         | 
| 1054 1026 |  | 
| 1027 | 
            +
                  stub_request(:get, 'https://myserver:123/status/v1/simple/master').to_return(status: [500, "Internal Server Error"])
         | 
| 1028 | 
            +
             | 
| 1029 | 
            +
                  allow(Puppet).to receive(:debug)
         | 
| 1055 1030 | 
             
                  expect(Puppet).to receive(:debug).with("Puppet server myserver:123 is unavailable: 500 Internal Server Error")
         | 
| 1056 | 
            -
                  expect { | 
| 1031 | 
            +
                  expect {
         | 
| 1032 | 
            +
                    configurer.run
         | 
| 1033 | 
            +
                  }.to raise_error(Puppet::Error, /Could not select a functional puppet master from server_list:/)
         | 
| 1057 1034 | 
             
                end
         | 
| 1058 1035 |  | 
| 1059 1036 | 
             
                it "should error when no servers in 'server_list' are reachable" do
         | 
| 1060 1037 | 
             
                  Puppet.settings[:server_list] = "myserver:123,someotherservername"
         | 
| 1061 | 
            -
             | 
| 1062 | 
            -
                   | 
| 1063 | 
            -
                   | 
| 1064 | 
            -
             | 
| 1065 | 
            -
                   | 
| 1066 | 
            -
             | 
| 1067 | 
            -
                   | 
| 1068 | 
            -
                  expect{ @agent.run }.to raise_error(Puppet::Error, /Could not select a functional puppet master from server_list: 'myserver:123,someotherservername'/)
         | 
| 1038 | 
            +
             | 
| 1039 | 
            +
                  stub_request(:get, 'https://myserver/status/v1/simple/master').to_return(status: 400)
         | 
| 1040 | 
            +
                  stub_request(:get, 'https://someotherservername/status/v1/simple/master').to_return(status: 400)
         | 
| 1041 | 
            +
             | 
| 1042 | 
            +
                  expect{
         | 
| 1043 | 
            +
                    configurer.run
         | 
| 1044 | 
            +
                  }.to raise_error(Puppet::Error, /Could not select a functional puppet master from server_list: 'myserver:123,someotherservername'/)
         | 
| 1069 1045 | 
             
                end
         | 
| 1070 1046 |  | 
| 1071 | 
            -
                it "should not make multiple node  | 
| 1072 | 
            -
                  response = Net::HTTPOK.new(nil, 200, 'OK')
         | 
| 1073 | 
            -
                  allow(Puppet::Network::HttpPool).to receive(:http_ssl_instance).with('myserver', '123').and_return(double('request', get: response))
         | 
| 1074 | 
            -
                  
         | 
| 1047 | 
            +
                it "should not make multiple node requests when the server is found" do
         | 
| 1075 1048 | 
             
                  Puppet.settings[:server_list] = ["myserver:123"]
         | 
| 1076 | 
            -
                   | 
| 1077 | 
            -
                   | 
| 1078 | 
            -
             | 
| 1049 | 
            +
                  Puppet::Node.indirection.terminus_class = :rest
         | 
| 1050 | 
            +
                  Puppet::Resource::Catalog.indirection.terminus_class = :rest
         | 
| 1051 | 
            +
             | 
| 1052 | 
            +
                  stub_request(:get, 'https://myserver:123/status/v1/simple/master').to_return(status: 200)
         | 
| 1053 | 
            +
                  stub_request(:get, %r{https://myserver:123/puppet/v3/catalog}).to_return(status: 200)
         | 
| 1054 | 
            +
                  node_request = stub_request(:get, %r{https://myserver:123/puppet/v3/node/}).to_return(status: 200)
         | 
| 1055 | 
            +
             | 
| 1056 | 
            +
                  configurer.run
         | 
| 1057 | 
            +
             | 
| 1058 | 
            +
                  expect(node_request).to have_been_requested.once
         | 
| 1079 1059 | 
             
                end
         | 
| 1080 1060 | 
             
              end
         | 
| 1081 1061 | 
             
            end
         |