Skip to content

Commit

Permalink
Add replication enabled attribute in volume resource
Browse files Browse the repository at this point in the history
  • Loading branch information
dhirendersingh19 authored and Dhirender-Singh committed Sep 5, 2022
1 parent 1787dd0 commit 99896d6
Show file tree
Hide file tree
Showing 5 changed files with 155 additions and 3 deletions.
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ go 1.16
require (
github.com/IBM-Cloud/bluemix-go v0.0.0-20220523145737-34645883de47
github.com/IBM-Cloud/container-services-go-sdk v0.0.0-20220728135852-60ff775f7a8d
github.com/IBM-Cloud/power-go-client v1.1.12
github.com/IBM-Cloud/power-go-client v1.2.0
github.com/IBM/apigateway-go-sdk v0.0.0-20210714141226-a5d5d49caaca
github.com/IBM/appconfiguration-go-admin-sdk v0.3.0
github.com/IBM/appid-management-go-sdk v0.0.0-20210908164609-dd0e0eaf732f
Expand Down
4 changes: 2 additions & 2 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,8 @@ github.com/IBM-Cloud/bluemix-go v0.0.0-20220523145737-34645883de47/go.mod h1:tfN
github.com/IBM-Cloud/container-services-go-sdk v0.0.0-20220728135852-60ff775f7a8d h1:cHu5Iev9ggo1fktwmHbmPqDOkt3VYmdUGn1U7/Zb238=
github.com/IBM-Cloud/container-services-go-sdk v0.0.0-20220728135852-60ff775f7a8d/go.mod h1:xUQL9SGAjoZFd4GNjrjjtEpjpkgU7RFXRyHesbKTjiY=
github.com/IBM-Cloud/ibm-cloud-cli-sdk v0.5.3/go.mod h1:RiUvKuHKTBmBApDMUQzBL14pQUGKcx/IioKQPIcRQjs=
github.com/IBM-Cloud/power-go-client v1.1.12 h1:zL8Br83MHe1mDhFI+2YenQsHeYUtPzqw9oeFL9fmguE=
github.com/IBM-Cloud/power-go-client v1.1.12/go.mod h1:Qfx0fNi+9hms+xu9Z6Euhu9088ByW6C/TCMLECTRWNE=
github.com/IBM-Cloud/power-go-client v1.2.0 h1:0A3sSOC0d/P4IUAj4YGthA0g4liMaJpWvyBx50Z6/Ck=
github.com/IBM-Cloud/power-go-client v1.2.0/go.mod h1:Qfx0fNi+9hms+xu9Z6Euhu9088ByW6C/TCMLECTRWNE=
github.com/IBM-Cloud/softlayer-go v1.0.5-tf h1:koUAyF9b6X78lLLruGYPSOmrfY2YcGYKOj/Ug9nbKNw=
github.com/IBM-Cloud/softlayer-go v1.0.5-tf/go.mod h1:6HepcfAXROz0Rf63krk5hPZyHT6qyx2MNvYyHof7ik4=
github.com/IBM/apigateway-go-sdk v0.0.0-20210714141226-a5d5d49caaca h1:crniVcf+YcmgF03NmmfonXwSQ73oJF+IohFYBwknMxs=
Expand Down
81 changes: 81 additions & 0 deletions ibm/service/power/resource_ibm_pi_volume.go
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,12 @@ func ResourceIBMPIVolume() *schema.Resource {
Description: "List of pvmInstances to base volume anti-affinity policy against; required if requesting anti-affinity and pi_anti_affinity_volumes is not provided",
ConflictsWith: []string{PIAntiAffinityVolumes},
},
helpers.PIReplicationEnabled: {
Type: schema.TypeBool,
Optional: true,
Computed: true,
Description: "Indicates if the volume should be replication enabled or not",
},

// Computed Attributes
"volume_id": {
Expand All @@ -132,6 +138,51 @@ func ResourceIBMPIVolume() *schema.Resource {
Computed: true,
Description: "WWN Of the volume",
},
"auxiliary": {
Type: schema.TypeBool,
Computed: true,
Description: "true if volume is auxiliary otherwise false",
},
"consistency_group_name": {
Type: schema.TypeString,
Computed: true,
Description: "Consistency Group Name if volume is a part of volume group",
},
"group_id": {
Type: schema.TypeString,
Computed: true,
Description: "Volume Group ID",
},
"replication_type": {
Type: schema.TypeString,
Computed: true,
Description: "Replication type(metro,global)",
},
"replication_status": {
Type: schema.TypeString,
Computed: true,
Description: "Replication status of a volume",
},
"mirroring_state": {
Type: schema.TypeString,
Computed: true,
Description: "Mirroring state for replication enabled volume",
},
"primary_role": {
Type: schema.TypeString,
Computed: true,
Description: "Indicates whether master/aux volume is playing the primary role",
},
"aux_volume_name": {
Type: schema.TypeString,
Computed: true,
Description: "Indicates auxiliary volume name",
},
"master_volume_name": {
Type: schema.TypeString,
Computed: true,
Description: "Indicates master volume name",
},
},
}
}
Expand Down Expand Up @@ -178,6 +229,10 @@ func resourceIBMPIVolumeCreate(ctx context.Context, d *schema.ResourceData, meta
volumePool := v.(string)
body.VolumePool = volumePool
}
if v, ok := d.GetOk(helpers.PIReplicationEnabled); ok {
replicationEnabled := v.(bool)
body.ReplicationEnabled = &replicationEnabled
}
if ap, ok := d.GetOk(PIAffinityPolicy); ok {
policy := ap.(string)
body.AffinityPolicy = &policy
Expand Down Expand Up @@ -249,6 +304,16 @@ func resourceIBMPIVolumeRead(ctx context.Context, d *schema.ResourceData, meta i
if vol.VolumeID != nil {
d.Set("volume_id", vol.VolumeID)
}
d.Set(helpers.PIReplicationEnabled, vol.ReplicationEnabled)
d.Set("auxiliary", vol.Auxiliary)
d.Set("consistency_group_name", vol.ConsistencyGroupName)
d.Set("group_id", vol.GroupID)
d.Set("replication_type", vol.ReplicationType)
d.Set("replication_status", vol.ReplicationStatus)
d.Set("mirroring_state", vol.MirroringState)
d.Set("primary_role", vol.PrimaryRole)
d.Set("master_volume_name", vol.MasterVolumeName)
d.Set("aux_volume_name", vol.AuxVolumeName)
if vol.DeleteOnTermination != nil {
d.Set("delete_on_termination", vol.DeleteOnTermination)
}
Expand Down Expand Up @@ -291,6 +356,22 @@ func resourceIBMPIVolumeUpdate(ctx context.Context, d *schema.ResourceData, meta
return diag.FromErr(err)
}

if d.HasChange(helpers.PIReplicationEnabled) {
replicationEnabled := d.Get(helpers.PIReplicationEnabled).(bool)
volActionBody := models.VolumeAction{
ReplicationEnabled: &replicationEnabled,
}

err = client.VolumeAction(volumeID, &volActionBody)
if err != nil {
return diag.FromErr(err)
}
_, err = isWaitForIBMPIVolumeAvailable(ctx, client, volumeID, d.Timeout(schema.TimeoutUpdate))
if err != nil {
return diag.FromErr(err)
}
}

return resourceIBMPIVolumeRead(ctx, d, meta)
}

Expand Down
61 changes: 61 additions & 0 deletions ibm/service/power/resource_ibm_pi_volume_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -160,3 +160,64 @@ func testAccCheckIBMPIVolumePoolConfig(name string) string {
}
`, name, acc.Pi_cloud_instance_id)
}

func TestAccIBMPIVolumeGRS(t *testing.T) {
name := fmt.Sprintf("tf-pi-volume-%d", acctest.RandIntRange(10, 100))
resource.Test(t, resource.TestCase{
PreCheck: func() { acc.TestAccPreCheck(t) },
Providers: acc.TestAccProviders,
CheckDestroy: testAccCheckIBMPIVolumeDestroy,
Steps: []resource.TestStep{
{
Config: testAccCheckIBMPIVolumeGRSConfig(name),
Check: resource.ComposeTestCheckFunc(
testAccCheckIBMPIVolumeExists("ibm_pi_volume.power_volume"),
resource.TestCheckResourceAttr(
"ibm_pi_volume.power_volume", "pi_volume_name", name),
resource.TestCheckResourceAttr(
"ibm_pi_volume.power_volume", "pi_replication_enabled", "true"),
resource.TestCheckResourceAttr(
"ibm_pi_volume.power_volume", "replication_type", "global"),
),
},
{
Config: testAccCheckIBMPIVolumeGRSUpdateConfig(name),
Check: resource.ComposeTestCheckFunc(
testAccCheckIBMPIVolumeExists("ibm_pi_volume.power_volume"),
resource.TestCheckResourceAttr(
"ibm_pi_volume.power_volume", "pi_volume_name", name),
resource.TestCheckResourceAttr(
"ibm_pi_volume.power_volume", "pi_replication_enabled", "false"),
resource.TestCheckResourceAttr(
"ibm_pi_volume.power_volume", "replication_type", ""),
),
},
},
})
}

func testAccCheckIBMPIVolumeGRSConfig(name string) string {
return fmt.Sprintf(`
resource "ibm_pi_volume" "power_volume"{
pi_volume_size = 20
pi_volume_name = "%[1]s"
pi_volume_pool = "%[3]s"
pi_volume_shareable = true
pi_cloud_instance_id = "%[2]s"
pi_replication_enabled = true
}
`, name, acc.Pi_cloud_instance_id, acc.PiStoragePool)
}

func testAccCheckIBMPIVolumeGRSUpdateConfig(name string) string {
return fmt.Sprintf(`
resource "ibm_pi_volume" "power_volume"{
pi_volume_size = 20
pi_volume_name = "%[1]s"
pi_volume_pool = "%[3]s"
pi_volume_shareable = true
pi_cloud_instance_id = "%[2]s"
pi_replication_enabled = false
}
`, name, acc.Pi_cloud_instance_id, acc.PiStoragePool)
}
10 changes: 10 additions & 0 deletions website/docs/r/pi_volume.html.markdown
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ Review the argument references that you can specify for your resource.
- `pi_anti_affinity_instances` - (Optional, String) List of pvmInstances to base volume anti-affinity policy against; required if requesting `anti-affinity` and `pi_anti_affinity_volumes` is not provided.
- `pi_anti_affinity_volumes`- (Optional, String) List of volumes to base volume anti-affinity policy against; required if requesting `anti-affinity` and `pi_anti_affinity_instances` is not provided.
- `pi_cloud_instance_id` - (Required, String) The GUID of the service instance associated with an account.
- `pi_replication_enabled` - (Opttional, Bool) Indicates if the volume should be replication enabled or not.
- `pi_volume_name` - (Required, String) The name of the volume.
- `pi_volume_pool` - (Optional, String) Volume pool where the volume will be created; if provided then `pi_volume_type` and `pi_affinity_policy` values will be ignored.
- `pi_volume_shareable` - (Required, Bool) If set to **true**, the volume can be shared across Power Systems Virtual Server instances. If set to **false**, you can attach it only to one instance.
Expand All @@ -64,8 +65,17 @@ Review the argument references that you can specify for your resource.
## Attribute reference
In addition to all argument reference list, you can access the following attribute reference after your resource is created.

- `auxiliary` - (Bool) Indicates if the volume is auxiliary or not.
- `aux_volume_name` - (String) The auxiliary volume name.
- `consistency_group_name` - (String) The consistency group name if volume is a part of volume group.
- `delete_on_termination` - (Bool) Indicates if the volume should be deleted when the server terminates.
- `group_id` - (String) The volume group id in which the volume belongs.
- `id` - (String) The unique identifier of the volume. The ID is composed of `<power_instance_id>/<volume_id>`.
- `master_volume_name` - (String) The master volume name.
- `mirroring_state` - (String) The mirroring state for replication enabled volume.
- `primary_role` - (String) Indicates whether `master`/`auxiliary` volume is playing the primary role.
- `replication_status` - (String) The replication status of the volume.
- `replication_type` - (String) The replication type of the volume `metro` or `global`.
- `volume_id` - (String) The unique identifier of the volume.
- `volume_status` - (String) The status of the volume.
- `wwn` - (String) The world wide name of the volume.
Expand Down

0 comments on commit 99896d6

Please sign in to comment.