Skip to content

Commit

Permalink
regression: azuread_application - don't populate the password blo…
Browse files Browse the repository at this point in the history
…ck unless specified in config, to avoid marking attributes as sensitive if the entire resource is used for an output variable
  • Loading branch information
manicminer committed Jun 28, 2024
1 parent 1ad927e commit 306d4b1
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 8 deletions.
16 changes: 8 additions & 8 deletions internal/services/applications/application_resource.go
Original file line number Diff line number Diff line change
Expand Up @@ -1626,15 +1626,15 @@ func applicationResourceRead(ctx context.Context, d *pluginsdk.ResourceData, met
if len(currentPassword) == 1 {
keyIdToMatch = currentPassword[0].(map[string]interface{})["key_id"].(string)
existingValue = currentPassword[0].(map[string]interface{})["value"].(string)
}

for _, credential := range flattenApplicationPasswordCredentials(app.PasswordCredentials) {
// Match against the known key ID, or select the first returned password if not present in state
if keyIdToMatch == "" || credential["key_id"] == keyIdToMatch {
// Retain the value from state, if known
credential["value"] = existingValue
passwordToSave = append(passwordToSave, credential)
break
for _, credential := range flattenApplicationPasswordCredentials(app.PasswordCredentials) {
// Match against the known key ID, or select the first returned password if not present in state
if credential["key_id"] == keyIdToMatch {
// Retain the value from state, if known
credential["value"] = existingValue
passwordToSave = append(passwordToSave, credential)
break
}
}
}

Expand Down
22 changes: 22 additions & 0 deletions internal/services/applications/application_resource_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -651,6 +651,28 @@ func TestAccApplication_passwordUpdate(t *testing.T) {
})
}

func TestAccApplication_passwordNotSet(t *testing.T) {
data := acceptance.BuildTestData(t, "azuread_application", "test")
r := ApplicationResource{}

data.ResourceTest(t, r, []acceptance.TestStep{
{
Config: ApplicationPasswordResource{}.basic(data),
Check: acceptance.ComposeTestCheckFunc(
check.That(data.ResourceName).ExistsInAzure(r),
),
},
{
RefreshState: true,
ExpectNonEmptyPlan: true,
Check: acceptance.ComposeTestCheckFunc(
check.That(data.ResourceName).ExistsInAzure(r),
check.That(data.ResourceName).Key("password.#").HasValue("0"),
),
},
})
}

func (r ApplicationResource) Exists(ctx context.Context, clients *clients.Client, state *terraform.InstanceState) (*bool, error) {
client := clients.Applications.ApplicationsClientBeta
client.BaseClient.DisableRetries = true
Expand Down

0 comments on commit 306d4b1

Please sign in to comment.