From 28dc527b2c2d26fa4cbbafd935c2d8a4925becef Mon Sep 17 00:00:00 2001 From: Tom Melendez Date: Fri, 4 Nov 2016 12:31:19 -0700 Subject: [PATCH] Basic integration test for gce_tag. (#17928) --- test/integration/gce.yml | 1 + .../roles/test_gce_tag/defaults/main.yml | 10 ++ .../roles/test_gce_tag/tasks/main.yml | 5 + .../roles/test_gce_tag/tasks/setup.yml | 20 +++ .../roles/test_gce_tag/tasks/teardown.yml | 18 +++ .../roles/test_gce_tag/tasks/test.yml | 133 ++++++++++++++++++ 6 files changed, 187 insertions(+) create mode 100644 test/integration/roles/test_gce_tag/defaults/main.yml create mode 100644 test/integration/roles/test_gce_tag/tasks/main.yml create mode 100644 test/integration/roles/test_gce_tag/tasks/setup.yml create mode 100644 test/integration/roles/test_gce_tag/tasks/teardown.yml create mode 100644 test/integration/roles/test_gce_tag/tasks/test.yml diff --git a/test/integration/gce.yml b/test/integration/gce.yml index e54074ef328..e5b5d80299e 100644 --- a/test/integration/gce.yml +++ b/test/integration/gce.yml @@ -5,4 +5,5 @@ - { role: test_gce_pd, tags: test_gce_pd } - { role: test_gce_mig, tags: test_gce_mig } - { role: test_gcdns, tags: test_gcdns } + - { role: test_gce_tag, tags: test_gce_tag } # TODO: tests for gce_lb, gce_net, gc_storage diff --git a/test/integration/roles/test_gce_tag/defaults/main.yml b/test/integration/roles/test_gce_tag/defaults/main.yml new file mode 100644 index 00000000000..077fd5353cf --- /dev/null +++ b/test/integration/roles/test_gce_tag/defaults/main.yml @@ -0,0 +1,10 @@ +--- +# defaults file for test_gce_tags +instance_name: "{{ resource_prefix|lower }}" +service_account_email: "{{ gce_service_account_email }}" +pem_file: "{{ gce_pem_file }}" +project_id: "{{ gce_project_id }}" +zone: "us-central1-c" +machine_type: f1-micro +image: debian-8 + diff --git a/test/integration/roles/test_gce_tag/tasks/main.yml b/test/integration/roles/test_gce_tag/tasks/main.yml new file mode 100644 index 00000000000..eb3e905d4db --- /dev/null +++ b/test/integration/roles/test_gce_tag/tasks/main.yml @@ -0,0 +1,5 @@ +--- +# test role for gce_tag +- include: setup.yml +- include: test.yml +- include: teardown.yml \ No newline at end of file diff --git a/test/integration/roles/test_gce_tag/tasks/setup.yml b/test/integration/roles/test_gce_tag/tasks/setup.yml new file mode 100644 index 00000000000..345dbce2d92 --- /dev/null +++ b/test/integration/roles/test_gce_tag/tasks/setup.yml @@ -0,0 +1,20 @@ +# GCE Tag Setup. +# ============================================================ +- name: "Create instance for executing gce_tag tests" + gce: + instance_names: "{{ instance_name }}" + machine_type: "{{ machine_type }}" + image: "{{ image }}" + zone: "{{ zone }}" + project_id: "{{ project_id }}" + pem_file: "{{ pem_file }}" + service_account_email: "{{ service_account_email }}" + state: present + register: result + +- name: assert VM created + assert: + that: + - 'result.changed' + - 'result.instance_names[0] == "{{ instance_name }}"' + - 'result.state == "present"' diff --git a/test/integration/roles/test_gce_tag/tasks/teardown.yml b/test/integration/roles/test_gce_tag/tasks/teardown.yml new file mode 100644 index 00000000000..5f47a82b7da --- /dev/null +++ b/test/integration/roles/test_gce_tag/tasks/teardown.yml @@ -0,0 +1,18 @@ +# GCE Tag Teardown. +# ============================================================ +- name: "Teardown instance used in gce_tag test" + gce: + instance_names: "{{ instance_name }}" + zone: "{{ zone }}" + project_id: "{{ project_id }}" + pem_file: "{{ pem_file }}" + service_account_email: "{{ service_account_email }}" + state: absent + register: result + +- name: assert VM removed + assert: + that: + - 'result.changed' + - 'result.instance_names[0] == "{{ instance_name }}"' + - 'result.state == "absent"' diff --git a/test/integration/roles/test_gce_tag/tasks/test.yml b/test/integration/roles/test_gce_tag/tasks/test.yml new file mode 100644 index 00000000000..a717f0f8211 --- /dev/null +++ b/test/integration/roles/test_gce_tag/tasks/test.yml @@ -0,0 +1,133 @@ +# GCE Tag Integration Tests. + +## Parameter checking tests ## +# ============================================================ +- name: "test missing param: instance_name" + gce_tag: + service_account_email: "{{ service_account_email }}" + pem_file: "{{ pem_file }}" + project_id: "{{ project_id }}" + register: result + ignore_errors: true + tags: + - param-check + +- name: "assert failure when param: instance_name missing" + assert: + that: + - 'result.failed' + - 'result.msg == "missing required arguments: instance_name"' + + +# ============================================================ +- name: "test missing param: tags" + gce_tag: + service_account_email: "{{ service_account_email }}" + pem_file: "{{ pem_file }}" + project_id: "{{ project_id }}" + zone: "{{ zone }}" + instance_name: "{{ instance_name }}" + register: result + ignore_errors: true + tags: + - param-check + +- name: "assert failure when param: tags missing" + assert: + that: + - 'result.failed' + - 'result.msg == "Must specify \"tags\""' + + +## Non-existant instance tests ## +# # ============================================================ +- name: "test tag non-existant instance (state==present)" + gce_tag: + service_account_email: "{{ service_account_email }}" + pem_file: "{{ pem_file }}" + project_id: "{{ project_id }}" + instance_name: "blahblahblah123" + zone: "{{ zone }}" + state: present + tags: foo,bar + register: result + ignore_errors: true + +- name: "assert tag failed" + assert: + that: + - 'result.failed' + +# # ============================================================ +- name: "test tag non-existant instance (state==absent)" + gce_tag: + service_account_email: "{{ service_account_email }}" + pem_file: "{{ pem_file }}" + project_id: "{{ project_id }}" + instance_name: "blahblahblah123" + zone: "{{ zone }}" + state: absent + tags: foo,bar + register: result + ignore_errors: true + +- name: "assert tag failed" + assert: + that: + - 'result.failed' + +## tagging tests ## +# # ============================================================ +- name: "test tags added (state==present)" + gce_tag: + service_account_email: "{{ service_account_email }}" + pem_file: "{{ pem_file }}" + project_id: "{{ project_id }}" + instance_name: "{{ instance_name }}" + zone: "{{ zone }}" + tags: foo,bar + state: present + register: result + +- name: "assert tag successful" + assert: + that: + - 'result.changed' + - 'result.tags|length == 2' + - 'result.tags == ["foo", "bar"]' + +# # ============================================================ +- name: "add existing tags, no change (state==present)" + gce_tag: + service_account_email: "{{ service_account_email }}" + pem_file: "{{ pem_file }}" + project_id: "{{ project_id }}" + instance_name: "{{ instance_name }}" + zone: "{{ zone }}" + tags: foo,bar + state: present + register: result + +- name: "assert tag successful" + assert: + that: + - 'result.changed == False' + - 'result.tags == None' + +# # ============================================================ +- name: "test tags removed from instance (state==absent)" + gce_tag: + service_account_email: "{{ service_account_email }}" + pem_file: "{{ pem_file }}" + project_id: "{{ project_id }}" + instance_name: "{{ instance_name }}" + zone: "{{ zone }}" + tags: foo,bar + state: absent + register: result + +- name: "assert tags removed" + assert: + that: + - 'result.changed' + - 'result.tags == ["foo", "bar"]'