202 lines
6 KiB
YAML
202 lines
6 KiB
YAML
---
|
|
# ----------------------------------------------------------------------------
|
|
#
|
|
# *** 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 network
|
|
gcp_compute_network:
|
|
name: network-vpn-tunnel
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
state: present
|
|
register: network
|
|
- name: create a router
|
|
gcp_compute_router:
|
|
name: router-vpn-tunnel
|
|
network: "{{ network }}"
|
|
bgp:
|
|
asn: 64514
|
|
advertise_mode: CUSTOM
|
|
advertised_groups:
|
|
- ALL_SUBNETS
|
|
advertised_ip_ranges:
|
|
- range: 1.2.3.4
|
|
- range: 6.7.0.0/16
|
|
region: us-central1
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
state: present
|
|
register: router
|
|
- name: create a target vpn gateway
|
|
gcp_compute_target_vpn_gateway:
|
|
name: gateway-vpn-tunnel
|
|
region: us-west1
|
|
network: "{{ network }}"
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
state: present
|
|
register: gateway
|
|
- name: delete a vpn tunnel
|
|
gcp_compute_vpn_tunnel:
|
|
name: "{{ resource_name }}"
|
|
region: us-west1
|
|
target_vpn_gateway: "{{ gateway }}"
|
|
router: "{{ router }}"
|
|
shared_secret: super secret
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
state: absent
|
|
#----------------------------------------------------------
|
|
- name: create a vpn tunnel
|
|
gcp_compute_vpn_tunnel:
|
|
name: "{{ resource_name }}"
|
|
region: us-west1
|
|
target_vpn_gateway: "{{ gateway }}"
|
|
router: "{{ router }}"
|
|
shared_secret: super secret
|
|
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
|
|
- name: verify that vpn_tunnel was created
|
|
gcp_compute_vpn_tunnel_info:
|
|
filters:
|
|
- name = {{ resource_name }}
|
|
region: us-west1
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
scopes:
|
|
- https://www.googleapis.com/auth/compute
|
|
register: results
|
|
- name: verify that command succeeded
|
|
assert:
|
|
that:
|
|
- results['resources'] | length == 1
|
|
# ----------------------------------------------------------------------------
|
|
- name: create a vpn tunnel that already exists
|
|
gcp_compute_vpn_tunnel:
|
|
name: "{{ resource_name }}"
|
|
region: us-west1
|
|
target_vpn_gateway: "{{ gateway }}"
|
|
router: "{{ router }}"
|
|
shared_secret: super secret
|
|
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
|
|
#----------------------------------------------------------
|
|
- name: delete a vpn tunnel
|
|
gcp_compute_vpn_tunnel:
|
|
name: "{{ resource_name }}"
|
|
region: us-west1
|
|
target_vpn_gateway: "{{ gateway }}"
|
|
router: "{{ router }}"
|
|
shared_secret: super secret
|
|
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
|
|
- name: verify that vpn_tunnel was deleted
|
|
gcp_compute_vpn_tunnel_info:
|
|
filters:
|
|
- name = {{ resource_name }}
|
|
region: us-west1
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
scopes:
|
|
- https://www.googleapis.com/auth/compute
|
|
register: results
|
|
- name: verify that command succeeded
|
|
assert:
|
|
that:
|
|
- results['resources'] | length == 0
|
|
# ----------------------------------------------------------------------------
|
|
- name: delete a vpn tunnel that does not exist
|
|
gcp_compute_vpn_tunnel:
|
|
name: "{{ resource_name }}"
|
|
region: us-west1
|
|
target_vpn_gateway: "{{ gateway }}"
|
|
router: "{{ router }}"
|
|
shared_secret: super secret
|
|
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
|
|
#---------------------------------------------------------
|
|
# Post-test teardown
|
|
# If errors happen, don't crash the playbook!
|
|
- name: delete a target vpn gateway
|
|
gcp_compute_target_vpn_gateway:
|
|
name: gateway-vpn-tunnel
|
|
region: us-west1
|
|
network: "{{ network }}"
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
state: absent
|
|
register: gateway
|
|
ignore_errors: true
|
|
- name: delete a router
|
|
gcp_compute_router:
|
|
name: router-vpn-tunnel
|
|
network: "{{ network }}"
|
|
bgp:
|
|
asn: 64514
|
|
advertise_mode: CUSTOM
|
|
advertised_groups:
|
|
- ALL_SUBNETS
|
|
advertised_ip_ranges:
|
|
- range: 1.2.3.4
|
|
- range: 6.7.0.0/16
|
|
region: us-central1
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
state: absent
|
|
register: router
|
|
ignore_errors: true
|
|
- name: delete a network
|
|
gcp_compute_network:
|
|
name: network-vpn-tunnel
|
|
project: "{{ gcp_project }}"
|
|
auth_kind: "{{ gcp_cred_kind }}"
|
|
service_account_file: "{{ gcp_cred_file }}"
|
|
state: absent
|
|
register: network
|
|
ignore_errors: true
|