Skip to content
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] Cannot recreate resource #120

Open
1 task done
andrewbrine opened this issue Dec 4, 2024 · 2 comments
Open
1 task done

[bug] Cannot recreate resource #120

andrewbrine opened this issue Dec 4, 2024 · 2 comments
Assignees
Labels
bug Something isn't working

Comments

@andrewbrine
Copy link

andrewbrine commented Dec 4, 2024

🐛 What happened?

When changing a property of a resource that forces replacement instead of changing the resource, terraform apply does not execute successfully.
The following error is returned: Could not create resource: Requested 'ResourceName' is already in use.
There is then a 5 minute delay before the resource can be created again and all terraform apply executions within that time limit also fail.
This was encountered when changing the enable_schemas configuration option of the fabric_lakehouse resource.

🔬 How to reproduce?

  1. Create a Lakehouse in a workspace with configuration option enable_schemas set to true and then run terraform apply.
  2. Once this is deployed, changed the enable_schemas option to false and then run terraform apply again
  3. The following error is returned Could not create resource: Requested 'LakehouseName' is already in use
  4. The Lakehouse will not be able to be created for the next 5 minutes
  5. Once 5 minutes has passed the Lakehouse can be created again

🏗️ Code Sample / Log

Lakehouse resource:

resource "fabric_lakehouse" "terraform_lakehouse" { display_name = "terraformLH" workspace_id = fabric_workspace.terraform_workspace.id configuration = { enable_schemas = true } }

The enable_schemas configuration property is changed from true to false

Terraform Apply Output

The output of the terraform apply command before approval

fabric_lakehouse.terraform_lakehouse must be replaced
-/+ resource "fabric_lakehouse" "terraform_lakehouse" {
~ configuration = { # forces replacement
~ enable_schemas = false -> true # forces replacement
}
~ id = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxx" -> (known after apply)
~ properties = {
+ default_schema = (known after apply)
~ onelake_files_path = "https://onelake.dfs.fabric.microsoft.com/xxxxxxxxxxxxxxxx/xxxxxxxxxxxxxxx/Files" -> (known after apply)
~ onelake_tables_path = "https://onelake.dfs.fabric.microsoft.com/xxxxxxxxxxxxxxxxxxxxxxx/Tables" -> (known after apply)
~ sql_endpoint_properties = {
~ connection_string = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.datawarehouse.fabric.microsoft.com" -> (known after apply)
~ id = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxx" -> (known after apply)
~ provisioning_status = "Success" -> (known after apply)
} -> (known after apply)
} -> (known after apply)
# (3 unchanged attributes hidden)
}

Plan: 1 to add, 0 to change, 1 to destroy.

Error:

│ Error: create operation │ │ with fabric_lakehouse.terraform_lakehouse, │ on lakehouse.tf line 1, in resource "fabric_lakehouse" "terraform_lakehouse": │ 1: resource "fabric_lakehouse" "terraform_lakehouse" { │ │ Could not create resource: Requested 'terraformLH' is already in use

📷 Screenshots

No response

📈 Expected behavior

The resource can be deleted and then created in the same execution without error and without a time delay .

🌌 Environment (Provider Version)

0.1.0-beta.5

🌌 Environment (Terraform Version)

1.10.0

🌌 Environment (OS)

Linux

📎 Additional context

No response

🔰 Code of Conduct

  • I agree to follow this project's Code of Conduct.
@andrewbrine andrewbrine added the bug Something isn't working label Dec 4, 2024
@DariuszPorowski
Copy link
Member

DariuszPorowski commented Dec 6, 2024

Hi @andrewbrine Actually this is not a provider bug, but standard Fabric behavior itself. We don't have much room to maneuver to do anything on the Provider side. The workaround is only to wait and then create the item once again.

PTAL @Halamish51 @cisraeli @badeamarjieh and see if this is a bug in the Fabric API side.

@Lachlan-White
Copy link

@andrewbrine for our own safety and protection! Wish we would follow the same behaviours across Microsoft APIs so the experience for those working on multiple via Terraform is the same.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

4 participants