mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-15 19:22:46 -06:00
bdcac8792d
Previously we were using the type name requested in the import to select the schema, but a provider is free to return additional objects of other types as part of an import result, and so it's important that we perform schema selection separately for each returned object. If we don't do this, we get confusing downstream errors where the resulting object decodes to the wrong type and breaks various invariants expected by Terraform Core. The testResourceImportOther test in the test provider didn't catch this previously because it happened to have an identical schema to the other resource type being imported. Now the schema is changed and also there's a computed attribute we can set as part of the refresh phase to make sure we're completing the Read call properly during import. Refresh was working correctly, but we didn't have any tests for it as part of the import flow.
75 lines
1.7 KiB
Go
75 lines
1.7 KiB
Go
package test
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
)
|
|
|
|
func testResourceImportOther() *schema.Resource {
|
|
return &schema.Resource{
|
|
Create: testResourceImportOtherCreate,
|
|
Read: testResourceImportOtherRead,
|
|
Delete: testResourceImportOtherDelete,
|
|
Update: testResourceImportOtherUpdate,
|
|
|
|
Importer: &schema.ResourceImporter{
|
|
State: testResourceImportOtherImportState,
|
|
},
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
"default_string": {
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
Default: "default string",
|
|
},
|
|
"default_bool": {
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
Default: true,
|
|
},
|
|
"computed": {
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
},
|
|
}
|
|
}
|
|
|
|
func testResourceImportOtherImportState(d *schema.ResourceData, meta interface{}) ([]*schema.ResourceData, error) {
|
|
var results []*schema.ResourceData
|
|
|
|
results = append(results, d)
|
|
|
|
{
|
|
other := testResourceDefaults()
|
|
od := other.Data(nil)
|
|
od.SetType("test_resource_defaults")
|
|
od.SetId("import_other_other")
|
|
results = append(results, od)
|
|
}
|
|
|
|
return results, nil
|
|
}
|
|
|
|
func testResourceImportOtherCreate(d *schema.ResourceData, meta interface{}) error {
|
|
d.SetId("import_other_main")
|
|
return testResourceImportOtherRead(d, meta)
|
|
}
|
|
|
|
func testResourceImportOtherUpdate(d *schema.ResourceData, meta interface{}) error {
|
|
return testResourceImportOtherRead(d, meta)
|
|
}
|
|
|
|
func testResourceImportOtherRead(d *schema.ResourceData, meta interface{}) error {
|
|
err := d.Set("computed", "hello!")
|
|
if err != nil {
|
|
return fmt.Errorf("failed to set 'computed' attribute: %s", err)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func testResourceImportOtherDelete(d *schema.ResourceData, meta interface{}) error {
|
|
return nil
|
|
}
|