puppet 7.10.0-universal-darwin → 7.13.1-universal-darwin
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +3 -3
- data/Gemfile.lock +20 -15
- data/ext/project_data.yaml +1 -1
- data/lib/puppet/application/agent.rb +4 -0
- data/lib/puppet/application/apply.rb +20 -2
- data/lib/puppet/application/lookup.rb +72 -24
- data/lib/puppet/application/resource.rb +15 -13
- data/lib/puppet/concurrent/thread_local_singleton.rb +6 -3
- data/lib/puppet/configurer.rb +98 -29
- data/lib/puppet/confine/variable.rb +1 -1
- data/lib/puppet/defaults.rb +17 -3
- data/lib/puppet/facter_impl.rb +96 -0
- data/lib/puppet/file_serving/metadata.rb +3 -0
- data/lib/puppet/file_serving/mount/file.rb +4 -4
- data/lib/puppet/file_system/file_impl.rb +10 -8
- data/lib/puppet/file_system/jruby.rb +1 -1
- data/lib/puppet/file_system/path_pattern.rb +10 -15
- data/lib/puppet/file_system/uniquefile.rb +1 -1
- data/lib/puppet/file_system/windows.rb +4 -4
- data/lib/puppet/file_system.rb +3 -2
- data/lib/puppet/forge.rb +1 -1
- data/lib/puppet/functions/versioncmp.rb +6 -2
- data/lib/puppet/graph/simple_graph.rb +2 -1
- data/lib/puppet/http/client.rb +1 -1
- data/lib/puppet/http/redirector.rb +5 -0
- data/lib/puppet/indirector/catalog/compiler.rb +3 -3
- data/lib/puppet/indirector/facts/facter.rb +6 -6
- data/lib/puppet/indirector/indirection.rb +1 -1
- data/lib/puppet/module_tool/applications/uninstaller.rb +1 -1
- data/lib/puppet/module_tool/applications/upgrader.rb +1 -1
- data/lib/puppet/pal/pal_impl.rb +1 -1
- data/lib/puppet/parser/resource.rb +1 -1
- data/lib/puppet/parser/scope.rb +8 -7
- data/lib/puppet/parser/templatewrapper.rb +1 -0
- data/lib/puppet/pops/evaluator/closure.rb +7 -5
- data/lib/puppet/pops/evaluator/runtime3_resource_support.rb +1 -0
- data/lib/puppet/pops/lookup/lookup_adapter.rb +3 -2
- data/lib/puppet/pops/model/ast.rb +1 -0
- data/lib/puppet/pops/model/factory.rb +14 -13
- data/lib/puppet/pops/parser/code_merger.rb +4 -4
- data/lib/puppet/pops/parser/egrammar.ra +4 -2
- data/lib/puppet/pops/parser/eparser.rb +909 -894
- data/lib/puppet/pops/parser/lexer2.rb +69 -68
- data/lib/puppet/pops/parser/slurp_support.rb +1 -0
- data/lib/puppet/pops/serialization/to_data_converter.rb +6 -18
- data/lib/puppet/pops/serialization/to_stringified_converter.rb +1 -1
- data/lib/puppet/pops/types/type_formatter.rb +7 -6
- data/lib/puppet/pops/types/types.rb +1 -1
- data/lib/puppet/pops/validation/checker4_0.rb +7 -2
- data/lib/puppet/provider/aix_object.rb +1 -1
- data/lib/puppet/provider/group/groupadd.rb +5 -2
- data/lib/puppet/provider/package/pkg.rb +11 -1
- data/lib/puppet/provider/package/puppet_gem.rb +1 -1
- data/lib/puppet/provider/package/puppetserver_gem.rb +1 -1
- data/lib/puppet/provider/package/yum.rb +1 -1
- data/lib/puppet/provider/service/base.rb +1 -1
- data/lib/puppet/provider/service/init.rb +10 -9
- data/lib/puppet/provider/service/launchd.rb +1 -1
- data/lib/puppet/provider/service/redhat.rb +1 -1
- data/lib/puppet/provider/service/smf.rb +3 -3
- data/lib/puppet/provider/service/systemd.rb +1 -1
- data/lib/puppet/provider/service/upstart.rb +5 -5
- data/lib/puppet/provider/user/aix.rb +44 -1
- data/lib/puppet/provider/user/directoryservice.rb +1 -1
- data/lib/puppet/provider/user/useradd.rb +30 -7
- data/lib/puppet/provider.rb +1 -1
- data/lib/puppet/reference/providers.rb +2 -2
- data/lib/puppet/resource/catalog.rb +1 -1
- data/lib/puppet/resource/type_collection.rb +2 -1
- data/lib/puppet/resource.rb +38 -5
- data/lib/puppet/runtime.rb +11 -1
- data/lib/puppet/settings/file_setting.rb +3 -8
- data/lib/puppet/settings.rb +2 -2
- data/lib/puppet/ssl/verifier.rb +3 -1
- data/lib/puppet/test/test_helper.rb +4 -1
- data/lib/puppet/transaction/persistence.rb +22 -12
- data/lib/puppet/type/exec.rb +9 -1
- data/lib/puppet/type/file/data_sync.rb +1 -1
- data/lib/puppet/type/file/group.rb +8 -1
- data/lib/puppet/type/file/owner.rb +8 -1
- data/lib/puppet/type/group.rb +0 -1
- data/lib/puppet/type/resources.rb +1 -1
- data/lib/puppet/type/service.rb +8 -3
- data/lib/puppet/type/user.rb +40 -39
- data/lib/puppet/util/autoload.rb +1 -1
- data/lib/puppet/util/command_line.rb +1 -1
- data/lib/puppet/util/filetype.rb +2 -2
- data/lib/puppet/util/json.rb +20 -0
- data/lib/puppet/util/log.rb +8 -4
- data/lib/puppet/util/logging.rb +1 -25
- data/lib/puppet/util/monkey_patches.rb +26 -2
- data/lib/puppet/util/package.rb +25 -16
- data/lib/puppet/util/pidlock.rb +1 -1
- data/lib/puppet/util/rdoc/parser/puppet_parser_core.rb +1 -1
- data/lib/puppet/util/suidmanager.rb +1 -2
- data/lib/puppet/util/tagging.rb +1 -0
- data/lib/puppet/util/windows/service.rb +0 -5
- data/lib/puppet/util/windows/user.rb +0 -1
- data/lib/puppet/util/windows.rb +3 -0
- data/lib/puppet/util/yaml.rb +11 -0
- data/lib/puppet/util.rb +4 -3
- data/lib/puppet/version.rb +1 -1
- data/lib/puppet.rb +3 -6
- data/locales/puppet.pot +265 -239
- data/man/man5/puppet.conf.5 +18 -2
- data/man/man8/puppet-agent.8 +4 -1
- data/man/man8/puppet-apply.8 +1 -1
- data/man/man8/puppet-catalog.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 +1 -1
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-lookup.8 +9 -6
- 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-ssl.8 +1 -1
- data/man/man8/puppet.8 +2 -2
- data/spec/fixtures/integration/application/agent/cached_deferred_catalog.json +2 -1
- data/spec/fixtures/unit/forge/bacula.json +1 -1
- data/spec/integration/application/agent_spec.rb +44 -0
- data/spec/integration/application/lookup_spec.rb +29 -6
- data/spec/integration/configurer_spec.rb +1 -1
- data/spec/integration/indirector/facts/facter_spec.rb +3 -3
- data/spec/integration/parser/pcore_resource_spec.rb +20 -0
- data/spec/integration/transaction/report_spec.rb +1 -1
- data/spec/integration/type/file_spec.rb +2 -2
- data/spec/integration/type/package_spec.rb +6 -6
- data/spec/integration/util/rdoc/parser_spec.rb +1 -1
- data/spec/integration/util/windows/process_spec.rb +1 -9
- data/spec/shared_contexts/l10n.rb +5 -0
- data/spec/unit/application/apply_spec.rb +76 -56
- data/spec/unit/application/lookup_spec.rb +131 -10
- data/spec/unit/application/resource_spec.rb +29 -0
- data/spec/unit/concurrent/thread_local_singleton_spec.rb +39 -0
- data/spec/unit/configurer_spec.rb +113 -28
- data/spec/unit/facter_impl_spec.rb +31 -0
- data/spec/unit/file_bucket/dipper_spec.rb +2 -2
- data/spec/unit/file_system/uniquefile_spec.rb +7 -1
- data/spec/unit/file_system_spec.rb +41 -4
- data/spec/unit/forge/module_release_spec.rb +3 -3
- data/spec/unit/functions/lookup_spec.rb +64 -0
- data/spec/unit/functions/versioncmp_spec.rb +40 -4
- data/spec/unit/http/client_spec.rb +58 -1
- data/spec/unit/indirector/indirection_spec.rb +10 -3
- data/spec/unit/network/formats_spec.rb +6 -0
- data/spec/unit/pops/parser/parse_containers_spec.rb +2 -2
- data/spec/unit/pops/serialization/to_from_hr_spec.rb +0 -58
- data/spec/unit/pops/serialization/to_stringified_spec.rb +5 -0
- data/spec/unit/pops/types/type_calculator_spec.rb +6 -0
- data/spec/unit/pops/validator/validator_spec.rb +5 -0
- data/spec/unit/provider/package/gem_spec.rb +1 -1
- data/spec/unit/provider/package/pip2_spec.rb +1 -1
- data/spec/unit/provider/package/pip3_spec.rb +1 -1
- data/spec/unit/provider/package/pip_spec.rb +1 -1
- data/spec/unit/provider/package/pkg_spec.rb +15 -0
- data/spec/unit/provider/package/puppet_gem_spec.rb +1 -1
- data/spec/unit/provider/package/puppetserver_gem_spec.rb +1 -1
- data/spec/unit/provider/service/gentoo_spec.rb +6 -5
- data/spec/unit/provider/service/init_spec.rb +15 -9
- data/spec/unit/provider/service/openwrt_spec.rb +21 -29
- data/spec/unit/provider/service/redhat_spec.rb +3 -2
- data/spec/unit/provider/user/aix_spec.rb +100 -0
- data/spec/unit/provider/user/directoryservice_spec.rb +1 -1
- data/spec/unit/provider/user/useradd_spec.rb +40 -0
- data/spec/unit/provider_spec.rb +4 -4
- data/spec/unit/puppet_spec.rb +12 -4
- data/spec/unit/resource/catalog_spec.rb +14 -1
- data/spec/unit/resource_spec.rb +58 -2
- data/spec/unit/settings/file_setting_spec.rb +10 -7
- data/spec/unit/transaction/persistence_spec.rb +51 -0
- data/spec/unit/type/file/group_spec.rb +7 -0
- data/spec/unit/type/file/owner_spec.rb +7 -0
- data/spec/unit/type/service_spec.rb +27 -0
- data/spec/unit/type/user_spec.rb +0 -45
- data/spec/unit/type_spec.rb +2 -2
- data/spec/unit/util/autoload_spec.rb +25 -8
- data/spec/unit/util/json_spec.rb +126 -0
- data/spec/unit/util/logging_spec.rb +2 -0
- data/spec/unit/util/yaml_spec.rb +37 -13
- data/tasks/parallel.rake +3 -3
- metadata +17 -4
@@ -4,7 +4,11 @@ RSpec.shared_context('l10n') do |locale|
|
|
4
4
|
before :all do
|
5
5
|
@old_locale = Locale.current
|
6
6
|
Locale.current = locale
|
7
|
+
|
8
|
+
@old_gettext_disabled = Puppet::GettextConfig.instance_variable_get(:@gettext_disabled)
|
9
|
+
Puppet::GettextConfig.instance_variable_set(:@gettext_disabled, false)
|
7
10
|
Puppet::GettextConfig.setup_locale
|
11
|
+
Puppet::GettextConfig.create_default_text_domain
|
8
12
|
|
9
13
|
# overwrite stubs with real implementation
|
10
14
|
::Object.send(:remove_method, :_)
|
@@ -17,6 +21,7 @@ RSpec.shared_context('l10n') do |locale|
|
|
17
21
|
after :all do
|
18
22
|
Locale.current = @old_locale
|
19
23
|
|
24
|
+
Puppet::GettextConfig.instance_variable_set(:@gettext_disabled, @old_gettext_disabled)
|
20
25
|
# restore stubs
|
21
26
|
load File.expand_path(File.join(__dir__, '../../lib/puppet/gettext/stubs.rb'))
|
22
27
|
end
|
@@ -10,21 +10,22 @@ describe Puppet::Application::Apply do
|
|
10
10
|
|
11
11
|
before :each do
|
12
12
|
@apply = Puppet::Application[:apply]
|
13
|
-
allow(Puppet::Util::Log).to receive(:newdestination)
|
14
13
|
Puppet[:reports] = "none"
|
15
14
|
end
|
16
15
|
|
17
|
-
[:debug,:loadclasses,:test,:verbose,:use_nodes,:detailed_exitcodes,:catalog
|
18
|
-
it "should declare handle_#{option} method" do
|
19
|
-
expect(@apply).to respond_to("handle_#{option}".to_sym)
|
20
|
-
end
|
21
|
-
|
16
|
+
[:debug,:loadclasses,:test,:verbose,:use_nodes,:detailed_exitcodes,:catalog].each do |option|
|
22
17
|
it "should store argument value when calling handle_#{option}" do
|
23
18
|
expect(@apply.options).to receive(:[]=).with(option, 'arg')
|
24
19
|
@apply.send("handle_#{option}".to_sym, 'arg')
|
25
20
|
end
|
26
21
|
end
|
27
22
|
|
23
|
+
it "should handle write_catalog_summary" do
|
24
|
+
@apply.send(:handle_write_catalog_summary, true)
|
25
|
+
|
26
|
+
expect(Puppet[:write_catalog_summary]).to eq(true)
|
27
|
+
end
|
28
|
+
|
28
29
|
it "should set the code to the provided code when :execute is used" do
|
29
30
|
expect(@apply.options).to receive(:[]=).with(:code, 'arg')
|
30
31
|
@apply.send("handle_execute".to_sym, 'arg')
|
@@ -53,23 +54,18 @@ describe Puppet::Application::Apply do
|
|
53
54
|
end
|
54
55
|
|
55
56
|
describe "with --test" do
|
56
|
-
it "should call setup_test" do
|
57
|
-
@apply.options[:test] = true
|
58
|
-
expect(@apply).to receive(:setup_test)
|
59
|
-
|
60
|
-
@apply.setup
|
61
|
-
end
|
62
|
-
|
63
57
|
it "should set options[:verbose] to true" do
|
64
58
|
@apply.setup_test
|
65
59
|
|
66
60
|
expect(@apply.options[:verbose]).to eq(true)
|
67
61
|
end
|
62
|
+
|
68
63
|
it "should set options[:show_diff] to true" do
|
69
64
|
Puppet.settings.override_default(:show_diff, false)
|
70
65
|
@apply.setup_test
|
71
66
|
expect(Puppet[:show_diff]).to eq(true)
|
72
67
|
end
|
68
|
+
|
73
69
|
it "should set options[:detailed_exitcodes] to true" do
|
74
70
|
@apply.setup_test
|
75
71
|
|
@@ -155,7 +151,7 @@ describe Puppet::Application::Apply do
|
|
155
151
|
end
|
156
152
|
|
157
153
|
describe "when executing" do
|
158
|
-
it "should dispatch to 'apply' if it was called with
|
154
|
+
it "should dispatch to 'apply' if it was called with a catalog" do
|
159
155
|
@apply.options[:catalog] = "foo"
|
160
156
|
|
161
157
|
expect(@apply).to receive(:apply)
|
@@ -213,47 +209,52 @@ describe Puppet::Application::Apply do
|
|
213
209
|
@apply.options[:code] = "code to run"
|
214
210
|
expect(Puppet).to receive(:[]=).with(:code,"code to run")
|
215
211
|
|
216
|
-
expect { @apply.
|
212
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
217
213
|
end
|
218
214
|
|
219
215
|
it "should set the code to run from STDIN if no arguments" do
|
220
|
-
|
216
|
+
@apply.command_line.args = []
|
221
217
|
allow(STDIN).to receive(:read).and_return("code to run")
|
222
218
|
|
223
219
|
expect(Puppet).to receive(:[]=).with(:code,"code to run")
|
224
220
|
|
225
|
-
expect { @apply.
|
221
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
226
222
|
end
|
227
223
|
|
228
224
|
it "should raise an error if a file is passed on command line and the file does not exist" do
|
229
225
|
noexist = tmpfile('noexist.pp')
|
230
|
-
|
231
|
-
expect {
|
226
|
+
@apply.command_line.args << noexist
|
227
|
+
expect {
|
228
|
+
@apply.run
|
229
|
+
}.to exit_with(1)
|
230
|
+
.and output(anything).to_stdout
|
231
|
+
.and output(/Could not find file #{noexist}/).to_stderr
|
232
232
|
end
|
233
233
|
|
234
234
|
it "should set the manifest to the first file and warn other files will be skipped" do
|
235
235
|
manifest = tmpfile('starwarsIV')
|
236
236
|
FileUtils.touch(manifest)
|
237
237
|
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
expect(msg.level).to eq(:warning)
|
238
|
+
@apply.command_line.args << manifest << 'starwarsI' << 'starwarsII'
|
239
|
+
expect {
|
240
|
+
@apply.run
|
241
|
+
}.to exit_with(0)
|
242
|
+
.and output(anything).to_stdout
|
243
|
+
.and output(/Warning: Only one file can be applied per run. Skipping starwarsI, starwarsII/).to_stderr
|
245
244
|
end
|
246
245
|
|
247
246
|
it "should splay" do
|
248
247
|
expect(@apply).to receive(:splay)
|
249
248
|
|
250
|
-
expect {
|
249
|
+
expect {
|
250
|
+
@apply.run
|
251
|
+
}.to exit_with(0).and output(anything).to_stdout
|
251
252
|
end
|
252
253
|
|
253
|
-
it "should
|
254
|
+
it "should exit with 1 if we can't find the node" do
|
254
255
|
expect(Puppet::Node.indirection).to receive(:find).and_return(nil)
|
255
256
|
|
256
|
-
expect { @apply.
|
257
|
+
expect { @apply.run }.to exit_with(1).and output(/Could not find node/).to_stderr
|
257
258
|
end
|
258
259
|
|
259
260
|
it "should load custom classes if loadclasses" do
|
@@ -264,18 +265,18 @@ describe Puppet::Application::Apply do
|
|
264
265
|
|
265
266
|
expect(@node).to receive(:classes=).with(['class'])
|
266
267
|
|
267
|
-
expect { @apply.
|
268
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
268
269
|
end
|
269
270
|
|
270
271
|
it "should compile the catalog" do
|
271
272
|
expect(Puppet::Resource::Catalog.indirection).to receive(:find).and_return(@catalog)
|
272
273
|
|
273
|
-
expect { @apply.
|
274
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
274
275
|
end
|
275
276
|
|
276
277
|
it 'should called the DeferredResolver to resolve any Deferred values' do
|
277
278
|
expect(Puppet::Pops::Evaluator::DeferredResolver).to receive(:resolve_and_replace).with(any_args)
|
278
|
-
expect { @apply.
|
279
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
279
280
|
end
|
280
281
|
|
281
282
|
it 'should make the Puppet::Pops::Loaders available when applying the compiled catalog' do
|
@@ -285,47 +286,67 @@ describe Puppet::Application::Apply do
|
|
285
286
|
fail('Loaders not found') unless Puppet.lookup(:loaders) { nil }.is_a?(Puppet::Pops::Loaders)
|
286
287
|
true
|
287
288
|
end.and_return(0)
|
288
|
-
expect { @apply.
|
289
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
289
290
|
end
|
290
291
|
|
291
292
|
it "should transform the catalog to ral" do
|
292
293
|
expect(@catalog).to receive(:to_ral).and_return(@catalog)
|
293
294
|
|
294
|
-
expect { @apply.
|
295
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
295
296
|
end
|
296
297
|
|
297
298
|
it "should finalize the catalog" do
|
298
299
|
expect(@catalog).to receive(:finalize)
|
299
300
|
|
300
|
-
expect { @apply.
|
301
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
301
302
|
end
|
302
303
|
|
303
304
|
it "should not save the classes or resource file by default" do
|
304
305
|
expect(@catalog).not_to receive(:write_class_file)
|
305
306
|
expect(@catalog).not_to receive(:write_resource_file)
|
306
|
-
|
307
|
+
|
308
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
307
309
|
end
|
308
310
|
|
309
|
-
it "should save the classes and resources files when requested" do
|
310
|
-
@
|
311
|
+
it "should save the classes and resources files when requested on the command line using dashes" do
|
312
|
+
expect(@catalog).to receive(:write_class_file).once
|
313
|
+
expect(@catalog).to receive(:write_resource_file).once
|
314
|
+
|
315
|
+
# dashes are parsed by the application's OptionParser
|
316
|
+
@apply.command_line.args = ['--write-catalog-summary']
|
317
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
318
|
+
end
|
319
|
+
|
320
|
+
it "should save the classes and resources files when requested on the command line using underscores" do
|
321
|
+
expect(@catalog).to receive(:write_class_file).once
|
322
|
+
expect(@catalog).to receive(:write_resource_file).once
|
323
|
+
|
324
|
+
# underscores are parsed by the settings PuppetOptionParser
|
325
|
+
@apply.command_line.args = ['--write_catalog_summary']
|
326
|
+
Puppet.initialize_settings(['--write_catalog_summary'])
|
327
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
328
|
+
end
|
329
|
+
|
330
|
+
it "should save the classes and resources files when specified as a setting" do
|
331
|
+
Puppet[:write_catalog_summary] = true
|
311
332
|
|
312
333
|
expect(@catalog).to receive(:write_class_file).once
|
313
334
|
expect(@catalog).to receive(:write_resource_file).once
|
314
335
|
|
315
|
-
expect { @apply.
|
336
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
316
337
|
end
|
317
338
|
|
318
339
|
it "should call the prerun and postrun commands on a Configurer instance" do
|
319
340
|
expect_any_instance_of(Puppet::Configurer).to receive(:execute_prerun_command).and_return(true)
|
320
341
|
expect_any_instance_of(Puppet::Configurer).to receive(:execute_postrun_command).and_return(true)
|
321
342
|
|
322
|
-
expect { @apply.
|
343
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
323
344
|
end
|
324
345
|
|
325
346
|
it "should apply the catalog" do
|
326
347
|
expect(@catalog).to receive(:apply).and_return(double('transaction'))
|
327
348
|
|
328
|
-
expect { @apply.
|
349
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
329
350
|
end
|
330
351
|
|
331
352
|
it "should save the last run summary" do
|
@@ -334,7 +355,7 @@ describe Puppet::Application::Apply do
|
|
334
355
|
allow(Puppet::Transaction::Report).to receive(:new).and_return(report)
|
335
356
|
|
336
357
|
expect_any_instance_of(Puppet::Configurer).to receive(:save_last_run_summary).with(report)
|
337
|
-
expect { @apply.
|
358
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
338
359
|
end
|
339
360
|
|
340
361
|
describe "when using node_name_fact" do
|
@@ -347,27 +368,27 @@ describe Puppet::Application::Apply do
|
|
347
368
|
end
|
348
369
|
|
349
370
|
it "should set the facts name based on the node_name_fact" do
|
350
|
-
expect { @apply.
|
371
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
351
372
|
expect(@facts.name).to eq('other_node_name')
|
352
373
|
end
|
353
374
|
|
354
375
|
it "should set the node_name_value based on the node_name_fact" do
|
355
|
-
expect { @apply.
|
376
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
356
377
|
expect(Puppet[:node_name_value]).to eq('other_node_name')
|
357
378
|
end
|
358
379
|
|
359
380
|
it "should merge in our node the loaded facts" do
|
360
381
|
@facts.values.merge!('key' => 'value')
|
361
382
|
|
362
|
-
expect { @apply.
|
383
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
363
384
|
|
364
385
|
expect(@node.parameters['key']).to eq('value')
|
365
386
|
end
|
366
387
|
|
367
|
-
it "should
|
388
|
+
it "should exit if we can't find the facts" do
|
368
389
|
expect(Puppet::Node::Facts.indirection).to receive(:find).and_return(nil)
|
369
390
|
|
370
|
-
expect { @apply.
|
391
|
+
expect { @apply.run }.to exit_with(1).and output(/Could not find facts/).to_stderr
|
371
392
|
end
|
372
393
|
end
|
373
394
|
|
@@ -380,14 +401,14 @@ describe Puppet::Application::Apply do
|
|
380
401
|
Puppet[:noop] = false
|
381
402
|
allow_any_instance_of(Puppet::Transaction::Report).to receive(:exit_status).and_return(666)
|
382
403
|
|
383
|
-
expect { @apply.
|
404
|
+
expect { @apply.run }.to exit_with(666).and output(anything).to_stdout
|
384
405
|
end
|
385
406
|
|
386
407
|
it "should exit with report's computed exit status, even if --noop is set" do
|
387
408
|
Puppet[:noop] = true
|
388
409
|
allow_any_instance_of(Puppet::Transaction::Report).to receive(:exit_status).and_return(666)
|
389
410
|
|
390
|
-
expect { @apply.
|
411
|
+
expect { @apply.run }.to exit_with(666).and output(anything).to_stdout
|
391
412
|
end
|
392
413
|
|
393
414
|
it "should always exit with 0 if option is disabled" do
|
@@ -395,7 +416,7 @@ describe Puppet::Application::Apply do
|
|
395
416
|
report = double('report', :exit_status => 666)
|
396
417
|
allow(@transaction).to receive(:report).and_return(report)
|
397
418
|
|
398
|
-
expect { @apply.
|
419
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
399
420
|
end
|
400
421
|
|
401
422
|
it "should always exit with 0 if --noop" do
|
@@ -403,7 +424,7 @@ describe Puppet::Application::Apply do
|
|
403
424
|
report = double('report', :exit_status => 666)
|
404
425
|
allow(@transaction).to receive(:report).and_return(report)
|
405
426
|
|
406
|
-
expect { @apply.
|
427
|
+
expect { @apply.run }.to exit_with(0).and output(anything).to_stdout
|
407
428
|
end
|
408
429
|
end
|
409
430
|
end
|
@@ -503,16 +524,15 @@ describe Puppet::Application::Apply do
|
|
503
524
|
}
|
504
525
|
CODE
|
505
526
|
|
506
|
-
|
507
|
-
|
527
|
+
Puppet.settings[:write_catalog_summary] = true
|
508
528
|
Puppet.settings[:resourcefile] = resourcefile
|
509
529
|
Puppet.settings[:classfile] = classfile
|
510
530
|
|
511
531
|
#We don't actually need the resource to do anything, we are using it's properties in other parts of the workflow.
|
512
|
-
|
513
|
-
|
514
|
-
expect { @apply.main }.to exit_with 0
|
532
|
+
allow_any_instance_of(Puppet::Type.type(:exec).defaultprovider).to receive(:which).and_return('cat')
|
533
|
+
allow(Puppet::Util::Execution).to receive(:execute).and_return(double(exitstatus: 0, output: ''))
|
515
534
|
|
535
|
+
expect { @apply.run }.to exit_with(0).and output(%r{Exec\[do it\]/returns: executed successfully}).to_stdout
|
516
536
|
result = File.read(resourcefile)
|
517
537
|
|
518
538
|
expect(result).not_to match(/secret_file_name/)
|
@@ -518,34 +518,155 @@ Searching for "a"
|
|
518
518
|
end
|
519
519
|
|
520
520
|
it 'receives extra facts in top scope' do
|
521
|
-
file_path =
|
522
|
-
filename = File.join(file_path, "facts.yaml")
|
523
|
-
File.open(filename, "w+") { |f| f.write(<<-YAML.unindent) }
|
521
|
+
file_path = file_containing('facts.yaml', <<~CONTENT)
|
524
522
|
---
|
525
523
|
cx: ' C from facts'
|
526
|
-
|
524
|
+
CONTENT
|
527
525
|
|
528
526
|
lookup.options[:node] = node
|
529
|
-
lookup.options[:fact_file] =
|
527
|
+
lookup.options[:fact_file] = file_path
|
530
528
|
lookup.options[:render_as] = :s
|
531
529
|
allow(lookup.command_line).to receive(:args).and_return(['c'])
|
532
530
|
expect(run_lookup(lookup)).to eql("This is C from facts")
|
533
531
|
end
|
534
532
|
|
535
533
|
it 'receives extra facts in the facts hash' do
|
536
|
-
file_path =
|
537
|
-
filename = File.join(file_path, "facts.yaml")
|
538
|
-
File.open(filename, "w+") { |f| f.write(<<-YAML.unindent) }
|
534
|
+
file_path = file_containing('facts.yaml', <<~CONTENT)
|
539
535
|
---
|
540
536
|
cx: ' G from facts'
|
541
|
-
|
537
|
+
CONTENT
|
542
538
|
|
543
539
|
lookup.options[:node] = node
|
544
|
-
lookup.options[:fact_file] =
|
540
|
+
lookup.options[:fact_file] = file_path
|
545
541
|
lookup.options[:render_as] = :s
|
546
542
|
allow(lookup.command_line).to receive(:args).and_return(['g'])
|
547
543
|
expect(run_lookup(lookup)).to eql("This is G from facts in facts hash")
|
548
544
|
end
|
545
|
+
|
546
|
+
describe 'when retrieving given facts' do
|
547
|
+
before do
|
548
|
+
lookup.options[:node] = node
|
549
|
+
allow(lookup.command_line).to receive(:args).and_return(['g'])
|
550
|
+
end
|
551
|
+
|
552
|
+
it 'loads files with yaml extension as yaml on first try' do
|
553
|
+
file_path = file_containing('facts.yaml', <<~CONTENT)
|
554
|
+
---
|
555
|
+
cx: ' G from facts'
|
556
|
+
CONTENT
|
557
|
+
lookup.options[:fact_file] = file_path
|
558
|
+
|
559
|
+
expect(Puppet::Util::Yaml).to receive(:safe_load_file).with(file_path, []).and_call_original
|
560
|
+
run_lookup(lookup)
|
561
|
+
end
|
562
|
+
|
563
|
+
it 'loads files with yml extension as yaml on first try' do
|
564
|
+
file_path = file_containing('facts.yml', <<~CONTENT)
|
565
|
+
---
|
566
|
+
cx: ' G from facts'
|
567
|
+
CONTENT
|
568
|
+
lookup.options[:fact_file] = file_path
|
569
|
+
|
570
|
+
expect(Puppet::Util::Yaml).to receive(:safe_load_file).with(file_path, []).and_call_original
|
571
|
+
run_lookup(lookup)
|
572
|
+
end
|
573
|
+
|
574
|
+
it 'loads files with json extension as json on first try' do
|
575
|
+
file_path = file_containing('facts.json', <<~CONTENT)
|
576
|
+
{
|
577
|
+
"cx": " G from facts"
|
578
|
+
}
|
579
|
+
CONTENT
|
580
|
+
lookup.options[:fact_file] = file_path
|
581
|
+
|
582
|
+
expect(Puppet::Util::Json).to receive(:load_file).with(file_path, {}).and_call_original
|
583
|
+
run_lookup(lookup)
|
584
|
+
end
|
585
|
+
|
586
|
+
it 'detects file format accordingly even with random file extension' do
|
587
|
+
file_path = file_containing('facts.txt', <<~CONTENT)
|
588
|
+
{
|
589
|
+
"cx": " G from facts"
|
590
|
+
}
|
591
|
+
CONTENT
|
592
|
+
lookup.options[:fact_file] = file_path
|
593
|
+
|
594
|
+
expect(Puppet::Util::Json).to receive(:load_file_if_valid).with(file_path).and_call_original
|
595
|
+
expect(Puppet::Util::Yaml).not_to receive(:safe_load_file_if_valid).with(file_path)
|
596
|
+
run_lookup(lookup)
|
597
|
+
end
|
598
|
+
|
599
|
+
it 'detects file without extension as json due to valid contents' do
|
600
|
+
file_path = file_containing('facts', <<~CONTENT)
|
601
|
+
{
|
602
|
+
"cx": " G from facts"
|
603
|
+
}
|
604
|
+
CONTENT
|
605
|
+
lookup.options[:fact_file] = file_path
|
606
|
+
|
607
|
+
expect(Puppet::Util::Json).to receive(:load_file_if_valid).with(file_path).and_call_original
|
608
|
+
expect(Puppet::Util::Yaml).not_to receive(:safe_load_file_if_valid).with(file_path)
|
609
|
+
run_lookup(lookup)
|
610
|
+
end
|
611
|
+
|
612
|
+
it 'detects file without extension as yaml due to valid contents' do
|
613
|
+
file_path = file_containing('facts', <<~CONTENT)
|
614
|
+
---
|
615
|
+
cx: ' G from facts'
|
616
|
+
CONTENT
|
617
|
+
lookup.options[:fact_file] = file_path
|
618
|
+
|
619
|
+
expect(Puppet::Util::Json.load_file_if_valid(file_path)).to be_nil
|
620
|
+
expect(Puppet::Util::Yaml).to receive(:safe_load_file_if_valid).with(file_path).and_call_original
|
621
|
+
run_lookup(lookup)
|
622
|
+
end
|
623
|
+
|
624
|
+
it 'raises error due to invalid contents' do
|
625
|
+
file_path = file_containing('facts.yml', <<~CONTENT)
|
626
|
+
INVALID CONTENT
|
627
|
+
CONTENT
|
628
|
+
lookup.options[:fact_file] = file_path
|
629
|
+
|
630
|
+
expect {
|
631
|
+
lookup.run_command
|
632
|
+
}.to raise_error(/Incorrectly formatted data in .+ given via the --facts flag \(only accepts yaml and json files\)/)
|
633
|
+
end
|
634
|
+
|
635
|
+
it "fails when a node doesn't have facts" do
|
636
|
+
lookup.options[:node] = "bad.node"
|
637
|
+
allow(lookup.command_line).to receive(:args).and_return(['c'])
|
638
|
+
|
639
|
+
expected_error = "No facts available for target node: #{lookup.options[:node]}"
|
640
|
+
expect { lookup.run_command }.to raise_error(RuntimeError, expected_error)
|
641
|
+
end
|
642
|
+
|
643
|
+
it 'raises error due to missing trusted information facts in --facts file' do
|
644
|
+
file_path = file_containing('facts.yaml', <<~CONTENT)
|
645
|
+
---
|
646
|
+
fqdn: some.fqdn.com
|
647
|
+
CONTENT
|
648
|
+
lookup.options[:fact_file] = file_path
|
649
|
+
|
650
|
+
expect {
|
651
|
+
lookup.run_command
|
652
|
+
}.to raise_error(/When overriding any of the hostname,domain,fqdn,clientcert facts with #{file_path} given via the --facts flag, they must all be overridden./)
|
653
|
+
end
|
654
|
+
|
655
|
+
it 'does not fail when all trusted information facts are provided via --facts file' do
|
656
|
+
file_path = file_containing('facts.yaml', <<~CONTENT)
|
657
|
+
---
|
658
|
+
fqdn: some.fqdn.com
|
659
|
+
hostname: some.hostname
|
660
|
+
domain: some.domain
|
661
|
+
clientcert: some.clientcert
|
662
|
+
CONTENT
|
663
|
+
lookup.options[:fact_file] = file_path
|
664
|
+
|
665
|
+
expect {
|
666
|
+
lookup.run_command
|
667
|
+
}.to exit_with(0)
|
668
|
+
end
|
669
|
+
end
|
549
670
|
end
|
550
671
|
|
551
672
|
context 'using a puppet function as data provider' do
|
@@ -129,6 +129,35 @@ describe Puppet::Application::Resource do
|
|
129
129
|
end
|
130
130
|
|
131
131
|
describe "when printing output" do
|
132
|
+
it "should not emit puppet class tags when printing yaml" do
|
133
|
+
Puppet::Type.newtype(:stringify) do
|
134
|
+
ensurable
|
135
|
+
newparam(:name, isnamevar: true)
|
136
|
+
newproperty(:string)
|
137
|
+
end
|
138
|
+
|
139
|
+
Puppet::Type.type(:stringify).provide(:stringify) do
|
140
|
+
def exists?
|
141
|
+
true
|
142
|
+
end
|
143
|
+
|
144
|
+
def string
|
145
|
+
Puppet::Util::Execution::ProcessOutput.new('test', 0)
|
146
|
+
end
|
147
|
+
end
|
148
|
+
|
149
|
+
@resource_app.options[:to_yaml] = true
|
150
|
+
allow(@resource_app.command_line).to receive(:args).and_return(['stringify', 'hello', 'ensure=present', 'string=asd'])
|
151
|
+
expect(@resource_app).to receive(:puts).with(<<~YAML)
|
152
|
+
---
|
153
|
+
stringify:
|
154
|
+
hello:
|
155
|
+
ensure: present
|
156
|
+
string: test
|
157
|
+
YAML
|
158
|
+
expect { @resource_app.main }.not_to raise_error
|
159
|
+
end
|
160
|
+
|
132
161
|
it "should ensure all values to be printed are in the external encoding" do
|
133
162
|
resources = [
|
134
163
|
Puppet::Type.type(:user).new(:name => "\u2603".force_encoding(Encoding::UTF_8)).to_resource,
|
@@ -0,0 +1,39 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
require 'puppet/concurrent/thread_local_singleton'
|
3
|
+
|
4
|
+
class PuppetSpec::Singleton
|
5
|
+
extend Puppet::Concurrent::ThreadLocalSingleton
|
6
|
+
end
|
7
|
+
|
8
|
+
# Use the `equal?` matcher to ensure we get the same object
|
9
|
+
describe Puppet::Concurrent::ThreadLocalSingleton do
|
10
|
+
it 'returns the same object for a single thread' do
|
11
|
+
expect(PuppetSpec::Singleton.singleton).to equal(PuppetSpec::Singleton.singleton)
|
12
|
+
end
|
13
|
+
|
14
|
+
it 'is not inherited for a newly created thread' do
|
15
|
+
main_thread_local = PuppetSpec::Singleton.singleton
|
16
|
+
Thread.new do
|
17
|
+
expect(main_thread_local).to_not equal(PuppetSpec::Singleton.singleton)
|
18
|
+
end.join
|
19
|
+
end
|
20
|
+
|
21
|
+
it 'does not leak outside a thread' do
|
22
|
+
thread_local = nil
|
23
|
+
Thread.new do
|
24
|
+
thread_local = PuppetSpec::Singleton.singleton
|
25
|
+
end.join
|
26
|
+
expect(thread_local).to_not equal(PuppetSpec::Singleton.singleton)
|
27
|
+
end
|
28
|
+
|
29
|
+
it 'is different for each thread' do
|
30
|
+
locals = []
|
31
|
+
Thread.new do
|
32
|
+
locals << PuppetSpec::Singleton.singleton
|
33
|
+
end.join
|
34
|
+
Thread.new do
|
35
|
+
locals << PuppetSpec::Singleton.singleton
|
36
|
+
end.join
|
37
|
+
expect(locals.first).to_not equal(locals.last)
|
38
|
+
end
|
39
|
+
end
|