Skip to content

Commit

Permalink
Fix identity refresh tests
Browse files Browse the repository at this point in the history
  • Loading branch information
dbanck committed Mar 5, 2025
1 parent 61bcbba commit ad27f6e
Show file tree
Hide file tree
Showing 2 changed files with 65 additions and 32 deletions.
85 changes: 54 additions & 31 deletions internal/terraform/context_plan_identity_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -216,6 +216,29 @@ func TestContext2Plan_resource_identity_refresh(t *testing.T) {
t.Run(name, func(t *testing.T) {
p := testProvider("aws")
m := testModule(t, "refresh-basic")
p.GetProviderSchemaResponse = getProviderSchemaResponseFromProviderSchema(&providerSchema{
ResourceTypes: map[string]*configschema.Block{
"aws_instance": {
Attributes: map[string]*configschema.Attribute{
"id": {
Type: cty.String,
Computed: true,
},
"foo": {
Type: cty.String,
Optional: true,
Computed: true,
},
},
},
},
IdentityTypes: map[string]*configschema.Object{
"aws_instance": tc.IdentitySchema.Body,
},
IdentityTypeSchemaVersions: map[string]uint64{
"aws_instance": uint64(tc.IdentitySchema.Version),
},
})

state := states.NewState()
root := state.EnsureModule(addrs.RootModuleInstance)
Expand Down Expand Up @@ -244,12 +267,6 @@ func TestContext2Plan_resource_identity_refresh(t *testing.T) {
t.Fatal(err)
}

p.GetResourceIdentitySchemasResponse = &providers.GetResourceIdentitySchemasResponse{
IdentityTypes: map[string]providers.IdentitySchema{
"aws_instance": tc.IdentitySchema,
},
}
schema.Identity = p.GetResourceIdentitySchemasResponse.IdentityTypes["aws_instance"].Body
p.ReadResourceResponse = &providers.ReadResourceResponse{
NewState: readState,
Identity: tc.IdentityData,
Expand Down Expand Up @@ -279,10 +296,6 @@ func TestContext2Plan_resource_identity_refresh(t *testing.T) {
t.Fatal("ReadResource should be called")
}

if !p.GetResourceIdentitySchemasCalled {
t.Fatal("GetResourceIdentitySchemas should be called")
}

if tc.ExpectUpgradeResourceIdentityCalled && !p.UpgradeResourceIdentityCalled {
t.Fatal("UpgradeResourceIdentity should be called")
}
Expand Down Expand Up @@ -314,6 +327,37 @@ func TestContext2Plan_resource_identity_refresh(t *testing.T) {
func TestContext2Plan_resource_identity_refresh_destroy_deposed(t *testing.T) {
p := testProvider("aws")
m := testModule(t, "refresh-basic")
p.GetProviderSchemaResponse = getProviderSchemaResponseFromProviderSchema(&providerSchema{
ResourceTypes: map[string]*configschema.Block{
"aws_instance": {
Attributes: map[string]*configschema.Attribute{
"id": {
Type: cty.String,
Computed: true,
},
"foo": {
Type: cty.String,
Optional: true,
Computed: true,
},
},
},
},
IdentityTypes: map[string]*configschema.Object{
"aws_instance": {
Attributes: map[string]*configschema.Attribute{
"id": {
Type: cty.String,
Required: true,
},
},
Nesting: configschema.NestingSingle,
},
},
IdentityTypeSchemaVersions: map[string]uint64{
"aws_instance": 0,
},
})

state := states.NewState()
root := state.EnsureModule(addrs.RootModuleInstance)
Expand Down Expand Up @@ -342,23 +386,6 @@ func TestContext2Plan_resource_identity_refresh_destroy_deposed(t *testing.T) {
t.Fatal(err)
}

p.GetResourceIdentitySchemasResponse = &providers.GetResourceIdentitySchemasResponse{
IdentityTypes: map[string]providers.IdentitySchema{
"aws_instance": {
Version: 0,
Body: &configschema.Object{
Attributes: map[string]*configschema.Attribute{
"id": {
Type: cty.String,
Required: true,
},
},
Nesting: configschema.NestingSingle,
},
},
},
}
schema.Identity = p.GetResourceIdentitySchemasResponse.IdentityTypes["aws_instance"].Body
p.ReadResourceResponse = &providers.ReadResourceResponse{
NewState: readState,
Identity: cty.ObjectVal(map[string]cty.Value{
Expand All @@ -376,10 +403,6 @@ func TestContext2Plan_resource_identity_refresh_destroy_deposed(t *testing.T) {
t.Fatal("ReadResource should be called")
}

if !p.GetResourceIdentitySchemasCalled {
t.Fatal("GetResourceIdentitySchemas should be called")
}

mod := s.PriorState.RootModule()
fromState, err := mod.Resources["aws_instance.web"].Instances[addrs.NoKey].Deposed[deposedKey].Decode(schema)
if err != nil {
Expand Down
12 changes: 11 additions & 1 deletion internal/terraform/resource_provider_mock_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,8 @@ type providerSchema struct {
ResourceTypes map[string]*configschema.Block
ResourceTypeSchemaVersions map[string]uint64
DataSources map[string]*configschema.Block
IdentityTypes map[string]*configschema.Object
IdentityTypeSchemaVersions map[string]uint64
}

// getProviderSchemaResponseFromProviderSchema is a test helper to convert a
Expand All @@ -137,10 +139,18 @@ func getProviderSchemaResponseFromProviderSchema(providerSchema *providerSchema)
}

for name, schema := range providerSchema.ResourceTypes {
resp.ResourceTypes[name] = providers.Schema{
ps := providers.Schema{
Body: schema,
Version: int64(providerSchema.ResourceTypeSchemaVersions[name]),
}

id, ok := providerSchema.IdentityTypes[name]
if ok {
ps.Identity = id
ps.IdentityVersion = int64(providerSchema.IdentityTypeSchemaVersions[name])
}

resp.ResourceTypes[name] = ps
}

for name, schema := range providerSchema.DataSources {
Expand Down

0 comments on commit ad27f6e

Please sign in to comment.