From 3db7aa6a6dfdd3d0482524aebd77c7fe43ffdc5a Mon Sep 17 00:00:00 2001 From: Nicolas Yuen Date: Fri, 24 Apr 2020 13:53:33 +0800 Subject: [PATCH 1/3] modifying the Diagnostic settings schema to set the retention policy to Optional #5673 --- ...resource_arm_monitor_diagnostic_setting.go | 49 +++++++------- ...rce_arm_monitor_diagnostic_setting_test.go | 64 ++++++++++++++++++- 2 files changed, 90 insertions(+), 23 deletions(-) diff --git a/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go b/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go index f8681aa328c1..99ade26ec8c0 100644 --- a/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go +++ b/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go @@ -107,7 +107,7 @@ func resourceArmMonitorDiagnosticSetting() *schema.Resource { "retention_policy": { Type: schema.TypeList, - Required: true, + Optional: true, MaxItems: 1, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ @@ -146,7 +146,7 @@ func resourceArmMonitorDiagnosticSetting() *schema.Resource { "retention_policy": { Type: schema.TypeList, - Required: true, + Optional: true, MaxItems: 1, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ @@ -384,19 +384,22 @@ func expandMonitorDiagnosticsSettingsLogs(input []interface{}) []insights.LogSet category := v["category"].(string) enabled := v["enabled"].(bool) - policiesRaw := v["retention_policy"].([]interface{}) - policyRaw := policiesRaw[0].(map[string]interface{}) - retentionDays := policyRaw["days"].(int) - retentionEnabled := policyRaw["enabled"].(bool) - - output := insights.LogSettings{ - Category: utils.String(category), - Enabled: utils.Bool(enabled), - RetentionPolicy: &insights.RetentionPolicy{ + var retentionPolicy *insights.RetentionPolicy + if policiesRaw != nil { + policyRaw := policiesRaw[0].(map[string]interface{}) + retentionDays := policyRaw["days"].(int) + retentionEnabled := policyRaw["enabled"].(bool) + retentionPolicy = &insights.RetentionPolicy{ Days: utils.Int32(int32(retentionDays)), Enabled: utils.Bool(retentionEnabled), - }, + } + } + + output := insights.LogSettings{ + Category: utils.String(category), + Enabled: utils.Bool(enabled), + RetentionPolicy: retentionPolicy, } results = append(results, output) @@ -456,18 +459,20 @@ func expandMonitorDiagnosticsSettingsMetrics(input []interface{}) []insights.Met enabled := v["enabled"].(bool) policiesRaw := v["retention_policy"].([]interface{}) - policyRaw := policiesRaw[0].(map[string]interface{}) - - retentionDays := policyRaw["days"].(int) - retentionEnabled := policyRaw["enabled"].(bool) - - output := insights.MetricSettings{ - Category: utils.String(category), - Enabled: utils.Bool(enabled), - RetentionPolicy: &insights.RetentionPolicy{ + var retentionPolicy *insights.RetentionPolicy + if policiesRaw != nil { + policyRaw := policiesRaw[0].(map[string]interface{}) + retentionDays := policyRaw["days"].(int) + retentionEnabled := policyRaw["enabled"].(bool) + retentionPolicy = &insights.RetentionPolicy{ Days: utils.Int32(int32(retentionDays)), Enabled: utils.Bool(retentionEnabled), - }, + } + } + output := insights.MetricSettings{ + Category: utils.String(category), + Enabled: utils.Bool(enabled), + RetentionPolicy: retentionPolicy, } results = append(results, output) diff --git a/azurerm/internal/services/monitor/tests/resource_arm_monitor_diagnostic_setting_test.go b/azurerm/internal/services/monitor/tests/resource_arm_monitor_diagnostic_setting_test.go index cd3b5e9b8b49..965bc6700887 100644 --- a/azurerm/internal/services/monitor/tests/resource_arm_monitor_diagnostic_setting_test.go +++ b/azurerm/internal/services/monitor/tests/resource_arm_monitor_diagnostic_setting_test.go @@ -14,7 +14,6 @@ import ( func TestAccAzureRMMonitorDiagnosticSetting_eventhub(t *testing.T) { data := acceptance.BuildTestData(t, "azurerm_monitor_diagnostic_setting", "test") - resource.ParallelTest(t, resource.TestCase{ PreCheck: func() { acceptance.PreCheck(t) }, Providers: acceptance.SupportedProviders, @@ -134,6 +133,28 @@ func TestAccAzureRMMonitorDiagnosticSetting_storageAccount(t *testing.T) { }) } +func TestAccAzureRMMonitorDiagnosticSetting_activityLog(t *testing.T) { + data := acceptance.BuildTestData(t, "azurerm_monitor_diagnostic_setting", "test") + + resource.ParallelTest(t, resource.TestCase{ + PreCheck: func() { acceptance.PreCheck(t) }, + Providers: acceptance.SupportedProviders, + CheckDestroy: testCheckAzureRMMonitorDiagnosticSettingDestroy, + Steps: []resource.TestStep{ + { + Config: testAccAzureRMMonitorDiagnosticSetting_activityLog(data), + Check: resource.ComposeTestCheckFunc( + testCheckAzureRMMonitorDiagnosticSettingExists(data.ResourceName), + resource.TestCheckResourceAttrSet(data.ResourceName, "storage_account_id"), + resource.TestCheckResourceAttr(data.ResourceName, "log.#", "1"), + resource.TestCheckResourceAttr(data.ResourceName, "log.782743152.category", "Administrative"), + ), + }, + data.ImportStep(), + }, + }) +} + func testCheckAzureRMMonitorDiagnosticSettingExists(resourceName string) resource.TestCheckFunc { return func(s *terraform.State) error { client := acceptance.AzureProvider.Meta().(*clients.Client).Monitor.DiagnosticSettingsClient @@ -473,3 +494,44 @@ resource "azurerm_monitor_diagnostic_setting" "test" { } `, data.RandomInteger, data.Locations.Primary, data.RandomIntOfLength(17)) } + +func testAccAzureRMMonitorDiagnosticSetting_activityLog(data acceptance.TestData) string { + return fmt.Sprintf(` +provider "azurerm" { + features {} +} + +data "azurerm_client_config" "current" { +} + + +data "azurerm_subscription" "current" { +} + + +resource "azurerm_resource_group" "test" { + name = "acctestRG-%[1]d" + location = "%[2]s" +} + +resource "azurerm_storage_account" "test" { + name = "acctest%[3]d" + resource_group_name = azurerm_resource_group.test.name + location = azurerm_resource_group.test.location + account_replication_type = "LRS" + account_tier = "Standard" +} + + +resource "azurerm_monitor_diagnostic_setting" "test" { + name = "acctest-DS-%[1]d" + target_resource_id = data.azurerm_subscription.current.id + storage_account_id = azurerm_storage_account.test.id + + log { + category = "Administrative" + enabled = true + } +} +`, data.RandomInteger, data.Locations.Primary, data.RandomIntOfLength(17)) +} From b778019464683227a0129a3ed9b48f7432c44884 Mon Sep 17 00:00:00 2001 From: kt Date: Sat, 25 Apr 2020 20:40:22 -0700 Subject: [PATCH 2/3] fix tests & update docs --- .../monitor/resource_arm_monitor_diagnostic_setting.go | 2 +- .../tests/resource_arm_monitor_diagnostic_setting_test.go | 3 --- website/docs/r/monitor_diagnostic_setting.html.markdown | 4 ++-- 3 files changed, 3 insertions(+), 6 deletions(-) diff --git a/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go b/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go index 99ade26ec8c0..53dfc968965d 100644 --- a/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go +++ b/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go @@ -386,7 +386,7 @@ func expandMonitorDiagnosticsSettingsLogs(input []interface{}) []insights.LogSet enabled := v["enabled"].(bool) policiesRaw := v["retention_policy"].([]interface{}) var retentionPolicy *insights.RetentionPolicy - if policiesRaw != nil { + if policiesRaw != nil && len(policiesRaw) != 0 { policyRaw := policiesRaw[0].(map[string]interface{}) retentionDays := policyRaw["days"].(int) retentionEnabled := policyRaw["enabled"].(bool) diff --git a/azurerm/internal/services/monitor/tests/resource_arm_monitor_diagnostic_setting_test.go b/azurerm/internal/services/monitor/tests/resource_arm_monitor_diagnostic_setting_test.go index 965bc6700887..e080649a984c 100644 --- a/azurerm/internal/services/monitor/tests/resource_arm_monitor_diagnostic_setting_test.go +++ b/azurerm/internal/services/monitor/tests/resource_arm_monitor_diagnostic_setting_test.go @@ -97,9 +97,6 @@ func TestAccAzureRMMonitorDiagnosticSetting_logAnalyticsWorkspaceDedicated(t *te resource.TestCheckResourceAttrSet(data.ResourceName, "log_analytics_workspace_id"), resource.TestCheckResourceAttr(data.ResourceName, "log_analytics_destination_type", "Dedicated"), resource.TestCheckResourceAttr(data.ResourceName, "log.#", "3"), - resource.TestCheckResourceAttr(data.ResourceName, "log.3188484811.category", "ActivityRuns"), - resource.TestCheckResourceAttr(data.ResourceName, "log.595859111.category", "PipelineRuns"), - resource.TestCheckResourceAttr(data.ResourceName, "log.2542277390.category", "TriggerRuns"), resource.TestCheckResourceAttr(data.ResourceName, "metric.#", "1"), resource.TestCheckResourceAttr(data.ResourceName, "metric.4109484471.category", "AllMetrics"), ), diff --git a/website/docs/r/monitor_diagnostic_setting.html.markdown b/website/docs/r/monitor_diagnostic_setting.html.markdown index eb474ca5d359..7c8a69994c20 100644 --- a/website/docs/r/monitor_diagnostic_setting.html.markdown +++ b/website/docs/r/monitor_diagnostic_setting.html.markdown @@ -99,7 +99,7 @@ A `log` block supports the following: -> **NOTE:** The Log Categories available vary depending on the Resource being used. You may wish to use [the `azurerm_monitor_diagnostic_categories` Data Source](../d/monitor_diagnostic_categories.html) to identify which categories are available for a given Resource. -* `retention_policy` - (Required) A `retention_policy` block as defined below. +* `retention_policy` - (Optional) A `retention_policy` block as defined below. * `enabled` - (Optional) Is this Diagnostic Log enabled? Defaults to `true`. @@ -111,7 +111,7 @@ A `metric` block supports the following: -> **NOTE:** The Metric Categories available vary depending on the Resource being used. You may wish to use [the `azurerm_monitor_diagnostic_categories` Data Source](../d/monitor_diagnostic_categories.html) to identify which categories are available for a given Resource. -* `retention_policy` - (Required) A `retention_policy` block as defined below. +* `retention_policy` - (Optional) A `retention_policy` block as defined below. * `enabled` - (Optional) Is this Diagnostic Metric enabled? Defaults to `true`. From d93afcc39d3f88228472700792ccbea8300db7a3 Mon Sep 17 00:00:00 2001 From: kt Date: Sat, 25 Apr 2020 23:21:57 -0700 Subject: [PATCH 3/3] appease linter --- .../services/monitor/resource_arm_monitor_diagnostic_setting.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go b/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go index 53dfc968965d..d075b3bab471 100644 --- a/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go +++ b/azurerm/internal/services/monitor/resource_arm_monitor_diagnostic_setting.go @@ -386,7 +386,7 @@ func expandMonitorDiagnosticsSettingsLogs(input []interface{}) []insights.LogSet enabled := v["enabled"].(bool) policiesRaw := v["retention_policy"].([]interface{}) var retentionPolicy *insights.RetentionPolicy - if policiesRaw != nil && len(policiesRaw) != 0 { + if len(policiesRaw) != 0 { policyRaw := policiesRaw[0].(map[string]interface{}) retentionDays := policyRaw["days"].(int) retentionEnabled := policyRaw["enabled"].(bool)