-
Notifications
You must be signed in to change notification settings - Fork 4.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
azurerm_automation_schedule - Add missing properties for the advanced schedule #1626
azurerm_automation_schedule - Add missing properties for the advanced schedule #1626
Conversation
…_schedule` resource
…e `azurerm_automation_schedule` resource
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
hey @TFaga
Thanks for this PR :)
I've taken a look through and left some comments in-line but this is off to a good start; if we can fix up the comments then we should be able to run the tests and get this merged :)
Thanks!
|
||
advancedSchedules, hasAdvancedSchedule := diff.GetOk("advanced_schedule") | ||
if hasAdvancedSchedule { | ||
if asl := advancedSchedules.([]interface{}); len(asl) > 0 && asl[0] != nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we can remove asl[0] != nil
since that'll always be true if len(asl) > 0
?
//only pay attention to the advanced schedule if frequency is either Week or Month | ||
if properties.Frequency == automation.Week || properties.Frequency == automation.Month { | ||
if v, ok := d.GetOk("advanced_schedule"); ok { | ||
if vl := v.([]interface{}); len(vl) > 0 && vl[0] != nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
same here - I think we can remove vl[0] != nil
since that's implied?
@@ -257,6 +336,9 @@ func resourceArmAutomationScheduleRead(d *schema.ResourceData, meta interface{}) | |||
if v := resp.TimeZone; v != nil { | |||
d.Set("timezone", v) | |||
} | |||
if v := resp.AdvancedSchedule; v != nil { | |||
d.Set("advanced_schedule", flattenArmAutomationScheduleAdvanced(v)) | |||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we ensure we set this all the time and move the nil-check within the flatten function? that ensures changes to this are detected. in addition - given this is a complex object can we check for errors when setting it? e.g.
if err := d.Set("advanced_schedule", flattenArmAutomationScheduleAdvanced(v)); err != nil {
return fmt.Errorf("Error setting `advanced_schedule`: %+v", err)
}
|
||
expandedAdvancedSchedule := automation.AdvancedSchedule{} | ||
|
||
if len(weekDays) > 0 { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we remove this if statement - since it means it's not possible to remove these values once they've been set.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've noticed an issue with this particular property. When creating the resource, if frequency is set to Month
the week_days
array cannot be set (even empty), otherwise the API returns an error. However during update it can and should be in order to reset it if it was removed from state. I've added a check for whether the current operation is a Create or Update and act accordingly. Perhaps separating the create and update methods would be a more clean solution?
expandedAdvancedSchedule.WeekDays = &expandedWeekDays | ||
} | ||
|
||
if len(monthDays) > 0 { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we remove this if statement - since it means it's not possible to remove these values once they've been set.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same as with weekDays
.
flattenedMonthlyOccurrences[i] = f | ||
} | ||
result["monthly_occurrence"] = flattenedMonthlyOccurrences | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
(as above)
return &expandedAdvancedSchedule, nil | ||
} | ||
|
||
func flattenArmAutomationScheduleAdvanced(v *automation.AdvancedSchedule) []interface{} { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
given we're now passing in a nil-value here, can we return an empty list e.g.
if v == nil {
return []interface{}{}
}
Type: schema.TypeString, | ||
Required: true, | ||
DiffSuppressFunc: suppress.CaseDifference, | ||
ValidateFunc: validateScheduleDay(), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we in-line this validation method for the moment? I have a feeling we may end up extracting out a listOfWeekDays
method in time
@@ -61,6 +65,22 @@ The following arguments are supported: | |||
|
|||
* `timezone` - (Optional) The timezone of the start time. Defaults to `UTC`. For possible values see: https://msdn.microsoft.com/en-us/library/ms912391(v=winembedded.11).aspx | |||
|
|||
* `advanced_schedule` - (Optional) Advanced fine-grained schedule frequency configuration. The `advanced_schedule` block supports fields documented below. | |||
|
|||
The `advanced_schedule` block supports: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
minor can we add ---
above this line (and then a blank line) to add a divider
|
||
* `monthly_occurrence` - (Optional) List of occurrences of days within a month. The `monthly_occurrence` block supports fields documented below. | ||
|
||
The `monthly_occurrence` block supports: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
(as above) can we add a divider here by adding ---
and then a new line?
…roperties of the `azurerm_automation_schedule` resource
Hey! Thanks for the quick response and check. I've went through the comments and made the appropriate changes to the code. I've however noticed one behavior that may be problematic. If you specify the frequency of the schedule as either {
"properties": {
"interval": 1,
"frequency": "Month",
"advancedSchedule": {
"monthDays": null,
"monthlyOccurrences": null,
"weekDays": null
}
}
} This means that it gets saved in the state as having one item in the Thanks! |
…n_schedule` in case of state change to remove
// If frequency is set to `Month` the `week_days` array cannot be set (even empty), otherwise the API returns an error. | ||
// During update it can be set and it will not return an error. Workaround for the APIs behavior | ||
if len(weekDays) > 0 || update { | ||
expandedWeekDays := make([]string, len(weekDays)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
so this second argument is the starting position in the array, if we make this 0
there's no empty element
|
||
// Same as above with `week_days` | ||
if len(monthDays) > 0 || update { | ||
expandedMonthDays := make([]int32, len(monthDays)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
so this second argument is the starting position in the array, if we make this 0
there's no empty element
@TFaga hey, thanks for pushing those changes. Regarding the empty element that's present since the array creation (e.g. the |
…te of the `azurerm_automation_schedule` resource
@tombuildsstuff Hey, thanks for the quick response and info. I'm not sure I understand though, or rather I think I didn't phrase it very well. The problem that arises is that the schedule client/API is inconsistent with what properties of the advance schedule it deems valid on input. When creating a new resource and for instance setting the To clarify with API examples. This will error: {
"properties": {
"frequency": "Month",
"advancedSchedule": {
"monthDays": [2],
"monthlyOccurrences": [],
"weekDays": [] // <- this
}
}
} While this will succeed: {
"properties": {
"frequency": "Month",
"advancedSchedule": {
"monthDays": [2],
"monthlyOccurrences": [],
"weekDays": null // <- this
}
}
} Only on create, however. On update the first example will work without issue. I've pushed a commit addressing the same problem if the whole |
Hi @TFaga, You can always add a Additionally, might i suggest pulling What do you think @tombuildsstuff ? |
|
||
* `week_days` - (Optional) List of days of the week that the job should execute on. | ||
|
||
* `month_days` - (Optional) List of days of the month that the job should execute on. Must be between 1 and 31. 0 for last day of the month. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
0 [](start = 112, length = 1)
minor can we quote the numbers in backtick such that " Must be between 1
and 31
".
question are you sure 0
represents the last day of the month, or -1
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's indeed -1
. Thank you for the correction.
|
||
* `day` - (Required) Day of the occurrence. Must be one of Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday. | ||
|
||
* `occurrence` - (Required) Occurrence of the week within the month. Must be between 1 and 5. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
question tried with the Azure Rest API site, I also see -1
is available here (e.g. "Monday" -1
means the last Monday of a month). Can you confirm whether it is supported or not?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's supported. Confirmed and added.
@@ -338,3 +405,113 @@ func checkAccAzureRMAutomationSchedule_recurring_basic(resourceName string, freq | |||
resource.TestCheckResourceAttr(resourceName, "timezone", "UTC"), | |||
) | |||
} | |||
|
|||
func testAccAzureRMAutomationSchedule_recurring_advanced_week(rInt int, location, frequency string, interval int, weekDay string) string { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
interval int [](start = 100, length = 12)
suggestion The only possible value used in your test cases is 1
, so you may hardcode the 1
in the HCL below and remove this parameter. Similar two suggestions below.
@@ -107,14 +108,94 @@ func resourceArmAutomationSchedule() *schema.Resource { | |||
//todo figure out how to validate this properly | |||
}, | |||
|
|||
//todo missing properties: week_days, month_days, month_week_day from advanced automation section | |||
"advanced_schedule": { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"advanced_schedule" [](start = 3, length = 19)
suggestion We don't need to introduce wrapper advanced_schedule
object here. What I mean is to move the mutual exclusive objects week_days
, month_days
and monthly_occurrence
to the top level so we can reduce the depth of the hierarchy.
MaxItems: 1, | ||
Elem: &schema.Resource{ | ||
Schema: map[string]*schema.Schema{ | ||
"week_days": { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"week_days" [](start = 6, length = 11)
Since week_days
, month_days
and monthly_occurrence
are mutually exclusive, why not declare ConflictsWith
attribute in these three objects?
"occurrence": { | ||
Type: schema.TypeInt, | ||
Required: true, | ||
ValidateFunc: validation.IntBetween(1, 5), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
validation.IntBetween(1, 5) [](start = 24, length = 27)
Can you confirm whether Go SDK supports -1
or not?
if strings.ToLower(diff.Get("frequency").(string)) == "onetime" && interval.(int) > 0 { | ||
return fmt.Errorf("interval canot be set when frequency is not OneTime") | ||
if frequency == "onetime" && interval.(int) > 0 { | ||
return fmt.Errorf("`interval` cannot be set when frequency is not OneTime") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"
interval
cannot be set when frequency is not OneTime" [](start = 22, length = 56)
interval
cannot be set when frequency is not OneTime
.
Hi @TFaga , thanks for the contribution. I have looked through your code and provided some comments. Feel free to ask if some of them confused your. |
…to reduce depth of the `azurerm_automation_schedule` resource
Hi @JunyiYi . Thanks for the review. I've made the changes in the comments. I've moved the props one level up as was suggested. I agree it makes more sense, I wasn't sure whether to deviate from the SDK/API design. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi @TFaga,
Thank you for the changes, most of my comments are minor improvements outside of the documentation. Look forward to getting this merged for you once these last few changes are made!
Set: set.HashStringIgnoreCase, | ||
ConflictsWith: []string{"month_days", "monthly_occurrence"}, | ||
}, | ||
"month_days": { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we get an empty line here to make the spacing consistent?
|
||
func flattenArmAutomationScheduleAdvancedWeekDays(v *automation.AdvancedSchedule) *schema.Set { | ||
flattenedWeekDays := schema.NewSet(set.HashStringIgnoreCase, []interface{}{}) | ||
if v.WeekDays != nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe this could be written as:
if weekDays := v.WeekDays; weekdays != nil {
for i, v := range *weekDays {
flattenedWeekDays.Add(v)
}
}
|
||
func flattenArmAutomationScheduleAdvancedMonthDays(v *automation.AdvancedSchedule) *schema.Set { | ||
flattenedMonthDays := schema.NewSet(set.HashInt, []interface{}{}) | ||
if v.MonthDays != nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The same as above, could definitely be simplified.
func flattenArmAutomationScheduleAdvancedMonthlyOccurrences(v *automation.AdvancedSchedule) []map[string]interface{} { | ||
flattenedMonthlyOccurrences := make([]map[string]interface{}, 0) | ||
if v.MonthlyOccurrences != nil { | ||
for i := range *v.MonthlyOccurrences { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Again, could use the syntax: for _, v := range monthlyOccurrences {
and not have to deref and index so much.
%s | ||
|
||
resource "azurerm_automation_schedule" "test" { | ||
name = "acctestAS-%d" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we make sure the =s are aligned here?
%s | ||
|
||
resource "azurerm_automation_schedule" "test" { | ||
name = "acctestAS-%d" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we make sure the =s are aligned here?
%s | ||
|
||
resource "azurerm_automation_schedule" "test" { | ||
name = "acctestAS-%d" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we make sure the =s are aligned here?
@@ -61,6 +65,20 @@ The following arguments are supported: | |||
|
|||
* `timezone` - (Optional) The timezone of the start time. Defaults to `UTC`. For possible values see: https://msdn.microsoft.com/en-us/library/ms912391(v=winembedded.11).aspx | |||
|
|||
* `week_days` - (Optional) List of days of the week that the job should execute on. Only valid for `Week`. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we be a bit clearer by phrasing Only valid for 'Week'
as Only valid when frequency is 'Week'
? Applies to the new two properties to
|
||
The `monthly_occurrence` block supports: | ||
|
||
* `day` - (Required) Day of the occurrence. Must be one of Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we quote these values as such: Monday
… the `azurerm_automation_schedule` resource
Hi @katbyte Thanks for the quick review. I've made and pushed the changes in the comments. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi @TFaga,
Thank you for the changes! this LGTM now 👍
I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues. If you feel this issue should be reopened, we encourage creating a new issue linking back to this one for added context. If you feel I made an error 🤖 🙉 , please reach out to my human friends 👉 hashibot-feedback@hashicorp.com. Thanks! |
This pull request adds the missing properties in the
azurerm_automation_schedule
resource to configure the advanced schedule. Addresses issue #1392