summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTim Smith <tsmith@chef.io>2017-12-11 10:00:43 -0800
committerGitHub <noreply@github.com>2017-12-11 10:00:43 -0800
commit50c50322f0d7270b98cf62133bb109860e9f2223 (patch)
tree5d08c68f684ef5b6ecbb09813b645b2f174c9b25
parent72aa31170d09af49405c259434e32e7b1ce7acfa (diff)
parent93cc046e9afad04f41133376e7ba07aee994784d (diff)
downloadchef-50c50322f0d7270b98cf62133bb109860e9f2223.tar.gz
Merge pull request #6618 from MsysTechnologiesllc/nim/on_logon_issue
Invalid date error on windows_task with frequency :on_logon
-rw-r--r--lib/chef/provider/windows_task.rb18
-rw-r--r--spec/unit/provider/windows_task_spec.rb16
2 files changed, 24 insertions, 10 deletions
diff --git a/lib/chef/provider/windows_task.rb b/lib/chef/provider/windows_task.rb
index 937d28cf4b..5228254308 100644
--- a/lib/chef/provider/windows_task.rb
+++ b/lib/chef/provider/windows_task.rb
@@ -81,18 +81,16 @@ class Chef
return
end
# Setting the attributes of new_resource as current_resource.
- # This is required to maintain idempotency when the user is not passing start_day and start_time
- # because SCHTASK.exe sets them by default as the current time and day.
- # So the current_resource will always have start_time and start_days set for an existing task,
- # even though the user didn't pass it. So we set the new_resource attributes as the current_resource attributes
+ # This is required to handle update scenarios when the user specifies
+ # only those attributes in the recipe which require update
resource_attributes.each do |attribute|
new_resource_attribute = new_resource.send(attribute)
current_resource_attribute = current_resource.send(attribute)
# We accept start_day in mm/dd/yyyy format only. Hence while copying the start_day from system to new_resource.start_day,
# we are converting from system date format to mm/dd/yyyy
- current_resource_attribute = convert_system_date_to_mm_dd_yyyy(current_resource_attribute) if attribute == "start_day"
+ current_resource_attribute = convert_system_date_to_mm_dd_yyyy(current_resource_attribute) if attribute == "start_day" && current_resource_attribute != "N/A"
# Convert start_time into 24hr time format
- current_resource_attribute = DateTime.parse(current_resource_attribute).strftime("%H:%M") if attribute == "start_time"
+ current_resource_attribute = DateTime.parse(current_resource_attribute).strftime("%H:%M") if attribute == "start_time" && current_resource_attribute != "N/A"
new_resource.send("#{attribute}=", current_resource_attribute ) if current_resource_attribute && new_resource_attribute.nil?
end
end
@@ -105,8 +103,8 @@ class Chef
options["SD"] = convert_user_date_to_system_date "12/12/2012"
else
options["SC"] = schedule
- options["ST"] = new_resource.start_time unless new_resource.start_time.nil?
- options["SD"] = convert_user_date_to_system_date new_resource.start_day unless new_resource.start_day.nil?
+ options["ST"] = new_resource.start_time unless new_resource.start_time.nil? || new_resource.start_time == "N/A"
+ options["SD"] = convert_user_date_to_system_date new_resource.start_day unless new_resource.start_day.nil? || new_resource.start_day == "N/A"
end
options["MO"] = new_resource.frequency_modifier if frequency_modifier_allowed
options["I"] = new_resource.idle_time unless new_resource.idle_time.nil?
@@ -227,8 +225,8 @@ class Chef
current_resource.idle_time != new_resource.idle_time ||
current_resource.random_delay != new_resource.random_delay ||
!new_resource.execution_time_limit.include?(current_resource.execution_time_limit) ||
- (new_resource.start_day && start_day_updated?) ||
- (new_resource.start_time && start_time_updated?)
+ (new_resource.start_day && new_resource.start_day != "N/A" && start_day_updated?) ||
+ (new_resource.start_time && new_resource.start_time != "N/A" && start_time_updated?)
begin
return true if new_resource.day.to_s.casecmp(current_resource.day.to_s) != 0 ||
new_resource.months.to_s.casecmp(current_resource.months.to_s) != 0
diff --git a/spec/unit/provider/windows_task_spec.rb b/spec/unit/provider/windows_task_spec.rb
index d45531f3dc..9a73f4f07f 100644
--- a/spec/unit/provider/windows_task_spec.rb
+++ b/spec/unit/provider/windows_task_spec.rb
@@ -137,6 +137,22 @@ describe Chef::Provider::WindowsTask do
expect(new_resource).to be_updated_by_last_action
end
+ context "when start_day and start_time are N/A for frequency :on_logon" do
+ it "doesn't update the start_day and start_time of new_resource" do
+ task_hash[:on_logon] = true
+ task_hash[:StartDate] = "N/A"
+ task_hash[:StartTime] = "N/A"
+ allow(provider).to receive(:load_task_hash).and_return(task_hash)
+ current_resource = provider.load_current_resource
+ allow(provider).to receive(:task_need_update?).and_return(true)
+ allow(provider).to receive(:run_schtasks)
+ expect(provider).not_to receive(:convert_system_date_to_mm_dd_yyyy)
+ expect(DateTime).not_to receive(:parse)
+ expect(new_resource.start_day).to eq(nil)
+ expect(new_resource.start_time).to eq(nil)
+ end
+ end
+
context "when task is not existing" do
before do
allow(provider).to receive(:load_task_hash)