puppet 5.5.17-universal-darwin → 5.5.18-universal-darwin

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of puppet might be problematic. Click here for more details.

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