puppet 6.0.5-universal-darwin → 6.0.7-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.
- checksums.yaml +4 -4
- data/CODEOWNERS +30 -0
- data/Gemfile.lock +14 -14
- data/lib/puppet.rb +4 -4
- data/lib/puppet/application.rb +1 -1
- data/lib/puppet/application/filebucket.rb +6 -1
- data/lib/puppet/configurer.rb +6 -6
- data/lib/puppet/confine/boolean.rb +45 -0
- data/lib/puppet/confine/false.rb +7 -1
- data/lib/puppet/confine/true.rb +7 -1
- data/lib/puppet/defaults.rb +21 -29
- data/lib/puppet/functions/call.rb +2 -1
- data/lib/puppet/network/http/connection.rb +15 -5
- data/lib/puppet/pops/issues.rb +4 -0
- data/lib/puppet/pops/loader/ruby_legacy_function_instantiator.rb +60 -4
- data/lib/puppet/pops/model/factory.rb +38 -4
- data/lib/puppet/pops/parser/egrammar.ra +2 -2
- data/lib/puppet/pops/parser/heredoc_support.rb +17 -7
- data/lib/puppet/pops/parser/lexer2.rb +6 -1
- data/lib/puppet/pops/parser/locator.rb +106 -86
- data/lib/puppet/pops/parser/parser_support.rb +11 -2
- data/lib/puppet/pops/types/type_mismatch_describer.rb +1 -1
- data/lib/puppet/provider/file/windows.rb +49 -1
- data/lib/puppet/provider/group/windows_adsi.rb +4 -1
- data/lib/puppet/provider/package/windows.rb +5 -1
- data/lib/puppet/provider/service/upstart.rb +16 -6
- data/lib/puppet/settings.rb +10 -5
- data/lib/puppet/transaction.rb +8 -6
- data/lib/puppet/transaction/resource_harness.rb +1 -0
- data/lib/puppet/type/exec.rb +27 -5
- data/lib/puppet/type/file/mode.rb +6 -1
- data/lib/puppet/type/filebucket.rb +12 -8
- data/lib/puppet/util/command_line.rb +5 -1
- data/lib/puppet/util/log.rb +7 -2
- data/lib/puppet/util/pidlock.rb +14 -1
- data/lib/puppet/util/windows/process.rb +73 -5
- data/lib/puppet/util/windows/security.rb +29 -8
- data/lib/puppet/version.rb +1 -1
- data/locales/ja/puppet.po +149 -132
- data/locales/puppet.pot +197 -148
- data/man/man5/puppet.conf.5 +14 -6
- data/man/man8/puppet-agent.8 +1 -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 +6 -2
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-key.8 +1 -1
- data/man/man8/puppet-lookup.8 +1 -1
- data/man/man8/puppet-man.8 +1 -1
- data/man/man8/puppet-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-status.8 +1 -1
- data/man/man8/puppet.8 +2 -2
- data/spec/fixtures/unit/pops/loaders/loaders/mix_4x_and_3x_functions/usee/lib/puppet/parser/functions/bad_func_load2.rb +11 -0
- data/spec/fixtures/unit/pops/loaders/loaders/mix_4x_and_3x_functions/usee/lib/puppet/parser/functions/bad_func_load3.rb +11 -0
- data/spec/fixtures/unit/pops/loaders/loaders/mix_4x_and_3x_functions/usee/lib/puppet/parser/functions/bad_func_load4.rb +11 -0
- data/spec/fixtures/unit/pops/loaders/loaders/mix_4x_and_3x_functions/usee/lib/puppet/parser/functions/bad_func_load5.rb +12 -0
- data/spec/fixtures/unit/pops/loaders/loaders/mix_4x_and_3x_functions/usee/lib/puppet/parser/functions/good_func_load.rb +9 -0
- data/spec/integration/provider/file/windows_spec.rb +162 -0
- data/spec/integration/type/file_spec.rb +0 -19
- data/spec/unit/application_spec.rb +8 -1
- data/spec/unit/configurer_spec.rb +6 -7
- data/spec/unit/confine/false_spec.rb +27 -0
- data/spec/unit/confine/true_spec.rb +27 -0
- data/spec/unit/defaults_spec.rb +0 -14
- data/spec/unit/network/http/connection_spec.rb +1 -1
- data/spec/unit/pops/loaders/loaders_spec.rb +70 -3
- data/spec/unit/pops/parser/locator_spec.rb +45 -0
- data/spec/unit/pops/parser/parse_heredoc_spec.rb +111 -15
- data/spec/unit/pops/types/type_mismatch_describer_spec.rb +9 -0
- data/spec/unit/provider/group/windows_adsi_spec.rb +7 -1
- data/spec/unit/provider/package/windows_spec.rb +12 -1
- data/spec/unit/provider/service/systemd_spec.rb +7 -5
- data/spec/unit/settings_spec.rb +36 -0
- data/spec/unit/transaction/resource_harness_spec.rb +26 -0
- data/spec/unit/transaction_spec.rb +29 -0
- data/spec/unit/type/exec_spec.rb +47 -0
- data/spec/unit/type/filebucket_spec.rb +8 -6
- data/spec/unit/util/command_line_spec.rb +23 -2
- data/spec/unit/util/execution_spec.rb +2 -2
- data/spec/unit/util/log_spec.rb +15 -0
- data/spec/unit/util/pidlock_spec.rb +21 -1
- data/spec/unit/util/storage_spec.rb +19 -19
- metadata +16 -3
- data/MAINTAINERS +0 -47
@@ -244,6 +244,15 @@ describe 'the type mismatch describer' do
|
|
244
244
|
expect { eval_and_collect_notices(code) }.to(raise_error(Puppet::Error,
|
245
245
|
/Class\[Test\]: parameter 'opts' expects size to be 1, got 0/))
|
246
246
|
end
|
247
|
+
|
248
|
+
it "treats Optional as Optional[Any]" do
|
249
|
+
code = <<-PUPPET
|
250
|
+
class test(Optional $var=undef) {}
|
251
|
+
class { 'test': var => 'hello' }
|
252
|
+
PUPPET
|
253
|
+
expect { eval_and_collect_notices(code) }.not_to raise_error
|
254
|
+
end
|
255
|
+
|
247
256
|
end
|
248
257
|
end
|
249
258
|
end
|
@@ -251,7 +251,13 @@ describe Puppet::Type.type(:group).provider(:windows_adsi), :if => Puppet::Util:
|
|
251
251
|
'user3',
|
252
252
|
]
|
253
253
|
|
254
|
-
|
254
|
+
expected_member_sids = [user1.sid, user2.sid, user3.sid]
|
255
|
+
expected_members = ['user1', 'user2', 'user3']
|
256
|
+
provider.stubs(:members_to_s)
|
257
|
+
.with(expected_member_sids)
|
258
|
+
.returns(expected_members.join(','))
|
259
|
+
|
260
|
+
expect(provider.members).to match_array(expected_members)
|
255
261
|
end
|
256
262
|
|
257
263
|
it "should be able to set group members" do
|
@@ -86,7 +86,7 @@ describe Puppet::Type.type(:package).provider(:windows), :if => Puppet.features.
|
|
86
86
|
context '#install' do
|
87
87
|
let(:command) { 'blarg.exe /S' }
|
88
88
|
let(:klass) { mock('installer', :install_command => ['blarg.exe', '/S'] ) }
|
89
|
-
let(:execute_options) do {:failonfail => false, :combine => true, :cwd =>
|
89
|
+
let(:execute_options) do {:failonfail => false, :combine => true, :cwd => nil, :suppress_window => true} end
|
90
90
|
before :each do
|
91
91
|
Puppet::Provider::Package::Windows::Package.expects(:installer_class).returns(klass)
|
92
92
|
end
|
@@ -136,6 +136,17 @@ describe Puppet::Type.type(:package).provider(:windows), :if => Puppet.features.
|
|
136
136
|
expect(error.code).to eq(5) # ERROR_ACCESS_DENIED
|
137
137
|
end
|
138
138
|
end
|
139
|
+
|
140
|
+
context 'With a real working dir' do
|
141
|
+
let(:execute_options) do {:failonfail => false, :combine => true, :cwd => 'E:\Rando\Directory', :suppress_window => true} end
|
142
|
+
|
143
|
+
it 'should not try to set the working directory' do
|
144
|
+
Puppet::FileSystem.expects(:exist?).with('E:\Rando\Directory').returns(true)
|
145
|
+
expect_execute(command, 0)
|
146
|
+
|
147
|
+
provider.install
|
148
|
+
end
|
149
|
+
end
|
139
150
|
end
|
140
151
|
|
141
152
|
context '#uninstall' do
|
@@ -33,11 +33,13 @@ describe 'Puppet::Type::Service::Provider::Systemd', unless: Puppet::Util::Platf
|
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
36
|
+
[7, 8].each do |ver|
|
37
|
+
it "should be the default provider on rhel#{ver}" do
|
38
|
+
Facter.stubs(:value).with(:osfamily).returns(:redhat)
|
39
|
+
Facter.stubs(:value).with(:operatingsystem).returns(:redhat)
|
40
|
+
Facter.stubs(:value).with(:operatingsystemmajrelease).returns(ver.to_s)
|
41
|
+
expect(provider_class).to be_default
|
42
|
+
end
|
41
43
|
end
|
42
44
|
|
43
45
|
[ 4, 5, 6 ].each do |ver|
|
data/spec/unit/settings_spec.rb
CHANGED
@@ -702,6 +702,42 @@ describe Puppet::Settings do
|
|
702
702
|
@settings.send(:parse_config_files)
|
703
703
|
end
|
704
704
|
end
|
705
|
+
|
706
|
+
describe "when the file exists" do
|
707
|
+
it "fails if the file is not readable" do
|
708
|
+
Puppet::FileSystem.expects(:exist?).with(user_config_file_default_location).returns(true)
|
709
|
+
@settings.expects(:read_file).raises('Permission denied')
|
710
|
+
|
711
|
+
expect{ @settings.send(:parse_config_files) }.to raise_error(RuntimeError, /Could not load #{user_config_file_default_location}: Permission denied/)
|
712
|
+
end
|
713
|
+
|
714
|
+
it "does not fail if the file is not readable and when `require_config` is false" do
|
715
|
+
Puppet::FileSystem.expects(:exist?).with(user_config_file_default_location).returns(true)
|
716
|
+
@settings.expects(:read_file).raises('Permission denied')
|
717
|
+
|
718
|
+
@settings.expects(:parse_config).never
|
719
|
+
Puppet.expects(:log_exception)
|
720
|
+
|
721
|
+
expect{ @settings.send(:parse_config_files, false) }.not_to raise_error
|
722
|
+
end
|
723
|
+
|
724
|
+
it "reads the file if it is readable" do
|
725
|
+
Puppet::FileSystem.expects(:exist?).with(user_config_file_default_location).returns(true)
|
726
|
+
@settings.expects(:read_file).returns('server = host.string')
|
727
|
+
@settings.expects(:parse_config)
|
728
|
+
|
729
|
+
@settings.send(:parse_config_files)
|
730
|
+
end
|
731
|
+
end
|
732
|
+
|
733
|
+
describe "when the file does not exist" do
|
734
|
+
it "does not attempt to parse the config file" do
|
735
|
+
Puppet::FileSystem.expects(:exist?).with(user_config_file_default_location).returns(false)
|
736
|
+
@settings.expects(:parse_config).never
|
737
|
+
|
738
|
+
@settings.send(:parse_config_files)
|
739
|
+
end
|
740
|
+
end
|
705
741
|
end
|
706
742
|
|
707
743
|
describe "when parsing its configuration" do
|
@@ -601,4 +601,30 @@ describe Puppet::Transaction::ResourceHarness do
|
|
601
601
|
Puppet::Util::Storage.expects(:cache).with(@resource).returns data
|
602
602
|
expect(@harness.cached(@resource, :foo)).to eq("other")
|
603
603
|
end
|
604
|
+
|
605
|
+
describe "successful event message" do
|
606
|
+
let(:test_file) do
|
607
|
+
tmpfile('foo').tap do |path|
|
608
|
+
File.open(path, 'w') { |fh| fh.write("old contents") }
|
609
|
+
end
|
610
|
+
end
|
611
|
+
|
612
|
+
let(:resource) do
|
613
|
+
Puppet::Type.type(:file).new(:path => test_file, :backup => false, :content => "hello world")
|
614
|
+
end
|
615
|
+
|
616
|
+
it "contains (corrective) when corrective change" do
|
617
|
+
Puppet::Transaction::Event.any_instance.stubs(:corrective_change).returns(true)
|
618
|
+
status = @harness.evaluate(resource)
|
619
|
+
sync_event = status.events[0]
|
620
|
+
expect(sync_event.message).to match(/content changed '{md5}[0-9a-f]+' to '{md5}[0-9a-f]+' \(corrective\)/)
|
621
|
+
end
|
622
|
+
|
623
|
+
it "contains no modifier when intentional change" do
|
624
|
+
Puppet::Transaction::Event.any_instance.stubs(:corrective_change).returns(false)
|
625
|
+
status = @harness.evaluate(resource)
|
626
|
+
sync_event = status.events[0]
|
627
|
+
expect(sync_event.message).to match(/content changed '{md5}[0-9a-f]+' to '{md5}[0-9a-f]+'$/)
|
628
|
+
end
|
629
|
+
end
|
604
630
|
end
|
@@ -600,6 +600,30 @@ describe Puppet::Transaction do
|
|
600
600
|
transaction.prefetch_if_necessary(resource)
|
601
601
|
end
|
602
602
|
|
603
|
+
it "should not rescue SystemExit without future_features flag" do
|
604
|
+
Puppet.settings[:future_features] = false
|
605
|
+
resource.provider.class.expects(:prefetch).raises(SystemExit, "SystemMessage")
|
606
|
+
expect { transaction.prefetch_if_necessary(resource) }.to raise_error(SystemExit, "SystemMessage")
|
607
|
+
end
|
608
|
+
|
609
|
+
it "should not rescue SystemExit with future_features flag" do
|
610
|
+
Puppet.settings[:future_features] = true
|
611
|
+
resource.provider.class.expects(:prefetch).raises(SystemExit, "SystemMessage")
|
612
|
+
expect { transaction.prefetch_if_necessary(resource) }.to raise_error(SystemExit, "SystemMessage")
|
613
|
+
end
|
614
|
+
|
615
|
+
it "should rescue LoadError without future_features flag" do
|
616
|
+
Puppet.settings[:future_features] = false
|
617
|
+
resource.provider.class.expects(:prefetch).raises(LoadError, "LoadMessage")
|
618
|
+
expect { transaction.prefetch_if_necessary(resource) }.not_to raise_error
|
619
|
+
end
|
620
|
+
|
621
|
+
it "should rescue LoadError with future_features flag" do
|
622
|
+
Puppet.settings[:future_features] = true
|
623
|
+
resource.provider.class.expects(:prefetch).raises(LoadError, "LoadMessage")
|
624
|
+
expect { transaction.prefetch_if_necessary(resource) }.not_to raise_error
|
625
|
+
end
|
626
|
+
|
603
627
|
describe "and prefetching fails" do
|
604
628
|
before :each do
|
605
629
|
resource.provider.class.expects(:prefetch).raises(Puppet::Error, "message")
|
@@ -613,6 +637,11 @@ describe Puppet::Transaction do
|
|
613
637
|
it "should not rescue prefetch executions" do
|
614
638
|
expect { transaction.prefetch_if_necessary(resource) }.to raise_error(Puppet::Error)
|
615
639
|
end
|
640
|
+
|
641
|
+
it "should log the exception during prefetch" do
|
642
|
+
Puppet.expects(:log_exception).with(anything, "Could not prefetch package provider 'pkgng': message")
|
643
|
+
expect { transaction.prefetch_if_necessary(resource) }.to raise_error(Puppet::Error, "message")
|
644
|
+
end
|
616
645
|
end
|
617
646
|
|
618
647
|
context "with future_features flag" do
|
data/spec/unit/type/exec_spec.rb
CHANGED
@@ -31,6 +31,33 @@ describe Puppet::Type.type(:exec) do
|
|
31
31
|
return exec
|
32
32
|
end
|
33
33
|
|
34
|
+
def exec_stub(options = {})
|
35
|
+
command = options.delete(:command) || @command
|
36
|
+
#unless_val = options.delete(:unless) || :true
|
37
|
+
type_args = {
|
38
|
+
:name => command,
|
39
|
+
#:unless => unless_val,
|
40
|
+
}.merge(options)
|
41
|
+
|
42
|
+
# Chicken, meet egg:
|
43
|
+
# Provider methods have to be stubbed before resource init or checks fail
|
44
|
+
# We have to set 'unless' in resource init or it can not be marked sensitive correctly.
|
45
|
+
# So: we create a dummy ahead of time and use 'any_instance' to stub out provider methods.
|
46
|
+
dummy = Puppet::Type.type(:exec).new(:name => @command)
|
47
|
+
dummy.provider.class.any_instance.stubs(:validatecmd)
|
48
|
+
dummy.provider.class.any_instance.stubs(:checkexe).returns(true)
|
49
|
+
pass_status = stub('status', :exitstatus => 0, :split => ["pass output"])
|
50
|
+
fail_status = stub('status', :exitstatus => 1, :split => ["fail output"])
|
51
|
+
Puppet::Util::Execution.stubs(:execute).with(:true, anything).returns(pass_status)
|
52
|
+
Puppet::Util::Execution.stubs(:execute).with(:false, anything).returns(fail_status)
|
53
|
+
|
54
|
+
test = Puppet::Type.type(:exec).new(type_args)
|
55
|
+
|
56
|
+
Puppet::Util::Log.level = :debug
|
57
|
+
|
58
|
+
return test
|
59
|
+
end
|
60
|
+
|
34
61
|
before do
|
35
62
|
@command = make_absolute('/bin/true whatever')
|
36
63
|
@executable = make_absolute('/bin/true')
|
@@ -176,6 +203,26 @@ describe Puppet::Type.type(:exec) do
|
|
176
203
|
expect(@logs).to eq([])
|
177
204
|
end
|
178
205
|
|
206
|
+
describe "when checks stop execution when debugging" do
|
207
|
+
[[:unless, :true], [:onlyif, :false]].each do |check, result|
|
208
|
+
it "should log a message with the command when #{check} is #{result}" do
|
209
|
+
output = "'#{@command}' won't be executed because of failed check '#{check}'"
|
210
|
+
test = exec_stub({:command => @command, check => result})
|
211
|
+
expect(test.check_all_attributes).to eq(false)
|
212
|
+
expect(@logs).to include(an_object_having_attributes(level: :debug, message: output))
|
213
|
+
end
|
214
|
+
|
215
|
+
it "should log a message with a redacted command and check if #{check} is sensitive" do
|
216
|
+
output1 = "Executing check '[redacted]'"
|
217
|
+
output2 = "'[command redacted]' won't be executed because of failed check '#{check}'"
|
218
|
+
test = exec_stub({:command => @command, check => result, :sensitive_parameters => [check]})
|
219
|
+
expect(test.check_all_attributes).to eq(false)
|
220
|
+
expect(@logs).to include(an_object_having_attributes(level: :debug, message: output1))
|
221
|
+
expect(@logs).to include(an_object_having_attributes(level: :debug, message: output2))
|
222
|
+
end
|
223
|
+
end
|
224
|
+
end
|
225
|
+
|
179
226
|
describe " when multiple tries are set," do
|
180
227
|
it "should repeat the command attempt 'tries' times on failure and produce an error" do
|
181
228
|
tries = 5
|
@@ -21,14 +21,14 @@ describe Puppet::Type.type(:filebucket) do
|
|
21
21
|
expect(Puppet::Type.type(:filebucket).new(:name => "main")[:path]).to eq(Puppet[:clientbucketdir])
|
22
22
|
end
|
23
23
|
|
24
|
-
it "should
|
24
|
+
it "should not have a default port" do
|
25
25
|
Puppet.settings[:masterport] = 50
|
26
|
-
expect(Puppet::Type.type(:filebucket).new(:name => "main")[:port]).to eq(
|
26
|
+
expect(Puppet::Type.type(:filebucket).new(:name => "main")[:port]).to eq(nil)
|
27
27
|
end
|
28
28
|
|
29
|
-
it "should
|
29
|
+
it "should not have a default server" do
|
30
30
|
Puppet.settings[:server] = "myserver"
|
31
|
-
expect(Puppet::Type.type(:filebucket).new(:name => "main")[:server]).to eq(
|
31
|
+
expect(Puppet::Type.type(:filebucket).new(:name => "main")[:server]).to eq(nil)
|
32
32
|
end
|
33
33
|
|
34
34
|
it "be local by default" do
|
@@ -93,10 +93,12 @@ describe Puppet::Type.type(:filebucket) do
|
|
93
93
|
bucket.bucket
|
94
94
|
end
|
95
95
|
|
96
|
-
it "should
|
96
|
+
it "should not try to guess server or port if the path is unset and no server is provided" do
|
97
97
|
Puppet.settings[:server] = "myserv"
|
98
|
+
Puppet.settings[:server_list] = ['server_list_0', 'server_list_1']
|
99
|
+
Puppet::FileBucket::Dipper.expects(:new).with(:Server => nil, :Port => nil).returns @bucket
|
100
|
+
|
98
101
|
bucket = Puppet::Type.type(:filebucket).new :name => "main", :path => false
|
99
|
-
Puppet::FileBucket::Dipper.expects(:new).with { |args| args[:Server] == "myserv" }.returns @bucket
|
100
102
|
bucket.bucket
|
101
103
|
end
|
102
104
|
end
|
@@ -67,8 +67,8 @@ describe Puppet::Util::CommandLine do
|
|
67
67
|
end
|
68
68
|
end
|
69
69
|
|
70
|
-
%w{--help -h}.each do|arg|
|
71
|
-
it "should print help" do
|
70
|
+
%w{--help -h help}.each do|arg|
|
71
|
+
it "should print help and exit if #{arg} is given" do
|
72
72
|
commandline = Puppet::Util::CommandLine.new("puppet", [arg])
|
73
73
|
commandline.expects(:exec).never
|
74
74
|
|
@@ -77,6 +77,27 @@ describe Puppet::Util::CommandLine do
|
|
77
77
|
}.to have_printed(/Usage: puppet <subcommand> \[options\] <action> \[options\]/).and_exit_with(0)
|
78
78
|
end
|
79
79
|
end
|
80
|
+
|
81
|
+
it "should fail if the config file isn't readable and we're running a subcommand that requires a readable config file" do
|
82
|
+
Puppet::FileSystem.stubs(:exist?).with(Puppet[:config]).returns(true)
|
83
|
+
Puppet::Settings.any_instance.stubs(:read_file).returns('')
|
84
|
+
Puppet::Settings.any_instance.expects(:read_file).with(Puppet[:config]).raises('Permission denied')
|
85
|
+
|
86
|
+
expect{ described_class.new("puppet", ['config']).execute }.to raise_error(SystemExit)
|
87
|
+
end
|
88
|
+
|
89
|
+
it "should not fail if the config file isn't readable and we're running a subcommand that does not require a readable config file" do
|
90
|
+
Puppet::FileSystem.stubs(:exist?)
|
91
|
+
Puppet::FileSystem.stubs(:exist?).with(Puppet[:config]).returns(true)
|
92
|
+
Puppet::Settings.any_instance.stubs(:read_file).returns('')
|
93
|
+
Puppet::Settings.any_instance.expects(:read_file).with(Puppet[:config]).raises('Permission denied')
|
94
|
+
|
95
|
+
commandline = described_class.new("puppet", ['help'])
|
96
|
+
|
97
|
+
expect {
|
98
|
+
commandline.execute
|
99
|
+
}.to have_printed(/Usage: puppet <subcommand> \[options\] <action> \[options\]/).and_exit_with(0)
|
100
|
+
end
|
80
101
|
end
|
81
102
|
|
82
103
|
describe "when dealing with puppet commands" do
|
@@ -158,7 +158,6 @@ describe Puppet::Util::Execution, if: !Puppet::Util::Platform.jruby? do
|
|
158
158
|
context 'cwd option' do
|
159
159
|
let(:cwd) { 'cwd' }
|
160
160
|
it "should execute the command in the specified working directory" do
|
161
|
-
Dir.expects(:chdir).with(cwd).yields
|
162
161
|
Process.expects(:create).with(
|
163
162
|
:command_line => "test command",
|
164
163
|
:startup_info => {
|
@@ -166,7 +165,8 @@ describe Puppet::Util::Execution, if: !Puppet::Util::Platform.jruby? do
|
|
166
165
|
:stdout => @stdout,
|
167
166
|
:stderr => @stderr
|
168
167
|
},
|
169
|
-
:close_handles => false
|
168
|
+
:close_handles => false,
|
169
|
+
:cwd => cwd
|
170
170
|
)
|
171
171
|
|
172
172
|
call_exec_windows('test command', { :cwd => cwd }, @stdin, @stdout, @stderr)
|
data/spec/unit/util/log_spec.rb
CHANGED
@@ -88,6 +88,21 @@ describe Puppet::Util::Log do
|
|
88
88
|
expect(logs.last.source).to eq(utf_8_msg)
|
89
89
|
end
|
90
90
|
|
91
|
+
require 'puppet/util/log/destinations'
|
92
|
+
|
93
|
+
it "raises an error when it has no successful logging destinations" do
|
94
|
+
# spec_helper.rb redirects log output away from the console,
|
95
|
+
# so we have to stop that here, or else the logic we are testing
|
96
|
+
# will not be reached.
|
97
|
+
Puppet::Util::Log.stubs(:destinations).returns({})
|
98
|
+
|
99
|
+
our_exception = Puppet::DevError.new("test exception")
|
100
|
+
Puppet::FileSystem.expects(:dir).raises(our_exception)
|
101
|
+
bad_file = tmpfile("bad_file")
|
102
|
+
|
103
|
+
expect { Puppet::Util::Log.newdestination(bad_file) }.to raise_error(Puppet::DevError)
|
104
|
+
end
|
105
|
+
|
91
106
|
describe ".setup_default" do
|
92
107
|
it "should default to :syslog" do
|
93
108
|
Puppet.features.stubs(:syslog?).returns(true)
|
@@ -3,7 +3,7 @@ require 'spec_helper'
|
|
3
3
|
|
4
4
|
require 'puppet/util/pidlock'
|
5
5
|
|
6
|
-
describe Puppet::Util::Pidlock do
|
6
|
+
describe Puppet::Util::Pidlock, if: !Puppet::Util::Platform.jruby? do
|
7
7
|
require 'puppet_spec/files'
|
8
8
|
include PuppetSpec::Files
|
9
9
|
|
@@ -23,6 +23,11 @@ describe Puppet::Util::Pidlock do
|
|
23
23
|
|
24
24
|
it "should become locked" do
|
25
25
|
@lock.lock
|
26
|
+
if Puppet::Util::Platform.windows?
|
27
|
+
Puppet::Util::Windows::Process.stubs(:get_process_image_name_by_pid).with(@lock.lock_pid).returns('C:\Program Files\Puppet Labs\Puppet\puppet\bin\ruby.exe')
|
28
|
+
else
|
29
|
+
Puppet::Util::Execution.stubs(:execute).with(['ps', '-p', @lock.lock_pid, '-o', 'comm=']).returns('puppet')
|
30
|
+
end
|
26
31
|
expect(@lock).to be_locked
|
27
32
|
end
|
28
33
|
|
@@ -101,6 +106,11 @@ describe Puppet::Util::Pidlock do
|
|
101
106
|
describe "#locked?" do
|
102
107
|
it "should return true if locked" do
|
103
108
|
@lock.lock
|
109
|
+
if Puppet::Util::Platform.windows?
|
110
|
+
Puppet::Util::Windows::Process.stubs(:get_process_image_name_by_pid).with(@lock.lock_pid).returns('C:\Program Files\Puppet Labs\Puppet\puppet\bin\ruby.exe')
|
111
|
+
else
|
112
|
+
Puppet::Util::Execution.stubs(:execute).with(['ps', '-p', @lock.lock_pid, '-o', 'comm=']).returns('puppet')
|
113
|
+
end
|
104
114
|
expect(@lock).to be_locked
|
105
115
|
end
|
106
116
|
|
@@ -146,6 +156,11 @@ describe Puppet::Util::Pidlock do
|
|
146
156
|
end
|
147
157
|
|
148
158
|
it "should replace with new locks" do
|
159
|
+
if Puppet::Util::Platform.windows?
|
160
|
+
Puppet::Util::Windows::Process.stubs(:get_process_image_name_by_pid).with(6789).returns('C:\Program Files\Puppet Labs\Puppet\puppet\bin\ruby.exe')
|
161
|
+
else
|
162
|
+
Puppet::Util::Execution.stubs(:execute).with(['ps', '-p', 6789, '-o', 'comm=']).returns('puppet')
|
163
|
+
end
|
149
164
|
@lock.lock
|
150
165
|
expect(Puppet::FileSystem.exist?(@lockfile)).to be_truthy
|
151
166
|
expect(@lock.lock_pid).to eq(6789)
|
@@ -170,6 +185,11 @@ describe Puppet::Util::Pidlock do
|
|
170
185
|
before(:each) do
|
171
186
|
# fake our pid to be 1234
|
172
187
|
Process.stubs(:pid).returns(1234)
|
188
|
+
if Puppet::Util::Platform.windows?
|
189
|
+
Puppet::Util::Windows::Process.stubs(:get_process_image_name_by_pid).with(1234).returns('C:\Program Files\Puppet Labs\Puppet\puppet\bin\ruby.exe')
|
190
|
+
else
|
191
|
+
Puppet::Util::Execution.stubs(:execute).with(['ps', '-p', 1234, '-o', 'comm=']).returns('puppet')
|
192
|
+
end
|
173
193
|
# lock the file
|
174
194
|
@lock.lock
|
175
195
|
# fake our pid to be a different pid, to simulate someone else
|
@@ -181,6 +181,8 @@ describe Puppet::Util::Storage do
|
|
181
181
|
end
|
182
182
|
|
183
183
|
describe "when storing to the state file" do
|
184
|
+
A_SMALL_AMOUNT_OF_TIME = 0.001 #Seconds
|
185
|
+
|
184
186
|
before(:each) do
|
185
187
|
@state_file = tmpfile('storage_test')
|
186
188
|
@saved_statefile = Puppet[:statefile]
|
@@ -232,13 +234,13 @@ describe Puppet::Util::Storage do
|
|
232
234
|
stale_checked = recent_checked - (Puppet[:statettl] + 10)
|
233
235
|
Puppet::Util::Storage.cache(:yayness)[:checked] = recent_checked
|
234
236
|
Puppet::Util::Storage.cache(:stale)[:checked] = stale_checked
|
235
|
-
expect(Puppet::Util::Storage.state).to
|
237
|
+
expect(Puppet::Util::Storage.state).to match(
|
236
238
|
{
|
237
239
|
:yayness => {
|
238
|
-
:checked => recent_checked
|
240
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(recent_checked)
|
239
241
|
},
|
240
242
|
:stale => {
|
241
|
-
:checked => stale_checked
|
243
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(stale_checked)
|
242
244
|
}
|
243
245
|
}
|
244
246
|
)
|
@@ -250,29 +252,28 @@ describe Puppet::Util::Storage do
|
|
250
252
|
|
251
253
|
Puppet::Util::Storage.load
|
252
254
|
|
253
|
-
expect(Puppet::Util::Storage.state).to
|
255
|
+
expect(Puppet::Util::Storage.state).to match(
|
254
256
|
{
|
255
257
|
:yayness => {
|
256
|
-
:checked => recent_checked
|
258
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(recent_checked)
|
257
259
|
}
|
258
260
|
}
|
259
261
|
)
|
260
262
|
end
|
261
263
|
|
262
|
-
|
263
264
|
it "does not expire entries when statettl is 0" do
|
264
265
|
Puppet[:statettl] = '0'
|
265
266
|
recent_checked = Time.now.round
|
266
267
|
older_checked = recent_checked - 10_000_000
|
267
268
|
Puppet::Util::Storage.cache(:yayness)[:checked] = recent_checked
|
268
269
|
Puppet::Util::Storage.cache(:older)[:checked] = older_checked
|
269
|
-
expect(Puppet::Util::Storage.state).to
|
270
|
+
expect(Puppet::Util::Storage.state).to match(
|
270
271
|
{
|
271
272
|
:yayness => {
|
272
|
-
:checked => recent_checked
|
273
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(recent_checked)
|
273
274
|
},
|
274
275
|
:older => {
|
275
|
-
:checked => older_checked
|
276
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(older_checked)
|
276
277
|
}
|
277
278
|
}
|
278
279
|
)
|
@@ -284,32 +285,31 @@ describe Puppet::Util::Storage do
|
|
284
285
|
|
285
286
|
Puppet::Util::Storage.load
|
286
287
|
|
287
|
-
expect(Puppet::Util::Storage.state).to
|
288
|
+
expect(Puppet::Util::Storage.state).to match(
|
288
289
|
{
|
289
290
|
:yayness => {
|
290
|
-
:checked => recent_checked
|
291
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(recent_checked)
|
291
292
|
},
|
292
293
|
:older => {
|
293
|
-
:checked => older_checked
|
294
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(older_checked)
|
294
295
|
}
|
295
296
|
}
|
296
297
|
)
|
297
298
|
end
|
298
299
|
|
299
|
-
|
300
300
|
it "does not expire entries when statettl is 'unlimited'" do
|
301
301
|
Puppet[:statettl] = 'unlimited'
|
302
302
|
recent_checked = Time.now
|
303
303
|
older_checked = Time.now - 10_000_000
|
304
304
|
Puppet::Util::Storage.cache(:yayness)[:checked] = recent_checked
|
305
305
|
Puppet::Util::Storage.cache(:older)[:checked] = older_checked
|
306
|
-
expect(Puppet::Util::Storage.state).to
|
306
|
+
expect(Puppet::Util::Storage.state).to match(
|
307
307
|
{
|
308
308
|
:yayness => {
|
309
|
-
:checked => recent_checked
|
309
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(recent_checked)
|
310
310
|
},
|
311
311
|
:older => {
|
312
|
-
:checked => older_checked
|
312
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(older_checked)
|
313
313
|
}
|
314
314
|
}
|
315
315
|
)
|
@@ -321,13 +321,13 @@ describe Puppet::Util::Storage do
|
|
321
321
|
|
322
322
|
Puppet::Util::Storage.load
|
323
323
|
|
324
|
-
expect(Puppet::Util::Storage.state).to
|
324
|
+
expect(Puppet::Util::Storage.state).to match(
|
325
325
|
{
|
326
326
|
:yayness => {
|
327
|
-
:checked => recent_checked
|
327
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(recent_checked)
|
328
328
|
},
|
329
329
|
:older => {
|
330
|
-
:checked => older_checked
|
330
|
+
:checked => a_value_within(A_SMALL_AMOUNT_OF_TIME).of(older_checked)
|
331
331
|
}
|
332
332
|
}
|
333
333
|
)
|