-
Notifications
You must be signed in to change notification settings - Fork 75
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
[Bug]: Firewall rules DELETED when name or labels in hcloud_firewall resource are changed #931
Comments
Hey @borisceranic, looks like this bug was introduced in #874, first released in 1.46.0. This only happens if you omit the resource "hcloud_firewall" "test" {
name = "firewall_1"
apply_to {
label_selector = "test/label-1"
}
rule {
description = "allow all traffic from particular IPs"
direction = "in"
protocol = "tcp"
port = "1-65535"
source_ips = [
"1.2.3.4/32",
"1.3.4.5/32",
]
}
} We will take a look at this. |
This is reproducable with this e2e test: func TestFirewallResource_Regression931(t *testing.T) {
var f hcloud.Firewall
res := firewall.NewRData(t, "update-keep-rules", []firewall.RDataRule{
{
Direction: "in",
Protocol: "tcp",
SourceIPs: []string{"192.0.2.250"},
Port: "80",
Description: "allow http in",
},
}, nil)
updated := &firewall.RData{
Name: "update-keep-rules-changed",
Rules: res.Rules,
ApplyTo: res.ApplyTo,
Labels: res.Labels,
}
updated.SetRName(res.RName())
tmplMan := testtemplate.Manager{}
resource.Test(t, resource.TestCase{
PreCheck: teste2e.PreCheck(t),
ProtoV6ProviderFactories: teste2e.ProtoV6ProviderFactories(),
CheckDestroy: testsupport.CheckResourcesDestroyed(firewall.ResourceType, firewall.ByID(t, &f)),
Steps: []resource.TestStep{
{
Config: tmplMan.Render(t, "testdata/r/hcloud_firewall", res),
Check: testsupport.CheckResourceExists(res.TFID(), firewall.ByID(t, &f)),
},
{
// Update something other than the rules
Config: tmplMan.Render(t, "testdata/r/hcloud_firewall", updated),
},
},
})
} |
Hey @apricote ,
Thanks, that's a viable workaround, I'll implement it as a stop-gap solution to prevent possible issues, until the provider is fixed. By the way: are you saying that if I stick with the provider 1.45.0 or older (for the time being) that the issue would not happen? |
In theory yes, but before 1.46.0 you got an error if you specified the IP directly without |
Looks like we are running into the same bug as described here: #468 |
This issue has been marked as stale because it has not had recent activity. The bot will close the issue if no further action occurs. |
What happened?
While working with
hcloud_firewall
resource, I noticed that ALL RULES are silently deleted by Terraformhcloud
provider when Terraform wants to update the firewall in-place in cases when any argument (other thanrule
) changes.Consider this example:
Terraform creates the resource, and it appears Just Fine (tm) in the Hetzner Cloud Console:
Then, if I update only
name
argument, Terraform plan shows something that appears perfectly normal and expected:Similarly, here's a perfectly normal-looking plan output when changing
apply_to.label_selector
argument:Meanwhile, looking at the Cloud Console, the end result is actually a removal of ALL RULES:
The following re-run of
terraform plan
will first refresh all resources, it will pick up the missing rules, and then it will helpfully offer to re-create them on the nextapply
:What did you expect to happen?
When changing
name
,labels
andapply_to
arguments, I expected rules specified via therule {}
block to remain set in the firewall.Please provide a minimal working example
The text was updated successfully, but these errors were encountered: