diff --git a/README.md b/README.md index c8d33fcbf..655709ef5 100644 --- a/README.md +++ b/README.md @@ -340,6 +340,7 @@ The following resources are available in the InSpec GCP Profile | [google_storage_default_object_acl](docs/resources/google_storage_default_object_acl.md) | No Plural Resource | | [google_storage_object_acl](docs/resources/google_storage_object_acl.md) | No Plural Resource | | [google_user](docs/resources/google_user.md) | [google_users](docs/resources/google_users.md) | +| [google_vertex_ai_model](docs/resources/google_vertex_ai_model.md) | [google_vertex_ai_models](docs/resources/google_vertex_ai_models.md) | | [google_vertex_ai_dataset](docs/resources/google_vertex_ai_dataset.md) | [google_vertex_ai_datasets](docs/resources/google_vertex_ai_datasets.md) | | [google_vertex_ai_batch_prediction_job](docs/resources/google_vertex_ai_batch_prediction_job.md) | [google_vertex_ai_batch_prediction_jobs](docs/resources/google_vertex_ai_batch_prediction_jobs.md) | | [google_vertex_ai_custom_job](docs/resources/google_vertex_ai_custom_job.md) | [google_vertex_ai_custom_jobs](docs/resources/google_vertex_ai_custom_jobs.md) | diff --git a/docs/resources/google_vertex_ai_model.md b/docs/resources/google_vertex_ai_model.md new file mode 100644 index 000000000..37eac2753 --- /dev/null +++ b/docs/resources/google_vertex_ai_model.md @@ -0,0 +1,249 @@ +--- +title: About the google_vertex_ai_model resource +platform: gcp +--- + +## Syntax +A `google_vertex_ai_model` is used to test a Google Model resource + +## Examples +``` +describe google_vertex_ai_model(name: "projects/#{gcp_project_id}/locations/#{model['region']}/models/#{model['name']}", region: ' value_region') do + it { should exist } + its('name') { should cmp 'value_name' } + its('update_time') { should cmp 'value_updatetime' } + its('etag') { should cmp 'value_etag' } + its('description') { should cmp 'value_description' } + its('create_time') { should cmp 'value_createtime' } + its('pipeline_job') { should cmp 'value_pipelinejob' } + its('version_update_time') { should cmp 'value_versionupdatetime' } + its('metadata_artifact') { should cmp 'value_metadataartifact' } + its('metadata_schema_uri') { should cmp 'value_metadataschemauri' } + its('version_id') { should cmp 'value_versionid' } + its('artifact_uri') { should cmp 'value_artifacturi' } + its('training_pipeline') { should cmp 'value_trainingpipeline' } + its('display_name') { should cmp 'value_displayname' } + its('version_create_time') { should cmp 'value_versioncreatetime' } + its('version_description') { should cmp 'value_versiondescription' } + +end + +describe google_vertex_ai_model(name: "does_not_exit", region: ' value_region') do + it { should_not exist } +end +``` + +## Properties +Properties that can be accessed from the `google_vertex_ai_model` resource: + + + * `model_source_info`: Detail description of the source information of the model. + + * `copy`: If this Model is copy of another Model. If true then source_type pertains to the original. + + * `source_type`: Type of the model source. + Possible values: + * MODEL_SOURCE_TYPE_UNSPECIFIED + * AUTOML + * CUSTOM + * BQML + * MODEL_GARDEN + * GENIE + + * `name`: The resource name of the Model. + + * `metadata`: Immutable. An additional information about the Model; the schema of the metadata can be found in metadata_schema. Unset if the Model does not have any additional information. + + * `update_time`: Output only. Timestamp when this Model was most recently updated. + + * `etag`: Used to perform consistent read-modify-write updates. If not set, a blind "overwrite" update happens. + + * `description`: The description of the Model. + + * `deployed_models`: Output only. The pointers to DeployedModels created from this Model. Note that Model could have been deployed to Endpoints in different Locations. + + * `deployed_model_id`: Immutable. An ID of a DeployedModel in the above Endpoint. + + * `endpoint`: Immutable. A resource name of an Endpoint. + + * `create_time`: Output only. Timestamp when this Model was uploaded into Vertex AI. + + * `explanation_spec`: Specification of Model explanation. + + * `parameters`: Parameters to configure explaining for Model's predictions. + + * `output_indices`: If populated, only returns attributions that have output_index contained in output_indices. It must be an ndarray of integers, with the same shape of the output it's explaining. If not populated, returns attributions for top_k indices of outputs. If neither top_k nor output_indices is populated, returns the argmax index of the outputs. Only applicable to Models that predict multiple outputs (e,g, multi-class Models that predict multiple classes). + + * `examples`: Example-based explainability that returns the nearest neighbors from the provided dataset. + + * `presets`: Preset configuration for example-based explanations + + * `modality`: The modality of the uploaded model, which automatically configures the distance measurement and feature normalization for the underlying example index and queries. If your model does not precisely fit one of these types, it is okay to choose the closest type. + Possible values: + * MODALITY_UNSPECIFIED + * IMAGE + * TEXT + * TABULAR + + * `query`: Preset option controlling parameters for speed-precision trade-off when querying for examples. If omitted, defaults to `PRECISE`. + Possible values: + * PRECISE + * FAST + + * `neighbor_count`: The number of neighbors to return when querying for examples. + + * `example_gcs_source`: The Cloud Storage input instances. + + * `gcs_source`: The Google Cloud Storage location for the input content. + + * `uris`: Required. Google Cloud Storage URI(-s) to the input file(s). May contain wildcards. For more information on wildcards, see https://cloud.google.com/storage/docs/gsutil/addlhelp/WildcardNames. + + * `data_format`: The format in which instances are given, if not specified, assume it's JSONL format. Currently only JSONL format is supported. + Possible values: + * DATA_FORMAT_UNSPECIFIED + * JSONL + + * `nearest_neighbor_search_config`: The full configuration for the generated index, the semantics are the same as metadata and should match [NearestNeighborSearchConfig](https://cloud.google.com/vertex-ai/docs/explainable-ai/configuring-explanations-example-based#nearest-neighbor-search-config). + + * `xrai_attribution`: An explanation method that redistributes Integrated Gradients attributions to segmented regions, taking advantage of the model's fully differentiable structure. Refer to this paper for more details: https://arxiv.org/abs/1906.02825 Supported only by image Models. + + * `smooth_grad_config`: Config for SmoothGrad approximation of gradients. When enabled, the gradients are approximated by averaging the gradients from noisy samples in the vicinity of the inputs. Adding noise can help improve the computed gradients. Refer to this paper for more details: https://arxiv.org/pdf/1706.03825.pdf + + * `feature_noise_sigma`: Noise sigma by features. Noise sigma represents the standard deviation of the gaussian kernel that will be used to add noise to interpolated inputs prior to computing gradients. + + * `noise_sigma`: Noise sigma per feature. No noise is added to features that are not set. + + * `name`: The name of the input feature for which noise sigma is provided. The features are defined in explanation metadata inputs. + + * `sigma`: This represents the standard deviation of the Gaussian kernel that will be used to add noise to the feature prior to computing gradients. Similar to noise_sigma but represents the noise added to the current feature. Defaults to 0.1. + + * `noise_sigma`: This is a single float value and will be used to add noise to all the features. Use this field when all features are normalized to have the same distribution: scale to range [0, 1], [-1, 1] or z-scoring, where features are normalized to have 0-mean and 1-variance. Learn more about [normalization](https://developers.google.com/machine-learning/data-prep/transform/normalization). For best results the recommended value is about 10% - 20% of the standard deviation of the input feature. Refer to section 3.2 of the SmoothGrad paper: https://arxiv.org/pdf/1706.03825.pdf. Defaults to 0.1. If the distribution is different per feature, set feature_noise_sigma instead for each feature. + + * `noisy_sample_count`: The number of gradient samples to use for approximation. The higher this number, the more accurate the gradient is, but the runtime complexity increases by this factor as well. Valid range of its value is [1, 50]. Defaults to 3. + + * `step_count`: Required. The number of steps for approximating the path integral. A good value to start is 50 and gradually increase until the sum to diff property is met within the desired error range. Valid range of its value is [1, 100], inclusively. + + * `blur_baseline_config`: Config for blur baseline. When enabled, a linear path from the maximally blurred image to the input image is created. Using a blurred baseline instead of zero (black image) is motivated by the BlurIG approach explained here: https://arxiv.org/abs/2004.03383 + + * `max_blur_sigma`: The standard deviation of the blur kernel for the blurred baseline. The same blurring parameter is used for both the height and the width dimension. If not set, the method defaults to the zero (i.e. black for images) baseline. + + * `top_k`: If populated, returns attributions for top K indices of outputs (defaults to 1). Only applies to Models that predicts more than one outputs (e,g, multi-class Models). When set to -1, returns explanations for all outputs. + + * `integrated_gradients_attribution`: An attribution method that computes the Aumann-Shapley value taking advantage of the model's fully differentiable structure. Refer to this paper for more details: https://arxiv.org/abs/1703.01365 + + * `step_count`: Required. The number of steps for approximating the path integral. A good value to start is 50 and gradually increase until the sum to diff property is within the desired error range. Valid range of its value is [1, 100], inclusively. + + * `smooth_grad_config`: Config for SmoothGrad approximation of gradients. When enabled, the gradients are approximated by averaging the gradients from noisy samples in the vicinity of the inputs. Adding noise can help improve the computed gradients. Refer to this paper for more details: https://arxiv.org/pdf/1706.03825.pdf + + * `feature_noise_sigma`: Noise sigma by features. Noise sigma represents the standard deviation of the gaussian kernel that will be used to add noise to interpolated inputs prior to computing gradients. + + * `noise_sigma`: Noise sigma per feature. No noise is added to features that are not set. + + * `name`: The name of the input feature for which noise sigma is provided. The features are defined in explanation metadata inputs. + + * `sigma`: This represents the standard deviation of the Gaussian kernel that will be used to add noise to the feature prior to computing gradients. Similar to noise_sigma but represents the noise added to the current feature. Defaults to 0.1. + + * `noise_sigma`: This is a single float value and will be used to add noise to all the features. Use this field when all features are normalized to have the same distribution: scale to range [0, 1], [-1, 1] or z-scoring, where features are normalized to have 0-mean and 1-variance. Learn more about [normalization](https://developers.google.com/machine-learning/data-prep/transform/normalization). For best results the recommended value is about 10% - 20% of the standard deviation of the input feature. Refer to section 3.2 of the SmoothGrad paper: https://arxiv.org/pdf/1706.03825.pdf. Defaults to 0.1. If the distribution is different per feature, set feature_noise_sigma instead for each feature. + + * `noisy_sample_count`: The number of gradient samples to use for approximation. The higher this number, the more accurate the gradient is, but the runtime complexity increases by this factor as well. Valid range of its value is [1, 50]. Defaults to 3. + + * `blur_baseline_config`: Config for blur baseline. When enabled, a linear path from the maximally blurred image to the input image is created. Using a blurred baseline instead of zero (black image) is motivated by the BlurIG approach explained here: https://arxiv.org/abs/2004.03383 + + * `max_blur_sigma`: The standard deviation of the blur kernel for the blurred baseline. The same blurring parameter is used for both the height and the width dimension. If not set, the method defaults to the zero (i.e. black for images) baseline. + + * `sampled_shapley_attribution`: An attribution method that approximates Shapley values for features that contribute to the label being predicted. A sampling strategy is used to approximate the value rather than considering all subsets of features. + + * `path_count`: Required. The number of feature permutations to consider when approximating the Shapley values. Valid range of its value is [1, 50], inclusively. + + * `metadata`: Metadata describing the Model's input and output for explanation. + + * `feature_attributions_schema_uri`: Points to a YAML file stored on Google Cloud Storage describing the format of the feature attributions. The schema is defined as an OpenAPI 3.0.2 [Schema Object](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.2.md#schemaObject). AutoML tabular Models always have this field populated by Vertex AI. Note: The URI given on output may be different, including the URI scheme, than the one given on input. The output URI will point to a location where the user only has a read access. + + * `latent_space_source`: Name of the source to generate embeddings for example based explanations. + + * `outputs`: Required. Map from output names to output metadata. For Vertex AI-provided Tensorflow images, keys can be any user defined string that consists of any UTF-8 characters. For custom images, keys are the name of the output field in the prediction to be explained. Currently only one key is allowed. + + * `additional_properties`: Metadata of the prediction output to be explained. + + * `inputs`: Required. Map from feature names to feature input metadata. Keys are the name of the features. Values are the specification of the feature. An empty InputMetadata is valid. It describes a text feature which has the name specified as the key in ExplanationMetadata.inputs. The baseline of the empty feature is chosen by Vertex AI. For Vertex AI-provided Tensorflow images, the key can be any friendly name of the feature. Once specified, featureAttributions are keyed by this key (if not grouped with another feature). For custom images, the key must match with the key in instance. + + * `additional_properties`: Metadata of the input of a feature. Fields other than InputMetadata.input_baselines are applicable only for Models that are using Vertex AI-provided images for Tensorflow. + + * `encryption_spec`: Represents a customer-managed encryption key spec that can be applied to a top-level resource. + + * `kms_key_name`: Required. The Cloud KMS resource identifier of the customer managed encryption key used to protect a resource. Has the form: `projects/my-project/locations/my-region/keyRings/my-kr/cryptoKeys/my-key`. The key needs to be in the same region as where the compute resource is created. + + * `pipeline_job`: Optional. This field is populated if the model is produced by a pipeline job. + + * `predict_schemata`: Contains the schemata used in Model's predictions and explanations via PredictionService.Predict, PredictionService.Explain and BatchPredictionJob. + + * `instance_schema_uri`: Immutable. Points to a YAML file stored on Google Cloud Storage describing the format of a single instance, which are used in PredictRequest.instances, ExplainRequest.instances and BatchPredictionJob.input_config. The schema is defined as an OpenAPI 3.0.2 [Schema Object](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.2.md#schemaObject). AutoML Models always have this field populated by Vertex AI. Note: The URI given on output will be immutable and probably different, including the URI scheme, than the one given on input. The output URI will point to a location where the user only has a read access. + + * `parameters_schema_uri`: Immutable. Points to a YAML file stored on Google Cloud Storage describing the parameters of prediction and explanation via PredictRequest.parameters, ExplainRequest.parameters and BatchPredictionJob.model_parameters. The schema is defined as an OpenAPI 3.0.2 [Schema Object](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.2.md#schemaObject). AutoML Models always have this field populated by Vertex AI, if no parameters are supported, then it is set to an empty string. Note: The URI given on output will be immutable and probably different, including the URI scheme, than the one given on input. The output URI will point to a location where the user only has a read access. + + * `prediction_schema_uri`: Immutable. Points to a YAML file stored on Google Cloud Storage describing the format of a single prediction produced by this Model, which are returned via PredictResponse.predictions, ExplainResponse.explanations, and BatchPredictionJob.output_config. The schema is defined as an OpenAPI 3.0.2 [Schema Object](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.2.md#schemaObject). AutoML Models always have this field populated by Vertex AI. Note: The URI given on output will be immutable and probably different, including the URI scheme, than the one given on input. The output URI will point to a location where the user only has a read access. + + * `version_update_time`: Output only. Timestamp when this version was most recently updated. + + * `supported_export_formats`: Output only. The formats in which this Model may be exported. If empty, this Model is not available for export. + + * `exportable_contents`: Output only. The content of this Model that may be exported. + + * `id`: Output only. The ID of the export format. The possible format IDs are: * `tflite` Used for Android mobile devices. * `edgetpu-tflite` Used for [Edge TPU](https://cloud.google.com/edge-tpu/) devices. * `tf-saved-model` A tensorflow model in SavedModel format. * `tf-js` A [TensorFlow.js](https://www.tensorflow.org/js) model that can be used in the browser and in Node.js using JavaScript. * `core-ml` Used for iOS mobile devices. * `custom-trained` A Model that was uploaded or trained by custom code. + + * `original_model_info`: Contains information about the original Model if this Model is a copy. + + * `model`: Output only. The resource name of the Model this Model is a copy of, including the revision. Format: `projects/{project}/locations/{location}/models/{model_id}@{version_id}` + + * `metadata_artifact`: Output only. The resource name of the Artifact that was created in MetadataStore when creating the Model. The Artifact resource name pattern is `projects/{project}/locations/{location}/metadataStores/{metadata_store}/artifacts/{artifact}`. + + * `supported_input_storage_formats`: Output only. The formats this Model supports in BatchPredictionJob.input_config. If PredictSchemata.instance_schema_uri exists, the instances should be given as per that schema. The possible formats are: * `jsonl` The JSON Lines format, where each instance is a single line. Uses GcsSource. * `csv` The CSV format, where each instance is a single comma-separated line. The first line in the file is the header, containing comma-separated field names. Uses GcsSource. * `tf-record` The TFRecord format, where each instance is a single record in tfrecord syntax. Uses GcsSource. * `tf-record-gzip` Similar to `tf-record`, but the file is gzipped. Uses GcsSource. * `bigquery` Each instance is a single row in BigQuery. Uses BigQuerySource. * `file-list` Each line of the file is the location of an instance to process, uses `gcs_source` field of the InputConfig object. If this Model doesn't support any of these formats it means it cannot be used with a BatchPredictionJob. However, if it has supported_deployment_resources_types, it could serve online predictions by using PredictionService.Predict or PredictionService.Explain. + + * `metadata_schema_uri`: Immutable. Points to a YAML file stored on Google Cloud Storage describing additional information about the Model, that is specific to it. Unset if the Model does not have any additional information. The schema is defined as an OpenAPI 3.0.2 [Schema Object](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.2.md#schemaObject). AutoML Models always have this field populated by Vertex AI, if no additional metadata is needed, this field is set to an empty string. Note: The URI given on output will be immutable and probably different, including the URI scheme, than the one given on input. The output URI will point to a location where the user only has a read access. + + * `container_spec`: Specification of a container for serving predictions. Some fields in this message correspond to fields in the [Kubernetes Container v1 core specification](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.23/#container-v1-core). + + * `predict_route`: Immutable. HTTP path on the container to send prediction requests to. Vertex AI forwards requests sent using projects.locations.endpoints.predict to this path on the container's IP address and port. Vertex AI then returns the container's response in the API response. For example, if you set this field to `/foo`, then when Vertex AI receives a prediction request, it forwards the request body in a POST request to the `/foo` path on the port of your container specified by the first value of this `ModelContainerSpec`'s ports field. If you don't specify this field, it defaults to the following value when you deploy this Model to an Endpoint: /v1/endpoints/ENDPOINT/deployedModels/DEPLOYED_MODEL:predict The placeholders in this value are replaced as follows: * ENDPOINT: The last segment (following `endpoints/`)of the Endpoint.name][] field of the Endpoint where this Model has been deployed. (Vertex AI makes this value available to your container code as the [`AIP_ENDPOINT_ID` environment variable](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#aip-variables).) * DEPLOYED_MODEL: DeployedModel.id of the `DeployedModel`. (Vertex AI makes this value available to your container code as the [`AIP_DEPLOYED_MODEL_ID` environment variable](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#aip-variables).) + + * `image_uri`: Required. Immutable. URI of the Docker image to be used as the custom container for serving predictions. This URI must identify an image in Artifact Registry or Container Registry. Learn more about the [container publishing requirements](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#publishing), including permissions requirements for the Vertex AI Service Agent. The container image is ingested upon ModelService.UploadModel, stored internally, and this original path is afterwards not used. To learn about the requirements for the Docker image itself, see [Custom container requirements](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#). You can use the URI to one of Vertex AI's [pre-built container images for prediction](https://cloud.google.com/vertex-ai/docs/predictions/pre-built-containers) in this field. + + * `env`: Immutable. List of environment variables to set in the container. After the container starts running, code running in the container can read these environment variables. Additionally, the command and args fields can reference these variables. Later entries in this list can also reference earlier entries. For example, the following example sets the variable `VAR_2` to have the value `foo bar`: ```json [ { "name": "VAR_1", "value": "foo" }, { "name": "VAR_2", "value": "$(VAR_1) bar" } ] ``` If you switch the order of the variables in the example, then the expansion does not occur. This field corresponds to the `env` field of the Kubernetes Containers [v1 core API](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.23/#container-v1-core). + + * `name`: Required. Name of the environment variable. Must be a valid C identifier. + + * `value`: Required. Variables that reference a $(VAR_NAME) are expanded using the previous defined environment variables in the container and any service environment variables. If a variable cannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax can be escaped with a double $$, ie: $$(VAR_NAME). Escaped references will never be expanded, regardless of whether the variable exists or not. + + * `args`: Immutable. Specifies arguments for the command that runs when the container starts. This overrides the container's [`CMD`](https://docs.docker.com/engine/reference/builder/#cmd). Specify this field as an array of executable and arguments, similar to a Docker `CMD`'s "default parameters" form. If you don't specify this field but do specify the command field, then the command from the `command` field runs without any additional arguments. See the [Kubernetes documentation about how the `command` and `args` fields interact with a container's `ENTRYPOINT` and `CMD`](https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#notes). If you don't specify this field and don't specify the `command` field, then the container's [`ENTRYPOINT`](https://docs.docker.com/engine/reference/builder/#cmd) and `CMD` determine what runs based on their default behavior. See the Docker documentation about [how `CMD` and `ENTRYPOINT` interact](https://docs.docker.com/engine/reference/builder/#understand-how-cmd-and-entrypoint-interact). In this field, you can reference [environment variables set by Vertex AI](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#aip-variables) and environment variables set in the env field. You cannot reference environment variables set in the Docker image. In order for environment variables to be expanded, reference them by using the following syntax: $( VARIABLE_NAME) Note that this differs from Bash variable expansion, which does not use parentheses. If a variable cannot be resolved, the reference in the input string is used unchanged. To avoid variable expansion, you can escape this syntax with `$$`; for example: $$(VARIABLE_NAME) This field corresponds to the `args` field of the Kubernetes Containers [v1 core API](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.23/#container-v1-core). + + * `command`: Immutable. Specifies the command that runs when the container starts. This overrides the container's [ENTRYPOINT](https://docs.docker.com/engine/reference/builder/#entrypoint). Specify this field as an array of executable and arguments, similar to a Docker `ENTRYPOINT`'s "exec" form, not its "shell" form. If you do not specify this field, then the container's `ENTRYPOINT` runs, in conjunction with the args field or the container's [`CMD`](https://docs.docker.com/engine/reference/builder/#cmd), if either exists. If this field is not specified and the container does not have an `ENTRYPOINT`, then refer to the Docker documentation about [how `CMD` and `ENTRYPOINT` interact](https://docs.docker.com/engine/reference/builder/#understand-how-cmd-and-entrypoint-interact). If you specify this field, then you can also specify the `args` field to provide additional arguments for this command. However, if you specify this field, then the container's `CMD` is ignored. See the [Kubernetes documentation about how the `command` and `args` fields interact with a container's `ENTRYPOINT` and `CMD`](https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#notes). In this field, you can reference [environment variables set by Vertex AI](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#aip-variables) and environment variables set in the env field. You cannot reference environment variables set in the Docker image. In order for environment variables to be expanded, reference them by using the following syntax: $( VARIABLE_NAME) Note that this differs from Bash variable expansion, which does not use parentheses. If a variable cannot be resolved, the reference in the input string is used unchanged. To avoid variable expansion, you can escape this syntax with `$$`; for example: $$(VARIABLE_NAME) This field corresponds to the `command` field of the Kubernetes Containers [v1 core API](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.23/#container-v1-core). + + * `ports`: Immutable. List of ports to expose from the container. Vertex AI sends any prediction requests that it receives to the first port on this list. Vertex AI also sends [liveness and health checks](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#liveness) to this port. If you do not specify this field, it defaults to following value: ```json [ { "containerPort": 8080 } ] ``` Vertex AI does not use ports other than the first one listed. This field corresponds to the `ports` field of the Kubernetes Containers [v1 core API](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.23/#container-v1-core). + + * `container_port`: The number of the port to expose on the pod's IP address. Must be a valid port number, between 1 and 65535 inclusive. + + * `health_route`: Immutable. HTTP path on the container to send health checks to. Vertex AI intermittently sends GET requests to this path on the container's IP address and port to check that the container is healthy. Read more about [health checks](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#health). For example, if you set this field to `/bar`, then Vertex AI intermittently sends a GET request to the `/bar` path on the port of your container specified by the first value of this `ModelContainerSpec`'s ports field. If you don't specify this field, it defaults to the following value when you deploy this Model to an Endpoint: /v1/endpoints/ENDPOINT/deployedModels/ DEPLOYED_MODEL:predict The placeholders in this value are replaced as follows: * ENDPOINT: The last segment (following `endpoints/`)of the Endpoint.name][] field of the Endpoint where this Model has been deployed. (Vertex AI makes this value available to your container code as the [`AIP_ENDPOINT_ID` environment variable](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#aip-variables).) * DEPLOYED_MODEL: DeployedModel.id of the `DeployedModel`. (Vertex AI makes this value available to your container code as the [`AIP_DEPLOYED_MODEL_ID` environment variable](https://cloud.google.com/vertex-ai/docs/predictions/custom-container-requirements#aip-variables).) + + * `version_id`: Output only. Immutable. The version ID of the model. A new version is committed when a new model version is uploaded or trained under an existing model id. It is an auto-incrementing decimal number in string representation. + + * `artifact_uri`: Immutable. The path to the directory containing the Model artifact and any of its supporting files. Not present for AutoML Models or Large Models. + + * `training_pipeline`: Output only. The resource name of the TrainingPipeline that uploaded this Model, if any. + + * `display_name`: Required. The display name of the Model. The name can be up to 128 characters long and can consist of any UTF-8 characters. + + * `supported_deployment_resources_types`: Output only. When this Model is deployed, its prediction resources are described by the `prediction_resources` field of the Endpoint.deployed_models object. Because not all Models support all resource configuration types, the configuration types this Model supports are listed here. If no configuration types are listed, the Model cannot be deployed to an Endpoint and does not support online predictions (PredictionService.Predict or PredictionService.Explain). Such a Model can serve predictions by using a BatchPredictionJob, if it has at least one entry each in supported_input_storage_formats and supported_output_storage_formats. + + * `supported_output_storage_formats`: Output only. The formats this Model supports in BatchPredictionJob.output_config. If both PredictSchemata.instance_schema_uri and PredictSchemata.prediction_schema_uri exist, the predictions are returned together with their instances. In other words, the prediction has the original instance data first, followed by the actual prediction content (as per the schema). The possible formats are: * `jsonl` The JSON Lines format, where each prediction is a single line. Uses GcsDestination. * `csv` The CSV format, where each prediction is a single comma-separated line. The first line in the file is the header, containing comma-separated field names. Uses GcsDestination. * `bigquery` Each prediction is a single row in a BigQuery table, uses BigQueryDestination . If this Model doesn't support any of these formats it means it cannot be used with a BatchPredictionJob. However, if it has supported_deployment_resources_types, it could serve online predictions by using PredictionService.Predict or PredictionService.Explain. + + * `version_aliases`: User provided version aliases so that a model version can be referenced via alias (i.e. `projects/{project}/locations/{location}/models/{model_id}@{version_alias}` instead of auto-generated version id (i.e. `projects/{project}/locations/{location}/models/{model_id}@{version_id})`. The format is a-z{0,126}[a-z0-9] to distinguish from version_id. A default version alias will be created for the first version of the model, and there must be exactly one default version alias for a model. + + * `version_create_time`: Output only. Timestamp when this version was created. + + * `version_description`: The description of this version. + + * `labels`: The labels with user-defined metadata to organize your Models. Label keys and values can be no longer than 64 characters (Unicode codepoints), can only contain lowercase letters, numeric characters, underscores and dashes. International characters are allowed. See https://goo.gl/xmQnxf for more information and examples of labels. + + * `additional_properties`: + + +## GCP Permissions diff --git a/docs/resources/google_vertex_ai_models.md b/docs/resources/google_vertex_ai_models.md new file mode 100644 index 000000000..b1d93a44a --- /dev/null +++ b/docs/resources/google_vertex_ai_models.md @@ -0,0 +1,54 @@ +--- +title: About the google_vertex_ai_models resource +platform: gcp +--- + +## Syntax +A `google_vertex_ai_models` is used to test a Google Model resource + +## Examples +``` + describe google_vertex_ai_models(parent: "projects/#{gcp_project_id}/locations/#{model['region']}", region: ' value_region') do + it { should exist } + end +``` + +## Properties +Properties that can be accessed from the `google_vertex_ai_models` resource: + +See [google_vertex_ai_model.md](google_vertex_ai_model.md) for more detailed information + * `model_source_infos`: an array of `google_vertex_ai_model` model_source_info + * `names`: an array of `google_vertex_ai_model` name + * `metadata`: an array of `google_vertex_ai_model` metadata + * `update_times`: an array of `google_vertex_ai_model` update_time + * `etags`: an array of `google_vertex_ai_model` etag + * `descriptions`: an array of `google_vertex_ai_model` description + * `deployed_models`: an array of `google_vertex_ai_model` deployed_models + * `create_times`: an array of `google_vertex_ai_model` create_time + * `explanation_specs`: an array of `google_vertex_ai_model` explanation_spec + * `encryption_specs`: an array of `google_vertex_ai_model` encryption_spec + * `pipeline_jobs`: an array of `google_vertex_ai_model` pipeline_job + * `predict_schemata`: an array of `google_vertex_ai_model` predict_schemata + * `version_update_times`: an array of `google_vertex_ai_model` version_update_time + * `supported_export_formats`: an array of `google_vertex_ai_model` supported_export_formats + * `original_model_infos`: an array of `google_vertex_ai_model` original_model_info + * `metadata_artifacts`: an array of `google_vertex_ai_model` metadata_artifact + * `supported_input_storage_formats`: an array of `google_vertex_ai_model` supported_input_storage_formats + * `metadata_schema_uris`: an array of `google_vertex_ai_model` metadata_schema_uri + * `container_specs`: an array of `google_vertex_ai_model` container_spec + * `version_ids`: an array of `google_vertex_ai_model` version_id + * `artifact_uris`: an array of `google_vertex_ai_model` artifact_uri + * `training_pipelines`: an array of `google_vertex_ai_model` training_pipeline + * `display_names`: an array of `google_vertex_ai_model` display_name + * `supported_deployment_resources_types`: an array of `google_vertex_ai_model` supported_deployment_resources_types + * `supported_output_storage_formats`: an array of `google_vertex_ai_model` supported_output_storage_formats + * `version_aliases`: an array of `google_vertex_ai_model` version_aliases + * `version_create_times`: an array of `google_vertex_ai_model` version_create_time + * `version_descriptions`: an array of `google_vertex_ai_model` version_description + * `labels`: an array of `google_vertex_ai_model` labels + +## 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 diff --git a/libraries/google/vertexai/property/model_container_spec.rb b/libraries/google/vertexai/property/model_container_spec.rb new file mode 100644 index 000000000..fd8c54cd2 --- /dev/null +++ b/libraries/google/vertexai/property/model_container_spec.rb @@ -0,0 +1,54 @@ +# 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/vertexai/property/model_container_spec_env' +require 'google/vertexai/property/model_container_spec_ports' +module GoogleInSpec + module VertexAI + module Property + class ModelContainerSpec + attr_reader :predict_route + + attr_reader :image_uri + + attr_reader :env + + attr_reader :args + + attr_reader :command + + attr_reader :ports + + attr_reader :health_route + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @predict_route = args['predictRoute'] + @image_uri = args['imageUri'] + @env = GoogleInSpec::VertexAI::Property::ModelContainerSpecEnvArray.parse(args['env'], to_s) + @args = args['args'] + @command = args['command'] + @ports = GoogleInSpec::VertexAI::Property::ModelContainerSpecPortsArray.parse(args['ports'], to_s) + @health_route = args['healthRoute'] + end + + def to_s + "#{@parent_identifier} ModelContainerSpec" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_container_spec_env.rb b/libraries/google/vertexai/property/model_container_spec_env.rb new file mode 100644 index 000000000..1ffb89433 --- /dev/null +++ b/libraries/google/vertexai/property/model_container_spec_env.rb @@ -0,0 +1,45 @@ +# 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 VertexAI + module Property + class ModelContainerSpecEnv + attr_reader :name + + attr_reader :value + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @name = args['name'] + @value = args['value'] + end + + def to_s + "#{@parent_identifier} ModelContainerSpecEnv" + end + end + + class ModelContainerSpecEnvArray + def self.parse(value, parent_identifier) + return if value.nil? + return ModelContainerSpecEnv.new(value, parent_identifier) unless value.is_a?(::Array) + value.map { |v| ModelContainerSpecEnv.new(v, parent_identifier) } + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_container_spec_ports.rb b/libraries/google/vertexai/property/model_container_spec_ports.rb new file mode 100644 index 000000000..5d8f04218 --- /dev/null +++ b/libraries/google/vertexai/property/model_container_spec_ports.rb @@ -0,0 +1,42 @@ +# 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 VertexAI + module Property + class ModelContainerSpecPorts + attr_reader :container_port + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @container_port = args['containerPort'] + end + + def to_s + "#{@parent_identifier} ModelContainerSpecPorts" + end + end + + class ModelContainerSpecPortsArray + def self.parse(value, parent_identifier) + return if value.nil? + return ModelContainerSpecPorts.new(value, parent_identifier) unless value.is_a?(::Array) + value.map { |v| ModelContainerSpecPorts.new(v, parent_identifier) } + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_deployed_models.rb b/libraries/google/vertexai/property/model_deployed_models.rb new file mode 100644 index 000000000..3bccbe30d --- /dev/null +++ b/libraries/google/vertexai/property/model_deployed_models.rb @@ -0,0 +1,45 @@ +# 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 VertexAI + module Property + class ModelDeployedModels + attr_reader :deployed_model_id + + attr_reader :endpoint + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @deployed_model_id = args['deployedModelId'] + @endpoint = args['endpoint'] + end + + def to_s + "#{@parent_identifier} ModelDeployedModels" + end + end + + class ModelDeployedModelsArray + def self.parse(value, parent_identifier) + return if value.nil? + return ModelDeployedModels.new(value, parent_identifier) unless value.is_a?(::Array) + value.map { |v| ModelDeployedModels.new(v, parent_identifier) } + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_encryption_spec.rb b/libraries/google/vertexai/property/model_encryption_spec.rb new file mode 100644 index 000000000..7a2da1849 --- /dev/null +++ b/libraries/google/vertexai/property/model_encryption_spec.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 VertexAI + module Property + class ModelEncryptionSpec + 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} ModelEncryptionSpec" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec.rb b/libraries/google/vertexai/property/model_explanation_spec.rb new file mode 100644 index 000000000..306c363f3 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec.rb @@ -0,0 +1,56 @@ +# 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/vertexai/property/model_explanation_spec_metadata' +require 'google/vertexai/property/model_explanation_spec_metadata_inputs' +require 'google/vertexai/property/model_explanation_spec_metadata_outputs' +require 'google/vertexai/property/model_explanation_spec_parameters' +require 'google/vertexai/property/model_explanation_spec_parameters_examples' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source_gcs_source' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_presets' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_blur_baseline_config' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_sampled_shapley_attribution' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_blur_baseline_config' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpec + attr_reader :parameters + + attr_reader :metadata + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @parameters = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParameters.new(args['parameters'], to_s) + @metadata = GoogleInSpec::VertexAI::Property::ModelExplanationSpecMetadata.new(args['metadata'], to_s) + end + + def to_s + "#{@parent_identifier} ModelExplanationSpec" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_metadata.rb b/libraries/google/vertexai/property/model_explanation_spec_metadata.rb new file mode 100644 index 000000000..1fc66e947 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_metadata.rb @@ -0,0 +1,45 @@ +# 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/vertexai/property/model_explanation_spec_metadata_inputs' +require 'google/vertexai/property/model_explanation_spec_metadata_outputs' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecMetadata + attr_reader :feature_attributions_schema_uri + + attr_reader :latent_space_source + + attr_reader :outputs + + attr_reader :inputs + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @feature_attributions_schema_uri = args['featureAttributionsSchemaUri'] + @latent_space_source = args['latentSpaceSource'] + @outputs = GoogleInSpec::VertexAI::Property::ModelExplanationSpecMetadataOutputs.new(args['outputs'], to_s) + @inputs = GoogleInSpec::VertexAI::Property::ModelExplanationSpecMetadataInputs.new(args['inputs'], to_s) + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecMetadata" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_metadata_inputs.rb b/libraries/google/vertexai/property/model_explanation_spec_metadata_inputs.rb new file mode 100644 index 000000000..6634607ac --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_metadata_inputs.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 VertexAI + module Property + class ModelExplanationSpecMetadataInputs + attr_reader :additional_properties + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @additional_properties = args['additionalProperties'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecMetadataInputs" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_metadata_outputs.rb b/libraries/google/vertexai/property/model_explanation_spec_metadata_outputs.rb new file mode 100644 index 000000000..3737b731d --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_metadata_outputs.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 VertexAI + module Property + class ModelExplanationSpecMetadataOutputs + attr_reader :additional_properties + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @additional_properties = args['additionalProperties'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecMetadataOutputs" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters.rb new file mode 100644 index 000000000..409ebef13 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters.rb @@ -0,0 +1,64 @@ +# 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/vertexai/property/model_explanation_spec_parameters_examples' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source_gcs_source' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_presets' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_blur_baseline_config' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_sampled_shapley_attribution' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_blur_baseline_config' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecParameters + attr_reader :output_indices + + attr_reader :examples + + attr_reader :xrai_attribution + + attr_reader :top_k + + attr_reader :integrated_gradients_attribution + + attr_reader :sampled_shapley_attribution + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @output_indices = args['outputIndices'] + @examples = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersExamples.new(args['examples'], to_s) + @xrai_attribution = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersXraiAttribution.new(args['xraiAttribution'], to_s) + @top_k = args['topK'] + @integrated_gradients_attribution = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersIntegratedGradientsAttribution.new(args['integratedGradientsAttribution'], to_s) + @sampled_shapley_attribution = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersSampledShapleyAttribution.new(args['sampledShapleyAttribution'], to_s) + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParameters" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_examples.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_examples.rb new file mode 100644 index 000000000..9576fce39 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_examples.rb @@ -0,0 +1,46 @@ +# 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/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source_gcs_source' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_presets' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecParametersExamples + attr_reader :presets + + attr_reader :neighbor_count + + attr_reader :example_gcs_source + + attr_reader :nearest_neighbor_search_config + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @presets = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersExamplesPresets.new(args['presets'], to_s) + @neighbor_count = args['neighborCount'] + @example_gcs_source = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersExamplesExampleGcsSource.new(args['exampleGcsSource'], to_s) + @nearest_neighbor_search_config = args['nearestNeighborSearchConfig'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersExamples" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source.rb new file mode 100644 index 000000000..5420546ff --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source.rb @@ -0,0 +1,38 @@ +# 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/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source_gcs_source' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecParametersExamplesExampleGcsSource + attr_reader :gcs_source + + attr_reader :data_format + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @gcs_source = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersExamplesExampleGcsSourceGcsSource.new(args['gcsSource'], to_s) + @data_format = args['dataFormat'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersExamplesExampleGcsSource" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source_gcs_source.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source_gcs_source.rb new file mode 100644 index 000000000..874de218e --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source_gcs_source.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 VertexAI + module Property + class ModelExplanationSpecParametersExamplesExampleGcsSourceGcsSource + attr_reader :uris + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @uris = args['uris'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersExamplesExampleGcsSourceGcsSource" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_examples_presets.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_examples_presets.rb new file mode 100644 index 000000000..5dbe21fe4 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_examples_presets.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 VertexAI + module Property + class ModelExplanationSpecParametersExamplesPresets + attr_reader :modality + + attr_reader :query + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @modality = args['modality'] + @query = args['query'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersExamplesPresets" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution.rb new file mode 100644 index 000000000..49f7ef267 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution.rb @@ -0,0 +1,44 @@ +# 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/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_blur_baseline_config' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecParametersIntegratedGradientsAttribution + attr_reader :step_count + + attr_reader :smooth_grad_config + + attr_reader :blur_baseline_config + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @step_count = args['stepCount'] + @smooth_grad_config = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfig.new(args['smoothGradConfig'], to_s) + @blur_baseline_config = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersIntegratedGradientsAttributionBlurBaselineConfig.new(args['blurBaselineConfig'], to_s) + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersIntegratedGradientsAttribution" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_blur_baseline_config.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_blur_baseline_config.rb new file mode 100644 index 000000000..c8b741cb8 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_blur_baseline_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 VertexAI + module Property + class ModelExplanationSpecParametersIntegratedGradientsAttributionBlurBaselineConfig + attr_reader :max_blur_sigma + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @max_blur_sigma = args['maxBlurSigma'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersIntegratedGradientsAttributionBlurBaselineConfig" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config.rb new file mode 100644 index 000000000..9937f2ba8 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config.rb @@ -0,0 +1,42 @@ +# 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/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfig + attr_reader :feature_noise_sigma + + attr_reader :noise_sigma + + attr_reader :noisy_sample_count + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @feature_noise_sigma = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfigFeatureNoiseSigma.new(args['featureNoiseSigma'], to_s) + @noise_sigma = args['noiseSigma'] + @noisy_sample_count = args['noisySampleCount'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfig" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma.rb new file mode 100644 index 000000000..95cc69672 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma.rb @@ -0,0 +1,35 @@ +# 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/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfigFeatureNoiseSigma + attr_reader :noise_sigma + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @noise_sigma = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigmaArray.parse(args['noiseSigma'], to_s) + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfigFeatureNoiseSigma" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma.rb new file mode 100644 index 000000000..bab3b620d --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma.rb @@ -0,0 +1,45 @@ +# 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 VertexAI + module Property + class ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigma + attr_reader :name + + attr_reader :sigma + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @name = args['name'] + @sigma = args['sigma'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigma" + end + end + + class ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigmaArray + def self.parse(value, parent_identifier) + return if value.nil? + return ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigma.new(value, parent_identifier) unless value.is_a?(::Array) + value.map { |v| ModelExplanationSpecParametersIntegratedGradientsAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigma.new(v, parent_identifier) } + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_sampled_shapley_attribution.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_sampled_shapley_attribution.rb new file mode 100644 index 000000000..2c9c8eb4a --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_sampled_shapley_attribution.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 VertexAI + module Property + class ModelExplanationSpecParametersSampledShapleyAttribution + attr_reader :path_count + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @path_count = args['pathCount'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersSampledShapleyAttribution" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution.rb new file mode 100644 index 000000000..e166c8b38 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution.rb @@ -0,0 +1,44 @@ +# 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/vertexai/property/model_explanation_spec_parameters_xrai_attribution_blur_baseline_config' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecParametersXraiAttribution + attr_reader :smooth_grad_config + + attr_reader :step_count + + attr_reader :blur_baseline_config + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @smooth_grad_config = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersXraiAttributionSmoothGradConfig.new(args['smoothGradConfig'], to_s) + @step_count = args['stepCount'] + @blur_baseline_config = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersXraiAttributionBlurBaselineConfig.new(args['blurBaselineConfig'], to_s) + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersXraiAttribution" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_blur_baseline_config.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_blur_baseline_config.rb new file mode 100644 index 000000000..ed390f2b5 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_blur_baseline_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 VertexAI + module Property + class ModelExplanationSpecParametersXraiAttributionBlurBaselineConfig + attr_reader :max_blur_sigma + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @max_blur_sigma = args['maxBlurSigma'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersXraiAttributionBlurBaselineConfig" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config.rb new file mode 100644 index 000000000..29f809e0d --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config.rb @@ -0,0 +1,42 @@ +# 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/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecParametersXraiAttributionSmoothGradConfig + attr_reader :feature_noise_sigma + + attr_reader :noise_sigma + + attr_reader :noisy_sample_count + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @feature_noise_sigma = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersXraiAttributionSmoothGradConfigFeatureNoiseSigma.new(args['featureNoiseSigma'], to_s) + @noise_sigma = args['noiseSigma'] + @noisy_sample_count = args['noisySampleCount'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersXraiAttributionSmoothGradConfig" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma.rb new file mode 100644 index 000000000..dd82e5894 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma.rb @@ -0,0 +1,35 @@ +# 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/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +module GoogleInSpec + module VertexAI + module Property + class ModelExplanationSpecParametersXraiAttributionSmoothGradConfigFeatureNoiseSigma + attr_reader :noise_sigma + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @noise_sigma = GoogleInSpec::VertexAI::Property::ModelExplanationSpecParametersXraiAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigmaArray.parse(args['noiseSigma'], to_s) + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersXraiAttributionSmoothGradConfigFeatureNoiseSigma" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma.rb b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma.rb new file mode 100644 index 000000000..3c5a1ed97 --- /dev/null +++ b/libraries/google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma.rb @@ -0,0 +1,45 @@ +# 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 VertexAI + module Property + class ModelExplanationSpecParametersXraiAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigma + attr_reader :name + + attr_reader :sigma + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @name = args['name'] + @sigma = args['sigma'] + end + + def to_s + "#{@parent_identifier} ModelExplanationSpecParametersXraiAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigma" + end + end + + class ModelExplanationSpecParametersXraiAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigmaArray + def self.parse(value, parent_identifier) + return if value.nil? + return ModelExplanationSpecParametersXraiAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigma.new(value, parent_identifier) unless value.is_a?(::Array) + value.map { |v| ModelExplanationSpecParametersXraiAttributionSmoothGradConfigFeatureNoiseSigmaNoiseSigma.new(v, parent_identifier) } + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_labels.rb b/libraries/google/vertexai/property/model_labels.rb new file mode 100644 index 000000000..8ea675d79 --- /dev/null +++ b/libraries/google/vertexai/property/model_labels.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 VertexAI + module Property + class ModelLabels + attr_reader :additional_properties + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @additional_properties = args['additionalProperties'] + end + + def to_s + "#{@parent_identifier} ModelLabels" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_model_source_info.rb b/libraries/google/vertexai/property/model_model_source_info.rb new file mode 100644 index 000000000..51c44f68a --- /dev/null +++ b/libraries/google/vertexai/property/model_model_source_info.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 VertexAI + module Property + class ModelModelSourceInfo + attr_reader :copy + + attr_reader :source_type + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @copy = args['copy'] + @source_type = args['sourceType'] + end + + def to_s + "#{@parent_identifier} ModelModelSourceInfo" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_original_model_info.rb b/libraries/google/vertexai/property/model_original_model_info.rb new file mode 100644 index 000000000..42ca7d842 --- /dev/null +++ b/libraries/google/vertexai/property/model_original_model_info.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 VertexAI + module Property + class ModelOriginalModelInfo + attr_reader :model + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @model = args['model'] + end + + def to_s + "#{@parent_identifier} ModelOriginalModelInfo" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_predict_schemata.rb b/libraries/google/vertexai/property/model_predict_schemata.rb new file mode 100644 index 000000000..39b1711b4 --- /dev/null +++ b/libraries/google/vertexai/property/model_predict_schemata.rb @@ -0,0 +1,40 @@ +# 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 VertexAI + module Property + class ModelPredictSchemata + attr_reader :instance_schema_uri + + attr_reader :parameters_schema_uri + + attr_reader :prediction_schema_uri + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @instance_schema_uri = args['instanceSchemaUri'] + @parameters_schema_uri = args['parametersSchemaUri'] + @prediction_schema_uri = args['predictionSchemaUri'] + end + + def to_s + "#{@parent_identifier} ModelPredictSchemata" + end + end + end + end +end diff --git a/libraries/google/vertexai/property/model_supported_export_formats.rb b/libraries/google/vertexai/property/model_supported_export_formats.rb new file mode 100644 index 000000000..555456d93 --- /dev/null +++ b/libraries/google/vertexai/property/model_supported_export_formats.rb @@ -0,0 +1,45 @@ +# 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 VertexAI + module Property + class ModelSupportedExportFormats + attr_reader :exportable_contents + + attr_reader :id + + def initialize(args = nil, parent_identifier = nil) + return if args.nil? + @parent_identifier = parent_identifier + @exportable_contents = args['exportableContents'] + @id = args['id'] + end + + def to_s + "#{@parent_identifier} ModelSupportedExportFormats" + end + end + + class ModelSupportedExportFormatsArray + def self.parse(value, parent_identifier) + return if value.nil? + return ModelSupportedExportFormats.new(value, parent_identifier) unless value.is_a?(::Array) + value.map { |v| ModelSupportedExportFormats.new(v, parent_identifier) } + end + end + end + end +end diff --git a/libraries/google_vertex_ai_model.rb b/libraries/google_vertex_ai_model.rb new file mode 100644 index 000000000..c802821d2 --- /dev/null +++ b/libraries/google_vertex_ai_model.rb @@ -0,0 +1,141 @@ +# 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/vertexai/property/model_container_spec' +require 'google/vertexai/property/model_container_spec_env' +require 'google/vertexai/property/model_container_spec_ports' +require 'google/vertexai/property/model_deployed_models' +require 'google/vertexai/property/model_encryption_spec' +require 'google/vertexai/property/model_explanation_spec' +require 'google/vertexai/property/model_explanation_spec_metadata' +require 'google/vertexai/property/model_explanation_spec_metadata_inputs' +require 'google/vertexai/property/model_explanation_spec_metadata_outputs' +require 'google/vertexai/property/model_explanation_spec_parameters' +require 'google/vertexai/property/model_explanation_spec_parameters_examples' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_example_gcs_source_gcs_source' +require 'google/vertexai/property/model_explanation_spec_parameters_examples_presets' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_blur_baseline_config' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_integrated_gradients_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_sampled_shapley_attribution' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_blur_baseline_config' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma' +require 'google/vertexai/property/model_explanation_spec_parameters_xrai_attribution_smooth_grad_config_feature_noise_sigma_noise_sigma' +require 'google/vertexai/property/model_labels' +require 'google/vertexai/property/model_model_source_info' +require 'google/vertexai/property/model_original_model_info' +require 'google/vertexai/property/model_predict_schemata' +require 'google/vertexai/property/model_supported_export_formats' + +# A provider to manage Vertex AI resources. +class VertexAIModel < GcpResourceBase + name 'google_vertex_ai_model' + desc 'Model' + supports platform: 'gcp' + + attr_reader :params + attr_reader :model_source_info + attr_reader :name + attr_reader :metadata + attr_reader :update_time + attr_reader :etag + attr_reader :description + attr_reader :deployed_models + attr_reader :create_time + attr_reader :explanation_spec + attr_reader :encryption_spec + attr_reader :pipeline_job + attr_reader :predict_schemata + attr_reader :version_update_time + attr_reader :supported_export_formats + attr_reader :original_model_info + attr_reader :metadata_artifact + attr_reader :supported_input_storage_formats + attr_reader :metadata_schema_uri + attr_reader :container_spec + attr_reader :version_id + attr_reader :artifact_uri + attr_reader :training_pipeline + attr_reader :display_name + attr_reader :supported_deployment_resources_types + attr_reader :supported_output_storage_formats + attr_reader :version_aliases + attr_reader :version_create_time + attr_reader :version_description + attr_reader :labels + + 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 + @model_source_info = GoogleInSpec::VertexAI::Property::ModelModelSourceInfo.new(@fetched['modelSourceInfo'], to_s) + @name = @fetched['name'] + @metadata = @fetched['metadata'] + @update_time = @fetched['updateTime'] + @etag = @fetched['etag'] + @description = @fetched['description'] + @deployed_models = GoogleInSpec::VertexAI::Property::ModelDeployedModelsArray.parse(@fetched['deployedModels'], to_s) + @create_time = @fetched['createTime'] + @explanation_spec = GoogleInSpec::VertexAI::Property::ModelExplanationSpec.new(@fetched['explanationSpec'], to_s) + @encryption_spec = GoogleInSpec::VertexAI::Property::ModelEncryptionSpec.new(@fetched['encryptionSpec'], to_s) + @pipeline_job = @fetched['pipelineJob'] + @predict_schemata = GoogleInSpec::VertexAI::Property::ModelPredictSchemata.new(@fetched['predictSchemata'], to_s) + @version_update_time = @fetched['versionUpdateTime'] + @supported_export_formats = GoogleInSpec::VertexAI::Property::ModelSupportedExportFormatsArray.parse(@fetched['supportedExportFormats'], to_s) + @original_model_info = GoogleInSpec::VertexAI::Property::ModelOriginalModelInfo.new(@fetched['originalModelInfo'], to_s) + @metadata_artifact = @fetched['metadataArtifact'] + @supported_input_storage_formats = @fetched['supportedInputStorageFormats'] + @metadata_schema_uri = @fetched['metadataSchemaUri'] + @container_spec = GoogleInSpec::VertexAI::Property::ModelContainerSpec.new(@fetched['containerSpec'], to_s) + @version_id = @fetched['versionId'] + @artifact_uri = @fetched['artifactUri'] + @training_pipeline = @fetched['trainingPipeline'] + @display_name = @fetched['displayName'] + @supported_deployment_resources_types = @fetched['supportedDeploymentResourcesTypes'] + @supported_output_storage_formats = @fetched['supportedOutputStorageFormats'] + @version_aliases = @fetched['versionAliases'] + @version_create_time = @fetched['versionCreateTime'] + @version_description = @fetched['versionDescription'] + @labels = GoogleInSpec::VertexAI::Property::ModelLabels.new(@fetched['labels'], to_s) + end + + def exists? + !@fetched.nil? + end + + def to_s + "Model #{@params[:name]}" + end + + private + + def product_url(_ = nil) + 'https://{{region}}-aiplatform.googleapis.com/v1/' + end + + def resource_base_url + '{{name}}' + end +end diff --git a/libraries/google_vertex_ai_models.rb b/libraries/google_vertex_ai_models.rb new file mode 100644 index 000000000..e0387b328 --- /dev/null +++ b/libraries/google_vertex_ai_models.rb @@ -0,0 +1,135 @@ +# 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 VertexAIModels < GcpResourceBase + name 'google_vertex_ai_models' + desc 'Model plural resource' + supports platform: 'gcp' + + attr_reader :table + + filter_table_config = FilterTable.create + + filter_table_config.add(:model_source_infos, field: :model_source_info) + filter_table_config.add(:names, field: :name) + filter_table_config.add(:metadata, field: :metadata) + filter_table_config.add(:update_times, field: :update_time) + filter_table_config.add(:etags, field: :etag) + filter_table_config.add(:descriptions, field: :description) + filter_table_config.add(:deployed_models, field: :deployed_models) + filter_table_config.add(:create_times, field: :create_time) + filter_table_config.add(:explanation_specs, field: :explanation_spec) + filter_table_config.add(:encryption_specs, field: :encryption_spec) + filter_table_config.add(:pipeline_jobs, field: :pipeline_job) + filter_table_config.add(:predict_schemata, field: :predict_schemata) + filter_table_config.add(:version_update_times, field: :version_update_time) + filter_table_config.add(:supported_export_formats, field: :supported_export_formats) + filter_table_config.add(:original_model_infos, field: :original_model_info) + filter_table_config.add(:metadata_artifacts, field: :metadata_artifact) + filter_table_config.add(:supported_input_storage_formats, field: :supported_input_storage_formats) + filter_table_config.add(:metadata_schema_uris, field: :metadata_schema_uri) + filter_table_config.add(:container_specs, field: :container_spec) + filter_table_config.add(:version_ids, field: :version_id) + filter_table_config.add(:artifact_uris, field: :artifact_uri) + filter_table_config.add(:training_pipelines, field: :training_pipeline) + filter_table_config.add(:display_names, field: :display_name) + filter_table_config.add(:supported_deployment_resources_types, field: :supported_deployment_resources_types) + filter_table_config.add(:supported_output_storage_formats, field: :supported_output_storage_formats) + filter_table_config.add(:version_aliases, field: :version_aliases) + filter_table_config.add(:version_create_times, field: :version_create_time) + filter_table_config.add(:version_descriptions, field: :version_description) + filter_table_config.add(:labels, field: :labels) + + filter_table_config.connect(self, :table) + + def initialize(params = {}) + super(params.merge({ use_http_transport: true })) + @params = params + @table = fetch_wrapped_resource('models') + 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 + { + 'modelSourceInfo' => ->(obj) { return :model_source_info, GoogleInSpec::VertexAI::Property::ModelModelSourceInfo.new(obj['modelSourceInfo'], to_s) }, + 'name' => ->(obj) { return :name, obj['name'] }, + 'metadata' => ->(obj) { return :metadata, obj['metadata'] }, + 'updateTime' => ->(obj) { return :update_time, obj['updateTime'] }, + 'etag' => ->(obj) { return :etag, obj['etag'] }, + 'description' => ->(obj) { return :description, obj['description'] }, + 'deployedModels' => ->(obj) { return :deployed_models, GoogleInSpec::VertexAI::Property::ModelDeployedModelsArray.parse(obj['deployedModels'], to_s) }, + 'createTime' => ->(obj) { return :create_time, obj['createTime'] }, + 'explanationSpec' => ->(obj) { return :explanation_spec, GoogleInSpec::VertexAI::Property::ModelExplanationSpec.new(obj['explanationSpec'], to_s) }, + 'encryptionSpec' => ->(obj) { return :encryption_spec, GoogleInSpec::VertexAI::Property::ModelEncryptionSpec.new(obj['encryptionSpec'], to_s) }, + 'pipelineJob' => ->(obj) { return :pipeline_job, obj['pipelineJob'] }, + 'predictSchemata' => ->(obj) { return :predict_schemata, GoogleInSpec::VertexAI::Property::ModelPredictSchemata.new(obj['predictSchemata'], to_s) }, + 'versionUpdateTime' => ->(obj) { return :version_update_time, obj['versionUpdateTime'] }, + 'supportedExportFormats' => ->(obj) { return :supported_export_formats, GoogleInSpec::VertexAI::Property::ModelSupportedExportFormatsArray.parse(obj['supportedExportFormats'], to_s) }, + 'originalModelInfo' => ->(obj) { return :original_model_info, GoogleInSpec::VertexAI::Property::ModelOriginalModelInfo.new(obj['originalModelInfo'], to_s) }, + 'metadataArtifact' => ->(obj) { return :metadata_artifact, obj['metadataArtifact'] }, + 'supportedInputStorageFormats' => ->(obj) { return :supported_input_storage_formats, obj['supportedInputStorageFormats'] }, + 'metadataSchemaUri' => ->(obj) { return :metadata_schema_uri, obj['metadataSchemaUri'] }, + 'containerSpec' => ->(obj) { return :container_spec, GoogleInSpec::VertexAI::Property::ModelContainerSpec.new(obj['containerSpec'], to_s) }, + 'versionId' => ->(obj) { return :version_id, obj['versionId'] }, + 'artifactUri' => ->(obj) { return :artifact_uri, obj['artifactUri'] }, + 'trainingPipeline' => ->(obj) { return :training_pipeline, obj['trainingPipeline'] }, + 'displayName' => ->(obj) { return :display_name, obj['displayName'] }, + 'supportedDeploymentResourcesTypes' => ->(obj) { return :supported_deployment_resources_types, obj['supportedDeploymentResourcesTypes'] }, + 'supportedOutputStorageFormats' => ->(obj) { return :supported_output_storage_formats, obj['supportedOutputStorageFormats'] }, + 'versionAliases' => ->(obj) { return :version_aliases, obj['versionAliases'] }, + 'versionCreateTime' => ->(obj) { return :version_create_time, obj['versionCreateTime'] }, + 'versionDescription' => ->(obj) { return :version_description, obj['versionDescription'] }, + 'labels' => ->(obj) { return :labels, GoogleInSpec::VertexAI::Property::ModelLabels.new(obj['labels'], to_s) }, + } + end + + private + + def product_url(_ = nil) + 'https://{{region}}-aiplatform.googleapis.com/v1/' + end + + def resource_base_url + '{{parent}}/models' + end +end diff --git a/test/integration/verify/controls/google_vertex_ai_model.rb b/test/integration/verify/controls/google_vertex_ai_model.rb new file mode 100644 index 000000000..a90e24f2c --- /dev/null +++ b/test/integration/verify/controls/google_vertex_ai_model.rb @@ -0,0 +1,65 @@ +# ---------------------------------------------------------------------------- +# +# *** 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_vertex_ai_model resource.' + +gcp_project_id = input(:gcp_project_id, value: 'gcp_project_id', description: 'The GCP project identifier.') + + model = input('model', value: { + "name": "value_name", + "region": "value_region", + "parent": "value_parent", + "update_time": "value_updatetime", + "etag": "value_etag", + "description": "value_description", + "create_time": "value_createtime", + "pipeline_job": "value_pipelinejob", + "version_update_time": "value_versionupdatetime", + "metadata_artifact": "value_metadataartifact", + "metadata_schema_uri": "value_metadataschemauri", + "version_id": "value_versionid", + "artifact_uri": "value_artifacturi", + "training_pipeline": "value_trainingpipeline", + "display_name": "value_displayname", + "version_create_time": "value_versioncreatetime", + "version_description": "value_versiondescription" +}, description: 'model description') +control 'google_vertex_ai_model-1.0' do + impact 1.0 + title 'google_vertex_ai_model resource test' + + describe google_vertex_ai_model(name: "projects/#{gcp_project_id}/locations/#{model['region']}/models/#{model['name']}", region: model['region']) do + it { should exist } + its('name') { should cmp model['name'] } + its('update_time') { should cmp model['update_time'] } + its('etag') { should cmp model['etag'] } + its('description') { should cmp model['description'] } + its('create_time') { should cmp model['create_time'] } + its('pipeline_job') { should cmp model['pipeline_job'] } + its('version_update_time') { should cmp model['version_update_time'] } + its('metadata_artifact') { should cmp model['metadata_artifact'] } + its('metadata_schema_uri') { should cmp model['metadata_schema_uri'] } + its('version_id') { should cmp model['version_id'] } + its('artifact_uri') { should cmp model['artifact_uri'] } + its('training_pipeline') { should cmp model['training_pipeline'] } + its('display_name') { should cmp model['display_name'] } + its('version_create_time') { should cmp model['version_create_time'] } + its('version_description') { should cmp model['version_description'] } + + end + + describe google_vertex_ai_model(name: "does_not_exit", region: model['region']) do + it { should_not exist } + end +end diff --git a/test/integration/verify/controls/google_vertex_ai_models.rb b/test/integration/verify/controls/google_vertex_ai_models.rb new file mode 100644 index 000000000..ce94131fd --- /dev/null +++ b/test/integration/verify/controls/google_vertex_ai_models.rb @@ -0,0 +1,45 @@ +# ---------------------------------------------------------------------------- +# +# *** 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_vertex_ai_models resource.' + +gcp_project_id = input(:gcp_project_id, value: 'gcp_project_id', description: 'The GCP project identifier.') + + model = input('model', value: { + "name": "value_name", + "region": "value_region", + "parent": "value_parent", + "update_time": "value_updatetime", + "etag": "value_etag", + "description": "value_description", + "create_time": "value_createtime", + "pipeline_job": "value_pipelinejob", + "version_update_time": "value_versionupdatetime", + "metadata_artifact": "value_metadataartifact", + "metadata_schema_uri": "value_metadataschemauri", + "version_id": "value_versionid", + "artifact_uri": "value_artifacturi", + "training_pipeline": "value_trainingpipeline", + "display_name": "value_displayname", + "version_create_time": "value_versioncreatetime", + "version_description": "value_versiondescription" +}, description: 'model description') +control 'google_vertex_ai_models-1.0' do + impact 1.0 + title 'google_vertex_ai_models resource test' + + describe google_vertex_ai_models(parent: "projects/#{gcp_project_id}/locations/#{model['region']}", region: model['region']) do + it { should exist } + end +end