Removing azapi_resource
How do you safely remove an azapi_resource block and switch to a native resource without creating issues with your Terraform state?
Introduction
Date | Description |
---|---|
2021-04-29 | Azure Web PubSub in Public Preview |
2021-08-02 | Developers start testing the preview functionality |
2021-11-16 | Azure Web PubSub goes GA |
2021-12-06 | Developers ask to include Web PubSub in the Terraform config |
2022-01-28 | azurerm v2.94: new resource azurerm_web_pubsub |
2022-02-07 | Switch to native support for the resource |
With v2.94, the azurerm provider has caught up a little and has its first version of the resources and data sources for the Azure Web PubSub Service. https://registry.terraform.io/providers/hashicorp/azurerm/2.94.0/docs/resources/web_pubsub
Time to switch to the native resource and clean up our temporary azapi_resource.
Starting configuration
Your main.tf file should be similar to this:
terraform {
required_providers {
azurerm = {
source = "hashicorp/azurerm"
version = "=2.93"
}
azapi = {
source = "azure/azapi"
version = "=0.3.0"
}
}
}
provider "azurerm" {
features {}
}
provider "azapi" {}
resource "azurerm_resource_group" "azapi_labs" {
name = "azapi_labs"
location = "West Europe"
}
resource "azapi_resource" "webpubsub" {
type = "Microsoft.SignalRService/WebPubSub@2021-10-01"
name = "azapi-labs-richeney"
parent_id = azurerm_resource_group.azapi_labs.id
location = azurerm_resource_group.azapi_labs.location
body = jsonencode({
sku = {
name = "Free_F1"
capacity = 1
}
})
}
⚠️ You should have a different value for your azapi_resource.webpubsub.name.
Update the main.tf
-
Update the required azurerm version
Update to v2.94:
terraform { required_providers { azurerm = { source = "hashicorp/azurerm" version = "=2.94" } azapi = { source = "azure/azapi" version = "=0.3.0" } } }
-
Add the azurerm_web_pubsub resource
Add the block for the native resource.
resource "azurerm_web_pubsub" "webpubsub" { name = "azapi-labs-richeney" resource_group_name = azurerm_resource_group.azapi_labs.name location = azurerm_resource_group.azapi_labs.location sku = "Free_F1" capacity = 1 }
⚠️ Remember to change the name to match your existing Azure Web PubSub resource.
Upgrade the provider
Terraform does not automatically update versions.
Running terraform validate
with the current v2.93 provider will display an error message saying that The provider hashicorp/azurerm does not support resource type "azurerm_web_pubsub".
.
Running terraform init
with no arguments will display an error including locked provider registry.terraform.io/hashicorp/azurerm 2.93.0 does not match configured version constraint 2.94.0
.
-
Initialise
Use the
-upgrade
switch.terraform init -upgrade
Terraform will install azurerm v2.94.
Import the resource
Running terraform plan
will show that it will create the azurerm_web_pubsub.webpubsub
resource.
Running terraform apply
will fail as the resource exists.
-
Get the resource ID
id=$(az webpubsub list --resource-group azapi_labs --query [].id --output tsv)
-
Import the resource
terraform import azurerm_web_pubsub.webpubsub $id
The resource will be imported into state. Running
terraform plan
at this point will show that Terraform has a clean diff. -
List the identifiers
terraform state list
Expected output:
azapi_resource.webpubsub azurerm_resource_group.azapi_labs azurerm_web_pubsub.webpubsub
Remove the azapi_resource
-
Remove the azapi_resource block from main.tf
-
Remove from the state file
terraform state rm azapi_resource.webpubsub
-
List the identifiers
terraform state list
Expected output:
azurerm_resource_group.azapi_labs azurerm_web_pubsub.webpubsub
Sure enough, the azapi_resource has been cleared up. We are fully azurerm native.
Running terraform plan
will confirm that there are no planned changes.
Summary
You have successfully switched from an azapi_resource:
- upgraded the provider
- added the native resource
- imported the resource into state
- cleaned up the config
- removed the azapi_resource from state
In the next lab you will use azapi_update_resource.
Help us improve
Azure Citadel is a community site built on GitHub, please contribute and send a pull request
Make a change