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

Allow updating of resource policies in compute_disk #2228

Merged
merged 29 commits into from
Sep 18, 2019
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
fea1285
Allow updating of resource policies in compute_disk
chrissng Aug 22, 2019
1fd406a
Address add and removeResourcePolicies API via an attachment resource…
chrissng Aug 23, 2019
983ca8a
Apply suggestions from code review
chrissng Aug 24, 2019
c6dc881
Fixes based on suggestions from PR review
chrissng Aug 24, 2019
f1a42a6
exclude inspec and ansible. change resource name to reference singular
chrissng Aug 24, 2019
b23d829
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Aug 24, 2019
dcbd5ae
Remove unused code
chrissng Aug 24, 2019
b610d42
Merge branch 'compute-disk-update-resource-policies' of github.com:ch…
chrissng Aug 24, 2019
14aa274
Add resource policy attachment test
chrissng Aug 24, 2019
e416437
Use custom checker
chrissng Aug 24, 2019
460c842
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Aug 27, 2019
2c948c4
Exclude resource policy for ansible and inspec
chrissng Aug 28, 2019
964d489
Update products/compute/ansible.yaml
chrissng Aug 28, 2019
c9f861b
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Aug 30, 2019
6cd2d18
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Sep 2, 2019
14e714f
make imports work
chrissng Sep 4, 2019
fe1b1c0
exclude resource policy in ansible overrides also
chrissng Sep 4, 2019
f49df1b
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Sep 4, 2019
573b783
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Sep 5, 2019
6d4da33
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Sep 6, 2019
60eb12f
fix importing of tf resource
chrissng Sep 6, 2019
d2995ab
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Sep 7, 2019
b41b21e
resource policy example use google provider, default zone
chrissng Sep 7, 2019
d09db5e
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Sep 10, 2019
8d6fb75
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Sep 12, 2019
b7de2e6
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Sep 16, 2019
0594529
Merge branch 'master' into compute-disk-update-resource-policies
chrissng Sep 16, 2019
b001d14
fix async operation timeout
chrissng Sep 17, 2019
819ad06
Merge branch 'master' into compute-disk-update-resource-policies
rileykarson Sep 18, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
70 changes: 70 additions & 0 deletions products/compute/api.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -1275,6 +1275,76 @@ objects:
An optional textual description of the valid disk size, such as
"10GB-10TB".
output: true
- !ruby/object:Api::Resource
name: 'DiskResourcePoliciesAttachment'
kind: 'compute#diskResourcePoliciesAttachment'
chrissng marked this conversation as resolved.
Show resolved Hide resolved
input: true
min_version: beta
chrissng marked this conversation as resolved.
Show resolved Hide resolved
base_url: projects/{{project}}/zones/{{zone}}/disks
chrissng marked this conversation as resolved.
Show resolved Hide resolved
create_verb: :POST
create_url: projects/{{project}}/zones/{{zone}}/disks/{{name}}/addResourcePolicies
chrissng marked this conversation as resolved.
Show resolved Hide resolved
delete_verb: :POST
delete_url: projects/{{project}}/zones/{{zone}}/disks/{{name}}/removeResourcePolicies
self_link: projects/{{project}}/zones/{{zone}}/disks/{{name}}
# nested_query: !ruby/object:Api::Resource::NestedQuery
chrissng marked this conversation as resolved.
Show resolved Hide resolved
# keys:
# - disk
# - resourcePolicies
# - zone
# is_list_of_ids: true
# identity:
# - resourcePolicies
description: |
Disk resource policies define a schedule for taking snapshots and a
retention period for these snapshots.
async: !ruby/object:Api::Async
operation: !ruby/object:Api::Async::Operation
kind: 'compute#operation'
path: 'name'
base_url: 'projects/{{project}}/zones/{{zone}}/operations/{{op_id}}'
wait_ms: 1000
timeouts: !ruby/object:Api::Timeouts
chrissng marked this conversation as resolved.
Show resolved Hide resolved
insert_minutes: 3
result: !ruby/object:Api::Async::Result
path: 'targetLink'
status: !ruby/object:Api::Async::Status
path: 'status'
complete: 'DONE'
allowed:
- 'PENDING'
- 'RUNNING'
- 'DONE'
error: !ruby/object:Api::Async::Error
path: 'error/errors'
message: 'message'
properties:
chrissng marked this conversation as resolved.
Show resolved Hide resolved
- !ruby/object:Api::Type::ResourceRef
name: 'name'
resource: 'Disk'
imports: 'name'
description: |
The name of the disk in which the resource policies are attached to.
required: true
- !ruby/object:Api::Type::Array
name: 'resourcePolicies'
description: |
Resource policies to be added to this disk. You can only add one
policy which will be applied to the disk for scheduling snapshot
creation.
item_type: !ruby/object:Api::Type::ResourceRef
name: 'resourcePolicy'
chrissng marked this conversation as resolved.
Show resolved Hide resolved
resource: 'ResourcePolicy'
imports: 'selfLink'
description: |
A resource policy applied to this disk for automatic snapshot
creations.
required: true
- !ruby/object:Api::Type::ResourceRef
name: 'zone'
chrissng marked this conversation as resolved.
Show resolved Hide resolved
resource: 'Zone'
imports: 'name'
description: 'A reference to the zone where the disk resides.'
required: true
- !ruby/object:Api::Resource
name: 'Disk'
# TODO(nelsonjr): Implement disk special actions as defined in the API:
Expand Down
11 changes: 11 additions & 0 deletions products/compute/terraform.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -302,6 +302,15 @@ overrides: !ruby/object:Overrides::ResourceOverrides
state as plain-text. [Read more about sensitive data in state](/docs/state/sensitive-data.html).
Because the API does not return the sensitive key value,
we cannot confirm or reverse changes to a key outside of Terraform.
DiskResourcePoliciesAttachment: !ruby/object:Overrides::Terraform::ResourceOverride
chrissng marked this conversation as resolved.
Show resolved Hide resolved
chrissng marked this conversation as resolved.
Show resolved Hide resolved
custom_code: !ruby/object:Provider::Terraform::CustomCode
pre_delete: templates/terraform/pre_delete/compute_disk_resource_policies_attachment.go.erb
chrissng marked this conversation as resolved.
Show resolved Hide resolved
# properties:
# name: !ruby/object:Overrides::Terraform::PropertyOverride
# name: disk
# create_url: projects/{{project}}/zones/{{zone}}/disks/{{disk}}/addResourcePolicies
# delete_url: projects/{{project}}/zones/{{zone}}/disks/{{disk}}/removeResourcePolicies
# self_link: projects/{{project}}/zones/{{zone}}/disks/{{disk}}
Disk: !ruby/object:Overrides::Terraform::ResourceOverride
# Larger disks were timing out at creation. Bumping up to 5 minutes.
# https://github.com/terraform-providers/terraform-provider-google/issues/703
Expand Down Expand Up @@ -369,6 +378,8 @@ overrides: !ruby/object:Overrides::ResourceOverrides
https://cloud.google.com/compute/docs/disks/customer-managed-encryption#encrypt_a_new_persistent_disk_with_your_own_keys
physicalBlockSizeBytes: !ruby/object:Overrides::Terraform::PropertyOverride
default_from_api: true
resourcePolicies: !ruby/object:Overrides::Terraform::PropertyOverride
default_from_api: true
custom_code: !ruby/object:Provider::Terraform::CustomCode
pre_delete: templates/terraform/pre_delete/detach_disk.erb
constants: templates/terraform/constants/disk.erb
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
obj = make(map[string]interface{})
resourcePoliciesProp, err := expandComputeDiskResourcePoliciesAttachmentResourcePolicies(d.Get("resource_policies"), d, config)
if err != nil {
return err
} else if v, ok := d.GetOkExists("resource_policies"); !isEmptyValue(reflect.ValueOf(resourcePoliciesProp)) && (ok || !reflect.DeepEqual(v, resourcePoliciesProp)) {
obj["resourcePolicies"] = resourcePoliciesProp
}
88 changes: 87 additions & 1 deletion third_party/terraform/tests/resource_compute_disk_test.go.erb
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,8 @@ import (
"github.com/hashicorp/terraform/helper/acctest"
"github.com/hashicorp/terraform/helper/resource"
"github.com/hashicorp/terraform/terraform"
"google.golang.org/api/compute/v1"
computeBeta "google.golang.org/api/compute/v0.beta"
compute "google.golang.org/api/compute/v1"
)

func TestDiskImageDiffSuppress(t *testing.T) {
Expand Down Expand Up @@ -444,6 +445,8 @@ func TestAccComputeDisk_resourcePolicies(t *testing.T) {

diskName := fmt.Sprintf("tf-test-%s", acctest.RandString(10))
policyName := fmt.Sprintf("tf-test-policy-%s", acctest.RandString(10))
policyName2 := fmt.Sprintf("tf-test-policy-%s-bar", acctest.RandString(10))
var disk computeBeta.Disk

resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Expand All @@ -457,9 +460,64 @@ func TestAccComputeDisk_resourcePolicies(t *testing.T) {
ImportState: true,
ImportStateVerify: true,
},
{
chrissng marked this conversation as resolved.
Show resolved Hide resolved
Config: testAccComputeDisk_resourcePolicies_updated(diskName, policyName2),
chrissng marked this conversation as resolved.
Show resolved Hide resolved
Check: resource.ComposeTestCheckFunc(
testAccCheckComputeBetaDiskExists(
"google_compute_disk.foobar", getTestProjectFromEnv(), &disk),
testAccCheckComputeDiskHasResourcePolicies(
&disk, policyName2),
),
},
},
})
}

func testAccCheckComputeBetaDiskExists(n, p string, disk *computeBeta.Disk) resource.TestCheckFunc {
return func(s *terraform.State) error {
rs, ok := s.RootModule().Resources[n]
if !ok {
return fmt.Errorf("Not found: %s", n)
}

if rs.Primary.ID == "" {
return fmt.Errorf("No ID is set")
}

config := testAccProvider.Meta().(*Config)

found, err := config.clientComputeBeta.Disks.Get(
p, rs.Primary.Attributes["zone"], rs.Primary.ID).Do()
if err != nil {
return err
}

if found.Name != rs.Primary.ID {
return fmt.Errorf("Disk not found")
}

*disk = *found

return nil
}
}

func testAccCheckComputeDiskHasResourcePolicies(disk *computeBeta.Disk, policyName string) resource.TestCheckFunc {
return func(s *terraform.State) error {
found := false
for _, v := range disk.ResourcePolicies {
if v == policyName {
found = true
}
}

if !found {
return fmt.Errorf("Resource policy is wrong. Found: %s", disk.ResourcePolicies)
}

return nil
}
}
<% end -%>

func testAccCheckComputeDiskExists(n, p string, disk *compute.Disk) resource.TestCheckFunc {
Expand Down Expand Up @@ -828,4 +886,32 @@ resource "google_compute_disk" "foobar" {
resource_policies = [google_compute_resource_policy.foo.self_link]
}`, policyName, diskName)
}

func testAccComputeDisk_resourcePolicies_updated(diskName, policyName string) string {
return fmt.Sprintf(`
data "google_compute_image" "my_image" {
family = "debian-9"
project = "debian-cloud"
}
resource "google_compute_resource_policy" "bar" {
name = "%s"
region = "us-central1"
snapshot_schedule_policy {
schedule {
daily_schedule {
days_in_cycle = 3
chrissng marked this conversation as resolved.
Show resolved Hide resolved
start_time = "06:00"
}
}
}
}
resource "google_compute_disk" "foobar" {
name = "%s"
image = "${data.google_compute_image.my_image.self_link}"
size = 50
type = "pd-ssd"
zone = "us-central1-a"
resource_policies = [google_compute_resource_policy.bar.self_link]
}`, policyName, diskName)
}
<% end -%>