New GCP module: gcp_bigquery_table (#50678)
This commit is contained in:
parent
263e266f68
commit
937fe2f658
5 changed files with 1740 additions and 0 deletions
1582
lib/ansible/modules/cloud/google/gcp_bigquery_table.py
Normal file
1582
lib/ansible/modules/cloud/google/gcp_bigquery_table.py
Normal file
File diff suppressed because it is too large
Load diff
2
test/integration/targets/gcp_bigquery_table/aliases
Normal file
2
test/integration/targets/gcp_bigquery_table/aliases
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
cloud/gcp
|
||||||
|
unsupported
|
|
@ -0,0 +1,3 @@
|
||||||
|
---
|
||||||
|
# defaults file
|
||||||
|
resource_name: '{{resource_prefix}}'
|
153
test/integration/targets/gcp_bigquery_table/tasks/main.yml
Normal file
153
test/integration/targets/gcp_bigquery_table/tasks/main.yml
Normal file
|
@ -0,0 +1,153 @@
|
||||||
|
---
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# *** AUTO GENERATED CODE *** AUTO GENERATED CODE ***
|
||||||
|
#
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# 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 at
|
||||||
|
# https://www.github.com/GoogleCloudPlatform/magic-modules
|
||||||
|
#
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
# Pre-test setup
|
||||||
|
- name: create a dataset
|
||||||
|
gcp_bigquery_dataset:
|
||||||
|
name: example_dataset
|
||||||
|
dataset_reference:
|
||||||
|
dataset_id: example_dataset
|
||||||
|
project: "{{ gcp_project }}"
|
||||||
|
auth_kind: "{{ gcp_cred_kind }}"
|
||||||
|
service_account_file: "{{ gcp_cred_file }}"
|
||||||
|
state: present
|
||||||
|
register: dataset
|
||||||
|
- name: delete a table
|
||||||
|
gcp_bigquery_table:
|
||||||
|
name: example_table
|
||||||
|
dataset: example_dataset
|
||||||
|
table_reference:
|
||||||
|
dataset_id: example_dataset
|
||||||
|
project_id: "{{ gcp_project }}"
|
||||||
|
table_id: example_table
|
||||||
|
project: "{{ gcp_project }}"
|
||||||
|
auth_kind: "{{ gcp_cred_kind }}"
|
||||||
|
service_account_file: "{{ gcp_cred_file }}"
|
||||||
|
state: absent
|
||||||
|
#----------------------------------------------------------
|
||||||
|
- name: create a table
|
||||||
|
gcp_bigquery_table:
|
||||||
|
name: example_table
|
||||||
|
dataset: example_dataset
|
||||||
|
table_reference:
|
||||||
|
dataset_id: example_dataset
|
||||||
|
project_id: "{{ gcp_project }}"
|
||||||
|
table_id: example_table
|
||||||
|
project: "{{ gcp_project }}"
|
||||||
|
auth_kind: "{{ gcp_cred_kind }}"
|
||||||
|
service_account_file: "{{ gcp_cred_file }}"
|
||||||
|
state: present
|
||||||
|
register: result
|
||||||
|
- name: assert changed is true
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result.changed == true
|
||||||
|
- "result.kind == 'bigquery#table'"
|
||||||
|
- name: verify that table was created
|
||||||
|
gcp_bigquery_table_facts:
|
||||||
|
dataset: example_dataset
|
||||||
|
project: "{{ gcp_project }}"
|
||||||
|
auth_kind: "{{ gcp_cred_kind }}"
|
||||||
|
service_account_file: "{{ gcp_cred_file }}"
|
||||||
|
scopes:
|
||||||
|
- https://www.googleapis.com/auth/bigquery
|
||||||
|
register: results
|
||||||
|
- name: verify that command succeeded
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- results['items'] | length >= 1
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
- name: create a table that already exists
|
||||||
|
gcp_bigquery_table:
|
||||||
|
name: example_table
|
||||||
|
dataset: example_dataset
|
||||||
|
table_reference:
|
||||||
|
dataset_id: example_dataset
|
||||||
|
project_id: "{{ gcp_project }}"
|
||||||
|
table_id: example_table
|
||||||
|
project: "{{ gcp_project }}"
|
||||||
|
auth_kind: "{{ gcp_cred_kind }}"
|
||||||
|
service_account_file: "{{ gcp_cred_file }}"
|
||||||
|
state: present
|
||||||
|
register: result
|
||||||
|
- name: assert changed is false
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result.changed == false
|
||||||
|
- "result.kind == 'bigquery#table'"
|
||||||
|
#----------------------------------------------------------
|
||||||
|
- name: delete a table
|
||||||
|
gcp_bigquery_table:
|
||||||
|
name: example_table
|
||||||
|
dataset: example_dataset
|
||||||
|
table_reference:
|
||||||
|
dataset_id: example_dataset
|
||||||
|
project_id: "{{ gcp_project }}"
|
||||||
|
table_id: example_table
|
||||||
|
project: "{{ gcp_project }}"
|
||||||
|
auth_kind: "{{ gcp_cred_kind }}"
|
||||||
|
service_account_file: "{{ gcp_cred_file }}"
|
||||||
|
state: absent
|
||||||
|
register: result
|
||||||
|
- name: assert changed is true
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result.changed == true
|
||||||
|
- result.has_key('kind') == False
|
||||||
|
- name: verify that table was deleted
|
||||||
|
gcp_bigquery_table_facts:
|
||||||
|
dataset: example_dataset
|
||||||
|
project: "{{ gcp_project }}"
|
||||||
|
auth_kind: "{{ gcp_cred_kind }}"
|
||||||
|
service_account_file: "{{ gcp_cred_file }}"
|
||||||
|
scopes:
|
||||||
|
- https://www.googleapis.com/auth/bigquery
|
||||||
|
register: results
|
||||||
|
- name: verify that command succeeded
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- results['items'] | length == 0
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
- name: delete a table that does not exist
|
||||||
|
gcp_bigquery_table:
|
||||||
|
name: example_table
|
||||||
|
dataset: example_dataset
|
||||||
|
table_reference:
|
||||||
|
dataset_id: example_dataset
|
||||||
|
project_id: "{{ gcp_project }}"
|
||||||
|
table_id: example_table
|
||||||
|
project: "{{ gcp_project }}"
|
||||||
|
auth_kind: "{{ gcp_cred_kind }}"
|
||||||
|
service_account_file: "{{ gcp_cred_file }}"
|
||||||
|
state: absent
|
||||||
|
register: result
|
||||||
|
- name: assert changed is false
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result.changed == false
|
||||||
|
- result.has_key('kind') == False
|
||||||
|
#---------------------------------------------------------
|
||||||
|
# Post-test teardown
|
||||||
|
# If errors happen, don't crash the playbook!
|
||||||
|
- name: delete a dataset
|
||||||
|
gcp_bigquery_dataset:
|
||||||
|
name: example_dataset
|
||||||
|
dataset_reference:
|
||||||
|
dataset_id: example_dataset
|
||||||
|
project: "{{ gcp_project }}"
|
||||||
|
auth_kind: "{{ gcp_cred_kind }}"
|
||||||
|
service_account_file: "{{ gcp_cred_file }}"
|
||||||
|
state: absent
|
||||||
|
register: dataset
|
||||||
|
ignore_errors: true
|
Loading…
Reference in a new issue