You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
# Example of incident workflow triggerresource"pagerduty_incident_workflow_trigger""example_trigger" {
name="Example Workflow Trigger"conditions={...} # conditional logic for the triggerservices=[pagerduty_service.service_1.id, pagerduty_service.service_2.id, pagerduty_service.service_3.id]
workflow_id=pagerduty_incident_workflow.example_workflow.id# Had to add the below block to prevent this issuelifecycle {
ignore_changes=[services]
}
}
Expected Behavior
If no changes are made to the trigger, its associated incident workflow, or the list of services it monitors, the terraform plan or terraform apply should not detect any changes.
Actual Behavior
Every time terraform plan or terraform apply is run, it detects a change in the pagerduty_incident_workflow_trigger resource, even when there are no actual changes to the trigger, workflow, or services.
The detected change consistently shows the removal and re-addition of a service ID in the services list. For example:
This issue causes unnecessary updates in the plan, requiring approvals for applying the changes, even when no actual updates are required.
Steps to Reproduce
Create an incident_workflow_trigger resource in Terraform that includes a list of services.
Ensure no changes are made to the trigger, workflow, or services.
Run terraform plan or terraform apply.
Observe that the plan detects changes related to removing and re-adding a service ID in the services list.
Likely Cause
The provider does not maintain any consistent ordering or sorting for the services list in the incident_workflow_trigger resource. Terraform interprets this unordered behavior as a change in the list's structure, even though the content remains the same.
Temporary Workaround
To suppress these unnecessary changes, we have implemented the lifecycle -> ignore_changes meta-argument for the services attribute:
lifecycle {
ignore_changes=[services]
}
While this suppresses the false-positive changes in the plan, it is not an ideal solution. If there are legitimate updates to the services list, this workaround would ignore those changes, potentially causing the incident workflow and trigger to break.
Impact of the Issue
Unnecessary confusion during every terraform plan or terraform apply, as it always shows changes where none exist.
Version bump plans also detect this as a change, causing them to become full runs that require approval before applying, which disrupts efficient workflows.
Suppressing the changes using ignore_changes can lead to broken workflows if legitimate updates to the services list are overlooked.
Suggested Resolution
Ensure the services list or other lists in the incident_workflow_trigger resource is ordered or sorted consistently in the provider. This would prevent Terraform from detecting false changes and eliminate the need for the ignore_changes workaround, improving reliability and efficiency.
The text was updated successfully, but these errors were encountered:
Terraform Version
Terraform v1.10.4
PagerDuty Provider Version
v3.18.3
Affected Resource(s)
pagerduty_incident_workflow_trigger
Terraform Configuration Files
Expected Behavior
If no changes are made to the trigger, its associated incident workflow, or the list of services it monitors, the
terraform plan
orterraform apply
should not detect any changes.Actual Behavior
Every time
terraform plan
orterraform apply
is run, it detects a change in thepagerduty_incident_workflow_trigger
resource, even when there are no actual changes to the trigger, workflow, or services.The detected change consistently shows the removal and re-addition of a service ID in the
services
list. For example:This issue causes unnecessary updates in the plan, requiring approvals for applying the changes, even when no actual updates are required.
Steps to Reproduce
incident_workflow_trigger
resource in Terraform that includes a list of services.terraform plan
orterraform apply
.services
list.Likely Cause
The provider does not maintain any consistent ordering or sorting for the
services
list in theincident_workflow_trigger
resource. Terraform interprets this unordered behavior as a change in the list's structure, even though the content remains the same.Temporary Workaround
To suppress these unnecessary changes, we have implemented the
lifecycle
->ignore_changes
meta-argument for theservices
attribute:While this suppresses the false-positive changes in the plan, it is not an ideal solution. If there are legitimate updates to the
services
list, this workaround would ignore those changes, potentially causing the incident workflow and trigger to break.Impact of the Issue
terraform plan
orterraform apply
, as it always shows changes where none exist.ignore_changes
can lead to broken workflows if legitimate updates to theservices
list are overlooked.Suggested Resolution
Ensure the
services
list or other lists in theincident_workflow_trigger
resource is ordered or sorted consistently in the provider. This would prevent Terraform from detecting false changes and eliminate the need for theignore_changes
workaround, improving reliability and efficiency.The text was updated successfully, but these errors were encountered: