From dd128953d9540ba77456d210e885ee5c59a1c862 Mon Sep 17 00:00:00 2001 From: Samir <85890442+sa-progress@users.noreply.github.com> Date: Thu, 27 Jun 2024 15:03:21 +0530 Subject: [PATCH] Automatically generated by magic modules for service: bigtableadmin_v2 and resource: Projects__instances__cluster. This commit includes the following changes: - Singular Resource - Plural Resource - Documentation updates - Terraform configuration - Integration tests Signed-off-by: Samir <85890442+sa-progress@users.noreply.github.com> --- ..._bigtableadmin_project_instance_cluster.md | 90 ++++++++++++++++++ ...bigtableadmin_project_instance_clusters.md | 60 ++++++++++++ .../projectinstancecluster_cluster_config.rb | 37 ++++++++ ...uster_config_cluster_autoscaling_config.rb | 39 ++++++++ ...r_autoscaling_config_autoscaling_limits.rb | 37 ++++++++ ..._autoscaling_config_autoscaling_targets.rb | 37 ++++++++ ...rojectinstancecluster_encryption_config.rb | 34 +++++++ ..._bigtableadmin_project_instance_cluster.rb | 72 +++++++++++++++ ...bigtableadmin_project_instance_clusters.rb | 91 +++++++++++++++++++ ..._bigtableadmin_project_instance_cluster.rb | 42 +++++++++ ...bigtableadmin_project_instance_clusters.rb | 33 +++++++ 11 files changed, 572 insertions(+) create mode 100644 docs/resources/google_bigtableadmin_project_instance_cluster.md create mode 100644 docs/resources/google_bigtableadmin_project_instance_clusters.md create mode 100644 libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config.rb create mode 100644 libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config.rb create mode 100644 libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_limits.rb create mode 100644 libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_targets.rb create mode 100644 libraries/google/bigtableadmin/property/projectinstancecluster_encryption_config.rb create mode 100644 libraries/google_bigtableadmin_project_instance_cluster.rb create mode 100644 libraries/google_bigtableadmin_project_instance_clusters.rb create mode 100644 test/integration/verify/controls/google_bigtableadmin_project_instance_cluster.rb create mode 100644 test/integration/verify/controls/google_bigtableadmin_project_instance_clusters.rb diff --git a/docs/resources/google_bigtableadmin_project_instance_cluster.md b/docs/resources/google_bigtableadmin_project_instance_cluster.md new file mode 100644 index 00000000..c9e20973 --- /dev/null +++ b/docs/resources/google_bigtableadmin_project_instance_cluster.md @@ -0,0 +1,90 @@ ++++ + +title = "google_bigtableadmin_project_instance_cluster Resource" +platform = "gcp" +draft = false +gh_repo = "inspec-gcp" + + +[menu.inspec] + +title = "google_bigtableadmin_project_instance_cluster" +identifier = "inspec/resources/gcp/google_bigtableadmin_project_instance_cluster Resource" +parent = "inspec/resources/gcp" ++++ + +Use the `google_bigtableadmin_project_instance_cluster` InSpec audit resource to test the properties of a test a Google ProjectInstanceCluster. + +## Installation +{{% inspec_gcp_install %}} + +## Syntax +A `google_bigtableadmin_project_instance_cluster` is used to test a Google ProjectInstanceCluster resource + +## Examples +``` +describe google_bigtableadmin_project_instance_cluster(name: ' value_name') do + it { should exist } + its('name') { should cmp 'value_name' } + its('location') { should cmp 'value_location' } + its('state') { should cmp 'value_state' } + its('default_storage_type') { should cmp 'value_defaultstoragetype' } + +end + +describe google_bigtableadmin_project_instance_cluster(name: "does_not_exit") do + it { should_not exist } +end +``` + +## Parameters +Properties that can be accessed from the `google_bigtableadmin_project_instance_cluster` resource: + +## Properties +Properties that can be accessed from the `google_bigtableadmin_project_instance_cluster` resource: + + + * `name`: The unique name of the cluster. Values are of the form `projects/{project}/instances/{instance}/clusters/a-z*`. + + * `location`: Immutable. The location where this cluster's nodes and storage reside. For best performance, clients should be located as close as possible to this cluster. Currently only zones are supported, so values should be of the form `projects/{project}/locations/{zone}`. + + * `state`: Output only. The current state of the cluster. + Possible values: + * STATE_NOT_KNOWN + * READY + * CREATING + * RESIZING + * DISABLED + + * `serve_nodes`: The number of nodes in the cluster. If no value is set, Cloud Bigtable automatically allocates nodes based on your data footprint and optimized for 50% storage utilization. + + * `cluster_config`: Configuration for a cluster. + + * `cluster_autoscaling_config`: Autoscaling config for a cluster. + + * `autoscaling_limits`: Limits for the number of nodes a Cluster can autoscale up/down to. + + * `min_serve_nodes`: Required. Minimum number of nodes to scale down to. + + * `max_serve_nodes`: Required. Maximum number of nodes to scale up to. + + * `autoscaling_targets`: The Autoscaling targets for a Cluster. These determine the recommended nodes. + + * `cpu_utilization_percent`: The cpu utilization that the Autoscaler should be trying to achieve. This number is on a scale from 0 (no utilization) to 100 (total utilization), and is limited between 10 and 80, otherwise it will return INVALID_ARGUMENT error. + + * `storage_utilization_gib_per_node`: The storage utilization that the Autoscaler should be trying to achieve. This number is limited between 2560 (2.5TiB) and 5120 (5TiB) for a SSD cluster and between 8192 (8TiB) and 16384 (16TiB) for an HDD cluster, otherwise it will return INVALID_ARGUMENT error. If this value is set to 0, it will be treated as if it were set to the default value: 2560 for SSD, 8192 for HDD. + + * `default_storage_type`: Immutable. The type of storage used by this cluster to serve its parent instance's tables, unless explicitly overridden. + Possible values: + * STORAGE_TYPE_UNSPECIFIED + * SSD + * HDD + + * `encryption_config`: Cloud Key Management Service (Cloud KMS) settings for a CMEK-protected cluster. + + * `kms_key_name`: Describes the Cloud KMS encryption key that will be used to protect the destination Bigtable cluster. The requirements for this key are: 1) The Cloud Bigtable service account associated with the project that contains this cluster must be granted the `cloudkms.cryptoKeyEncrypterDecrypter` role on the CMEK key. 2) Only regional keys can be used and the region of the CMEK key must match the region of the cluster. Values are of the form `projects/{project}/locations/{location}/keyRings/{keyring}/cryptoKeys/{key}` + + +## GCP Permissions + +Ensure the [https://bigtableadmin.googleapis.com/](https://console.cloud.google.com/apis/library/bigtableadmin.googleapis.com/) is enabled for the current project. diff --git a/docs/resources/google_bigtableadmin_project_instance_clusters.md b/docs/resources/google_bigtableadmin_project_instance_clusters.md new file mode 100644 index 00000000..68d8d20f --- /dev/null +++ b/docs/resources/google_bigtableadmin_project_instance_clusters.md @@ -0,0 +1,60 @@ ++++ + +title = "google_bigtableadmin_project_instance_clusters Resource" +platform = "gcp" +draft = false +gh_repo = "inspec-gcp" + + +[menu.inspec] + +title = "google_bigtableadmin_project_instance_clusters" +identifier = "inspec/resources/gcp/google_bigtableadmin_project_instance_clusters Resource" +parent = "inspec/resources/gcp" ++++ + +Use the `google_bigtableadmin_project_instance_clusters` InSpec audit resource to test the properties of a test a Google ProjectInstanceCluster. + +## Installation +{{% inspec_gcp_install %}} + +## Syntax +A `google_bigtableadmin_project_instance_clusters` is used to test a Google ProjectInstanceCluster resource + +## Examples +``` + describe google_bigtableadmin_project_instance_clusters(parent: ' value_parent') do + it { should exist } + end +``` + +## Parameters +Properties that can be accessed from the `google_bigtableadmin_project_instance_clusters` resource: + +See [google_bigtableadmin_project_instance_cluster.md](google_bigtableadmin_project_instance_cluster.md) for more detailed information +* `names`: an array of `google_bigtableadmin_project_instance_cluster` name +* `locations`: an array of `google_bigtableadmin_project_instance_cluster` location +* `states`: an array of `google_bigtableadmin_project_instance_cluster` state +* `serve_nodes`: an array of `google_bigtableadmin_project_instance_cluster` serve_nodes +* `cluster_configs`: an array of `google_bigtableadmin_project_instance_cluster` cluster_config +* `default_storage_types`: an array of `google_bigtableadmin_project_instance_cluster` default_storage_type +* `encryption_configs`: an array of `google_bigtableadmin_project_instance_cluster` encryption_config +## Properties +Properties that can be accessed from the `google_bigtableadmin_project_instance_clusters` resource: + +See [google_bigtableadmin_project_instance_cluster.md](google_bigtableadmin_project_instance_cluster.md) for more detailed information +* `names`: an array of `google_bigtableadmin_project_instance_cluster` name +* `locations`: an array of `google_bigtableadmin_project_instance_cluster` location +* `states`: an array of `google_bigtableadmin_project_instance_cluster` state +* `serve_nodes`: an array of `google_bigtableadmin_project_instance_cluster` serve_nodes +* `cluster_configs`: an array of `google_bigtableadmin_project_instance_cluster` cluster_config +* `default_storage_types`: an array of `google_bigtableadmin_project_instance_cluster` default_storage_type +* `encryption_configs`: an array of `google_bigtableadmin_project_instance_cluster` encryption_config + +## Filter Criteria +This resource supports all of the above properties as filter criteria, which can be used +with `where` as a block or a method. + +## GCP Permissions + +Ensure the [https://bigtableadmin.googleapis.com/](https://console.cloud.google.com/apis/library/bigtableadmin.googleapis.com/) is enabled for the current project. diff --git a/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config.rb b/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config.rb new file mode 100644 index 00000000..a8650ae5 --- /dev/null +++ b/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config.rb @@ -0,0 +1,37 @@ +# frozen_string_literal: false + +# ---------------------------------------------------------------------------- +# +# *** AUTO GENERATED CODE *** Type: MMv1 *** +# +# ---------------------------------------------------------------------------- +# +# This file is automatically generated by Magic Modules and manual +# changes will be clobbered when the file is regenerated. +# +# Please read more about how to change this file in README.md and +# CONTRIBUTING.md located at the root of this package. +# +# ---------------------------------------------------------------------------- +require 'google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config' +require 'google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_limits' +require 'google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_targets' +module GoogleInSpec + module Bigtableadmin + module Property + class ProjectInstanceClusterClusterConfig + attr_reader :cluster_autoscaling_config + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @cluster_autoscaling_config = GoogleInSpec::Bigtableadmin::Property::ProjectInstanceClusterClusterConfigClusterAutoscalingConfig.new(args['clusterAutoscalingConfig'], to_s) + end + + def to_s + "#{@parent_identifier} ProjectInstanceClusterClusterConfig" + end + end + end + end +end diff --git a/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config.rb b/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config.rb new file mode 100644 index 00000000..a9c9b147 --- /dev/null +++ b/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config.rb @@ -0,0 +1,39 @@ +# frozen_string_literal: false + +# ---------------------------------------------------------------------------- +# +# *** AUTO GENERATED CODE *** Type: MMv1 *** +# +# ---------------------------------------------------------------------------- +# +# This file is automatically generated by Magic Modules and manual +# changes will be clobbered when the file is regenerated. +# +# Please read more about how to change this file in README.md and +# CONTRIBUTING.md located at the root of this package. +# +# ---------------------------------------------------------------------------- +require 'google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_limits' +require 'google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_targets' +module GoogleInSpec + module Bigtableadmin + module Property + class ProjectInstanceClusterClusterConfigClusterAutoscalingConfig + attr_reader :autoscaling_limits + + attr_reader :autoscaling_targets + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @autoscaling_limits = GoogleInSpec::Bigtableadmin::Property::ProjectInstanceClusterClusterConfigClusterAutoscalingConfigAutoscalingLimits.new(args['autoscalingLimits'], to_s) + @autoscaling_targets = GoogleInSpec::Bigtableadmin::Property::ProjectInstanceClusterClusterConfigClusterAutoscalingConfigAutoscalingTargets.new(args['autoscalingTargets'], to_s) + end + + def to_s + "#{@parent_identifier} ProjectInstanceClusterClusterConfigClusterAutoscalingConfig" + end + end + end + end +end diff --git a/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_limits.rb b/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_limits.rb new file mode 100644 index 00000000..d52ab19a --- /dev/null +++ b/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_limits.rb @@ -0,0 +1,37 @@ +# frozen_string_literal: false + +# ---------------------------------------------------------------------------- +# +# *** AUTO GENERATED CODE *** Type: MMv1 *** +# +# ---------------------------------------------------------------------------- +# +# This file is automatically generated by Magic Modules and manual +# changes will be clobbered when the file is regenerated. +# +# Please read more about how to change this file in README.md and +# CONTRIBUTING.md located at the root of this package. +# +# ---------------------------------------------------------------------------- +module GoogleInSpec + module Bigtableadmin + module Property + class ProjectInstanceClusterClusterConfigClusterAutoscalingConfigAutoscalingLimits + attr_reader :min_serve_nodes + + attr_reader :max_serve_nodes + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @min_serve_nodes = args['minServeNodes'] + @max_serve_nodes = args['maxServeNodes'] + end + + def to_s + "#{@parent_identifier} ProjectInstanceClusterClusterConfigClusterAutoscalingConfigAutoscalingLimits" + end + end + end + end +end diff --git a/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_targets.rb b/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_targets.rb new file mode 100644 index 00000000..cc30439b --- /dev/null +++ b/libraries/google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_targets.rb @@ -0,0 +1,37 @@ +# frozen_string_literal: false + +# ---------------------------------------------------------------------------- +# +# *** AUTO GENERATED CODE *** Type: MMv1 *** +# +# ---------------------------------------------------------------------------- +# +# This file is automatically generated by Magic Modules and manual +# changes will be clobbered when the file is regenerated. +# +# Please read more about how to change this file in README.md and +# CONTRIBUTING.md located at the root of this package. +# +# ---------------------------------------------------------------------------- +module GoogleInSpec + module Bigtableadmin + module Property + class ProjectInstanceClusterClusterConfigClusterAutoscalingConfigAutoscalingTargets + attr_reader :cpu_utilization_percent + + attr_reader :storage_utilization_gib_per_node + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @cpu_utilization_percent = args['cpuUtilizationPercent'] + @storage_utilization_gib_per_node = args['storageUtilizationGibPerNode'] + end + + def to_s + "#{@parent_identifier} ProjectInstanceClusterClusterConfigClusterAutoscalingConfigAutoscalingTargets" + end + end + end + end +end diff --git a/libraries/google/bigtableadmin/property/projectinstancecluster_encryption_config.rb b/libraries/google/bigtableadmin/property/projectinstancecluster_encryption_config.rb new file mode 100644 index 00000000..5e66a1dc --- /dev/null +++ b/libraries/google/bigtableadmin/property/projectinstancecluster_encryption_config.rb @@ -0,0 +1,34 @@ +# frozen_string_literal: false + +# ---------------------------------------------------------------------------- +# +# *** AUTO GENERATED CODE *** Type: MMv1 *** +# +# ---------------------------------------------------------------------------- +# +# This file is automatically generated by Magic Modules and manual +# changes will be clobbered when the file is regenerated. +# +# Please read more about how to change this file in README.md and +# CONTRIBUTING.md located at the root of this package. +# +# ---------------------------------------------------------------------------- +module GoogleInSpec + module Bigtableadmin + module Property + class ProjectInstanceClusterEncryptionConfig + attr_reader :kms_key_name + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @kms_key_name = args['kmsKeyName'] + end + + def to_s + "#{@parent_identifier} ProjectInstanceClusterEncryptionConfig" + end + end + end + end +end diff --git a/libraries/google_bigtableadmin_project_instance_cluster.rb b/libraries/google_bigtableadmin_project_instance_cluster.rb new file mode 100644 index 00000000..796bccc1 --- /dev/null +++ b/libraries/google_bigtableadmin_project_instance_cluster.rb @@ -0,0 +1,72 @@ +# frozen_string_literal: false + +# ---------------------------------------------------------------------------- +# +# *** AUTO GENERATED CODE *** Type: MMv1 *** +# +# ---------------------------------------------------------------------------- +# +# This file is automatically generated by Magic Modules and manual +# changes will be clobbered when the file is regenerated. +# +# Please read more about how to change this file in README.md and +# CONTRIBUTING.md located at the root of this package. +# +# ---------------------------------------------------------------------------- +require 'gcp_backend' +require 'google/bigtableadmin/property/projectinstancecluster_cluster_config' +require 'google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config' +require 'google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_limits' +require 'google/bigtableadmin/property/projectinstancecluster_cluster_config_cluster_autoscaling_config_autoscaling_targets' +require 'google/bigtableadmin/property/projectinstancecluster_encryption_config' + +# A provider to manage bigtableadmin resources. +class BigtableadminProjectInstanceCluster < GcpResourceBase + name 'google_bigtableadmin_project_instance_cluster' + desc 'ProjectInstanceCluster' + supports platform: 'gcp' + + attr_reader :params + attr_reader :name + attr_reader :location + attr_reader :state + attr_reader :serve_nodes + attr_reader :cluster_config + attr_reader :default_storage_type + attr_reader :encryption_config + + def initialize(params) + super(params.merge({ use_http_transport: true })) + @params = params + @fetched = @connection.fetch(product_url(params[:beta]), resource_base_url, params, 'Get') + parse unless @fetched.nil? + end + + def parse + @name = @fetched['name'] + @location = @fetched['location'] + @state = @fetched['state'] + @serve_nodes = @fetched['serveNodes'] + @cluster_config = GoogleInSpec::Bigtableadmin::Property::ProjectInstanceClusterClusterConfig.new(@fetched['clusterConfig'], to_s) + @default_storage_type = @fetched['defaultStorageType'] + @encryption_config = GoogleInSpec::Bigtableadmin::Property::ProjectInstanceClusterEncryptionConfig.new(@fetched['encryptionConfig'], to_s) + end + + def exists? + !@fetched.nil? + end + + def to_s + "ProjectInstanceCluster #{@params[:]}" + end + + private + + def product_url(_ = nil) + 'https://bigtableadmin.googleapis.com//v2/' + end + + def resource_base_url + '{{+name}}' + end +end diff --git a/libraries/google_bigtableadmin_project_instance_clusters.rb b/libraries/google_bigtableadmin_project_instance_clusters.rb new file mode 100644 index 00000000..d69765c9 --- /dev/null +++ b/libraries/google_bigtableadmin_project_instance_clusters.rb @@ -0,0 +1,91 @@ +# frozen_string_literal: false + +# ---------------------------------------------------------------------------- +# +# *** AUTO GENERATED CODE *** Type: MMv1 *** +# +# ---------------------------------------------------------------------------- +# +# This file is automatically generated by Magic Modules and manual +# changes will be clobbered when the file is regenerated. +# +# Please read more about how to change this file in README.md and +# CONTRIBUTING.md located at the root of this package. +# +# ---------------------------------------------------------------------------- +require 'gcp_backend' +class BigtableadminProjectInstanceClusters < GcpResourceBase + name 'google_bigtableadmin_project_instance_clusters' + desc 'ProjectInstanceCluster plural resource' + supports platform: 'gcp' + + attr_reader :table + + filter_table_config = FilterTable.create + + filter_table_config.add(:names, field: :name) + filter_table_config.add(:locations, field: :location) + filter_table_config.add(:states, field: :state) + filter_table_config.add(:serve_nodes, field: :serve_nodes) + filter_table_config.add(:cluster_configs, field: :cluster_config) + filter_table_config.add(:default_storage_types, field: :default_storage_type) + filter_table_config.add(:encryption_configs, field: :encryption_config) + + filter_table_config.connect(self, :table) + + def initialize(params = {}) + super(params.merge({ use_http_transport: true })) + @params = params + @table = fetch_wrapped_resource('projectInstanceClusters') + end + + def fetch_wrapped_resource(wrap_path) + # fetch_resource returns an array of responses (to handle pagination) + result = @connection.fetch_all(product_url, resource_base_url, @params, 'Get') + return if result.nil? + + # Conversion of string -> object hash to symbol -> object hash that InSpec needs + converted = [] + result.each do |response| + next if response.nil? || !response.key?(wrap_path) + response[wrap_path].each do |hash| + hash_with_symbols = {} + hash.each_key do |key| + name, value = transform(key, hash) + hash_with_symbols[name] = value + end + converted.push(hash_with_symbols) + end + end + + converted + end + + def transform(key, value) + return transformers[key].call(value) if transformers.key?(key) + + [key.to_sym, value] + end + + def transformers + { + 'name' => ->(obj) { [:name, obj['name']] }, + 'location' => ->(obj) { [:location, obj['location']] }, + 'state' => ->(obj) { [:state, obj['state']] }, + 'serveNodes' => ->(obj) { [:serve_nodes, obj['serveNodes']] }, + 'clusterConfig' => ->(obj) { [:cluster_config, GoogleInSpec::Bigtableadmin::Property::ProjectInstanceClusterClusterConfig.new(obj['clusterConfig'], to_s)] }, + 'defaultStorageType' => ->(obj) { [:default_storage_type, obj['defaultStorageType']] }, + 'encryptionConfig' => ->(obj) { [:encryption_config, GoogleInSpec::Bigtableadmin::Property::ProjectInstanceClusterEncryptionConfig.new(obj['encryptionConfig'], to_s)] }, + } + end + + private + + def product_url(_ = nil) + 'https://bigtableadmin.googleapis.com//v2/' + end + + def resource_base_url + '{{+parent}}/clusters' + end +end diff --git a/test/integration/verify/controls/google_bigtableadmin_project_instance_cluster.rb b/test/integration/verify/controls/google_bigtableadmin_project_instance_cluster.rb new file mode 100644 index 00000000..481d5557 --- /dev/null +++ b/test/integration/verify/controls/google_bigtableadmin_project_instance_cluster.rb @@ -0,0 +1,42 @@ +# ---------------------------------------------------------------------------- +# +# *** AUTO GENERATED CODE *** Type: MMv1 *** +# +# ---------------------------------------------------------------------------- +# +# This file is automatically generated by Magic Modules and manual +# changes will be clobbered when the file is regenerated. +# +# Please read more about how to change this file in README.md and +# CONTRIBUTING.md located at the root of this package. +# +# ---------------------------------------------------------------------------- + +title 'Test GCP google_bigtableadmin_project_instance_cluster resource.' + +gcp_project_id = input(:gcp_project_id, value: 'gcp_project_id', description: 'The GCP project identifier.') + + project_instance_cluster = input('project_instance_cluster', value: { + "name": "value_name", + "parent": "value_parent", + "location": "value_location", + "state": "value_state", + "default_storage_type": "value_defaultstoragetype" +}, description: 'project_instance_cluster description') +control 'google_bigtableadmin_project_instance_cluster-1.0' do + impact 1.0 + title 'google_bigtableadmin_project_instance_cluster resource test' + + describe google_bigtableadmin_project_instance_cluster(name: project_instance_cluster['name']) do + it { should exist } + its('name') { should cmp project_instance_cluster['name'] } + its('location') { should cmp project_instance_cluster['location'] } + its('state') { should cmp project_instance_cluster['state'] } + its('default_storage_type') { should cmp project_instance_cluster['default_storage_type'] } + + end + + describe google_bigtableadmin_project_instance_cluster(name: "does_not_exit") do + it { should_not exist } + end +end diff --git a/test/integration/verify/controls/google_bigtableadmin_project_instance_clusters.rb b/test/integration/verify/controls/google_bigtableadmin_project_instance_clusters.rb new file mode 100644 index 00000000..1a84dcb6 --- /dev/null +++ b/test/integration/verify/controls/google_bigtableadmin_project_instance_clusters.rb @@ -0,0 +1,33 @@ +# ---------------------------------------------------------------------------- +# +# *** AUTO GENERATED CODE *** Type: MMv1 *** +# +# ---------------------------------------------------------------------------- +# +# This file is automatically generated by Magic Modules and manual +# changes will be clobbered when the file is regenerated. +# +# Please read more about how to change this file in README.md and +# CONTRIBUTING.md located at the root of this package. +# +# ---------------------------------------------------------------------------- + +title 'Test GCP google_bigtableadmin_project_instance_clusters resource.' + +gcp_project_id = input(:gcp_project_id, value: 'gcp_project_id', description: 'The GCP project identifier.') + + project_instance_cluster = input('project_instance_cluster', value: { + "name": "value_name", + "parent": "value_parent", + "location": "value_location", + "state": "value_state", + "default_storage_type": "value_defaultstoragetype" +}, description: 'project_instance_cluster description') +control 'google_bigtableadmin_project_instance_clusters-1.0' do + impact 1.0 + title 'google_bigtableadmin_project_instance_clusters resource test' + + describe google_bigtableadmin_project_instance_clusters(parent: project_instance_cluster['parent']) do + it { should exist } + end +end