puppet 6.0.5-universal-darwin → 6.0.7-universal-darwin
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of puppet might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CODEOWNERS +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 | 
             
                  )
         |