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,12 @@ func resourceArmBackupProtectionPolicyVM() *schema.Resource {

"resource_group_name": azure.SchemaResourceGroupName(),

"instant_restore_retention_range": {
Type: schema.TypeInt,
Optional: true,
ValidateFunc: validation.IntAtLeast(1),
},

"recovery_vault_name": {
Type: schema.TypeString,
Required: true,
Expand Down Expand Up @@ -322,9 +328,10 @@ func resourceArmBackupProtectionPolicyVMCreateUpdate(d *schema.ResourceData, met
policy := backup.ProtectionPolicyResource{
Tags: tags.Expand(t),
Properties: &backup.AzureIaaSVMProtectionPolicy{
TimeZone: utils.String(d.Get("timezone").(string)),
BackupManagementType: backup.BackupManagementTypeAzureIaasVM,
SchedulePolicy: expandArmBackupProtectionPolicyVMSchedule(d, times),
TimeZone: utils.String(d.Get("timezone").(string)),
BackupManagementType: backup.BackupManagementTypeAzureIaasVM,
SchedulePolicy: expandArmBackupProtectionPolicyVMSchedule(d, times),
InstantRpRetentionRangeInDays: utils.Int32(d.Get("instant_restore_retention_range").(int32)),
RetentionPolicy: &backup.LongTermRetentionPolicy{ // SimpleRetentionPolicy only has duration property ¯\_(ツ)_/¯
RetentionPolicyType: backup.RetentionPolicyTypeLongTermRetentionPolicy,
DailySchedule: expandArmBackupProtectionPolicyVMRetentionDaily(d, times),
Expand Down Expand Up @@ -381,6 +388,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_range", 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,29 @@ func TestAccAzureRMBackupProtectionPolicyVM_basicDaily(t *testing.T) {
})
}

func TestAccAzureRMBackupProtectionPolicyVM_basicDailyWithInstantRestoreRetentionRange(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_basicDailyWithInstantRestoreRetentionRange(data),
Check: resource.ComposeAggregateTestCheckFunc(
testCheckAzureRMBackupProtectionPolicyVmExists(data.ResourceName),
resource.TestCheckResourceAttr(data.ResourceName, "backup.0.frequency", "Daily"),
resource.TestCheckResourceAttr(data.ResourceName, "backup.0.time", "23:00"),
resource.TestCheckResourceAttr(data.ResourceName, "retention_daily.0.count", "10"),
resource.TestCheckResourceAttr(data.ResourceName, "instant_restore_retention_range", "5"),
),
},
data.ImportStep(),
},
})
}

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

Expand Down Expand Up @@ -535,3 +558,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-%d"
Lucretius marked this conversation as resolved.
Show resolved Hide resolved
resource_group_name = azurerm_resource_group.test.name
recovery_vault_name = azurerm_recovery_services_vault.test.name
instant_restore_retention_range = 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_range` - (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