diff options
-rw-r--r-- | lib/chef/provider/cron.rb | 7 | ||||
-rw-r--r-- | spec/unit/provider/cron_spec.rb | 45 |
2 files changed, 50 insertions, 2 deletions
diff --git a/lib/chef/provider/cron.rb b/lib/chef/provider/cron.rb index 7d37f34b1a..694f7ba4b8 100644 --- a/lib/chef/provider/cron.rb +++ b/lib/chef/provider/cron.rb @@ -100,8 +100,11 @@ class Chef newcron = get_crontab_entry if @cron_exists - unless cron_different? - logger.trace("Skipping existing cron entry '#{new_resource.name}'") + # Only compare the crontab if the current resource has a set command. + # This may not be set in cases where the Chef comment exists but the + # crontab command was commented out. + if current_resource.property_is_set?(:command) && !cron_different? + logger.debug("#{new_resource}: Skipping existing cron entry") return end read_crontab.each_line do |line| diff --git a/spec/unit/provider/cron_spec.rb b/spec/unit/provider/cron_spec.rb index 76f170312e..ac92f45cf8 100644 --- a/spec/unit/provider/cron_spec.rb +++ b/spec/unit/provider/cron_spec.rb @@ -392,6 +392,27 @@ describe Chef::Provider::Cron do expect(cron.command).to eq("/bin/true") end end + + context "with a matching entry with a commented crontab line" do + it "should set cron_exists" do + allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB) + 0 2 * * * /some/other/command + + # Chef Name: cronhole some stuff + #* * * * * /bin/true + CRONTAB + cron = @provider.load_current_resource + expect(@provider.cron_exists).to eq(true) + expect(@provider.cron_empty).to eq(false) + expect(cron.minute).to eq("*") + expect(cron.hour).to eq("*") + expect(cron.day).to eq("*") + expect(cron.month).to eq("*") + expect(cron.weekday).to eq("*") + expect(cron.time).to eq(nil) + expect(cron.property_is_set?(:command)).to eq(false) + end + end end describe "cron_different?" do @@ -691,6 +712,30 @@ describe Chef::Provider::Cron do end end + context "when there is a crontab with a matching section with a commented crontab line in it" do + before :each do + @provider.cron_exists = true + end + + it "should add the crontab to the entry" do + allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB) + 0 2 * * * /some/other/command + + # Chef Name: cronhole some stuff + # * * * * * /bin/true + CRONTAB + expect(@provider).to receive(:write_crontab).with(<<~ENDCRON) + 0 2 * * * /some/other/command + + # Chef Name: cronhole some stuff + * * * * * /bin/true + # * * * * * /bin/true + ENDCRON + @new_resource.minute "*" + @provider.run_action(:create) + end + end + context "when there is a crontab with a matching and identical section" do context "when environment variable is not used" do before :each do |