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

azurerm_backup_policy_vm support instant_restore_retention_days property #8822

Merged
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,13 @@ func resourceArmBackupProtectionPolicyVM() *schema.Resource {

"resource_group_name": azure.SchemaResourceGroupName(),

"instant_restore_retention_days": {
Type: schema.TypeInt,
Optional: true,
Computed: true,
ValidateFunc: validation.IntBetween(1, 5),
},

"recovery_vault_name": {
Type: schema.TypeString,
Required: true,
Expand Down Expand Up @@ -319,21 +326,28 @@ func resourceArmBackupProtectionPolicyVMCreateUpdate(d *schema.ResourceData, met
return fmt.Errorf("The Azure API has recently changed behaviour so that provisioning a `count` for the `retention_daily` field can no longer be less than 7 days for new/updates to existing Backup Policies. Please ensure that `count` is less than 7, currently %d", d.Get("retention_daily.0.count").(int))
}

policy := backup.ProtectionPolicyResource{
Tags: tags.Expand(t),
Properties: &backup.AzureIaaSVMProtectionPolicy{
TimeZone: utils.String(d.Get("timezone").(string)),
BackupManagementType: backup.BackupManagementTypeAzureIaasVM,
SchedulePolicy: expandArmBackupProtectionPolicyVMSchedule(d, times),
RetentionPolicy: &backup.LongTermRetentionPolicy{ // SimpleRetentionPolicy only has duration property ¯\_(ツ)_/¯
RetentionPolicyType: backup.RetentionPolicyTypeLongTermRetentionPolicy,
DailySchedule: expandArmBackupProtectionPolicyVMRetentionDaily(d, times),
WeeklySchedule: expandArmBackupProtectionPolicyVMRetentionWeekly(d, times),
MonthlySchedule: expandArmBackupProtectionPolicyVMRetentionMonthly(d, times),
YearlySchedule: expandArmBackupProtectionPolicyVMRetentionYearly(d, times),
},
vmProtectionPolicyProperties := &backup.AzureIaaSVMProtectionPolicy{
TimeZone: utils.String(d.Get("timezone").(string)),
BackupManagementType: backup.BackupManagementTypeAzureIaasVM,
SchedulePolicy: expandArmBackupProtectionPolicyVMSchedule(d, times),
RetentionPolicy: &backup.LongTermRetentionPolicy{ // SimpleRetentionPolicy only has duration property ¯\_(ツ)_/¯
RetentionPolicyType: backup.RetentionPolicyTypeLongTermRetentionPolicy,
DailySchedule: expandArmBackupProtectionPolicyVMRetentionDaily(d, times),
WeeklySchedule: expandArmBackupProtectionPolicyVMRetentionWeekly(d, times),
MonthlySchedule: expandArmBackupProtectionPolicyVMRetentionMonthly(d, times),
YearlySchedule: expandArmBackupProtectionPolicyVMRetentionYearly(d, times),
},
}

if d.HasChange("instant_restore_retention_days") {
vmProtectionPolicyProperties.InstantRpRetentionRangeInDays = utils.Int32(int32(d.Get("instant_restore_retention_days").(int)))
}

policy := backup.ProtectionPolicyResource{
Tags: tags.Expand(t),
Properties: vmProtectionPolicyProperties,
}

if _, err = client.CreateOrUpdate(ctx, vaultName, resourceGroup, policyName, policy); err != nil {
return fmt.Errorf("Error creating/updating Azure Backup Protection Policy %q (Resource Group %q): %+v", policyName, resourceGroup, err)
}
Expand Down Expand Up @@ -381,6 +395,7 @@ func resourceArmBackupProtectionPolicyVMRead(d *schema.ResourceData, meta interf

if properties, ok := resp.Properties.AsAzureIaaSVMProtectionPolicy(); ok && properties != nil {
d.Set("timezone", properties.TimeZone)
d.Set("instant_restore_retention_days", properties.InstantRpRetentionRangeInDays)

if schedule, ok := properties.SchedulePolicy.AsSimpleSchedulePolicy(); ok && schedule != nil {
if err := d.Set("backup", flattenArmBackupProtectionPolicyVMSchedule(schedule)); err != nil {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,39 @@ func TestAccAzureRMBackupProtectionPolicyVM_basicDaily(t *testing.T) {
})
}

func TestAccAzureRMBackupProtectionPolicyVM_withInstantRestoreRetentionRangeUpdate(t *testing.T) {
data := acceptance.BuildTestData(t, "azurerm_backup_policy_vm", "test")

resource.ParallelTest(t, resource.TestCase{
PreCheck: func() { acceptance.PreCheck(t) },
Providers: acceptance.SupportedProviders,
CheckDestroy: testCheckAzureRMBackupProtectionPolicyVmDestroy,
Steps: []resource.TestStep{
{
Config: testAccAzureRMBackupProtectionPolicyVM_basicDaily(data),
Check: resource.ComposeAggregateTestCheckFunc(
testCheckAzureRMBackupProtectionPolicyVmExists(data.ResourceName),
),
},
data.ImportStep(),
{
Config: testAccAzureRMBackupProtectionPolicyVM_basicDailyWithInstantRestoreRetentionRange(data),
Check: resource.ComposeAggregateTestCheckFunc(
testCheckAzureRMBackupProtectionPolicyVmExists(data.ResourceName),
),
},
data.ImportStep(),
{
Config: testAccAzureRMBackupProtectionPolicyVM_basicDaily(data),
Check: resource.ComposeAggregateTestCheckFunc(
testCheckAzureRMBackupProtectionPolicyVmExists(data.ResourceName),
),
},
data.ImportStep(),
},
})
}

func TestAccAzureRMBackupProtectionPolicyVM_requiresImport(t *testing.T) {
data := acceptance.BuildTestData(t, "azurerm_backup_policy_vm", "test")

Expand Down Expand Up @@ -535,3 +568,25 @@ resource "azurerm_backup_policy_vm" "test" {
}
`, template, data.RandomInteger)
}

func testAccAzureRMBackupProtectionPolicyVM_basicDailyWithInstantRestoreRetentionRange(data acceptance.TestData) string {
template := testAccAzureRMBackupProtectionPolicyVM_template(data)
return fmt.Sprintf(`
%s

resource "azurerm_backup_policy_vm" "test" {
name = "acctest-BPVM-%d"
resource_group_name = azurerm_resource_group.test.name
recovery_vault_name = azurerm_recovery_services_vault.test.name
instant_restore_retention_days = 5
backup {
frequency = "Daily"
time = "23:00"
}

retention_daily {
count = 10
}
}
`, template, data.RandomInteger)
}
2 changes: 2 additions & 0 deletions website/docs/r/backup_policy_vm.markdown
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,8 @@ The following arguments are supported:

* `timezone` - (Optional) Specifies the timezone. Defaults to `UTC`

* `instant_restore_retention_days` - (Optional) Specifies the instant restore retention range in days.

* `retention_daily` - (Optional) Configures the policy daily retention as documented in the `retention_daily` block below. Required when backup frequency is `Daily`.

* `retention_weekly` - (Optional) Configures the policy weekly retention as documented in the `retention_weekly` block below. Required when backup frequency is `Weekly`.
Expand Down