From 2b9b5f5bb79a90fa2e2fb3df31ca57a1496f951f Mon Sep 17 00:00:00 2001 From: Matt Davis Date: Fri, 5 Apr 2019 16:30:57 -0700 Subject: [PATCH] fix rediscache/firewall tests (#54933) * cleaned up tagging to prevent long-running tasks in CI --- .../azure_rm_rediscache/tasks/main.yml | 329 +++++++++--------- 1 file changed, 166 insertions(+), 163 deletions(-) diff --git a/test/integration/targets/azure_rm_rediscache/tasks/main.yml b/test/integration/targets/azure_rm_rediscache/tasks/main.yml index fe23a28b3a..72d46f7ad0 100644 --- a/test/integration/targets/azure_rm_rediscache/tasks/main.yml +++ b/test/integration/targets/azure_rm_rediscache/tasks/main.yml @@ -52,7 +52,6 @@ - facts.rediscaches[0].sku.name == 'basic' - facts.rediscaches[0].sku.size == 'C1' - - name: Update the redis cache (idempotent) azure_rm_rediscache: resource_group: "{{ resource_group }}" @@ -67,96 +66,117 @@ that: - not output.changed -# creating redis Cache costs about 20 mins async operation, -# need to poll status from Creating to Running, then able to perform updating/deleting operation, -# otherwise, will met error: -# "The resource '' is busy processing a previous update request or is undergoing system maintenance. -# As such, it is currently unable to accept the update request. Please try again later." -# comment out updating/deleting tests for test efficiency. -# - name: Update redis cache -# azure_rm_rediscache: -# resource_group: "{{ resource_group }}" -# name: "{{ redis_name }}" -# sku: -# name: basic -# size: C1 -# enable_non_ssl_port: true -# tags: -# testing: foo -# register: output +- name: long-running rediscache tests [run with `--tags long_run,untagged` to enable] + # creating redis Cache costs about 20 mins async operation, + # need to poll status from Creating to Running, then able to perform updating/deleting operation, + # otherwise, will met error: + # "The resource '' is busy processing a previous update request or is undergoing system maintenance. + # As such, it is currently unable to accept the update request. Please try again later." + block: + - name: Wait for Redis provisioning to complete + azure_rm_rediscache_facts: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}" + register: facts + until: facts.rediscaches[0]['provisioning_state'] == 'Succeeded' + retries: 30 + delay: 60 -# - name: assert output changed -# assert: -# that: -# - output.changed + - name: (actually) update redis cache + azure_rm_rediscache: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}" + sku: + name: basic + size: C1 + enable_non_ssl_port: true + tags: + testing: foo + register: output -# - name: Update redis cache configuration -# azure_rm_rediscache: -# resource_group: "{{ resource_group }}" -# name: "{{ redis_name }}" -# sku: -# name: basic -# size: C1 -# enable_non_ssl_port: true -# maxmemory_policy: allkeys_lru -# tags: -# testing: foo -# register: output + - name: assert output changed + assert: + that: + - output.changed -# - name: assert output changed -# assert: -# that: -# - output.changed + - name: Update redis cache configuration + azure_rm_rediscache: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}" + sku: + name: basic + size: C1 + enable_non_ssl_port: true + maxmemory_policy: allkeys_lru + tags: + testing: foo + register: output -# - name: Scale up the redis cache -# azure_rm_rediscache: -# resource_group: "{{ resource_group }}" -# name: "{{ redis_name }}" -# sku: -# name: standard -# size: C1 -# tags: -# testing: foo -# register: output + - name: assert output changed + assert: + that: + - output.changed -# - assert: -# that: -# - output.changed + - name: Scale up the redis cache + azure_rm_rediscache: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}" + sku: + name: standard + size: C1 + tags: + testing: foo + register: output -# - name: Force reboot redis cache -# azure_rm_rediscache: -# resource_group: "{{ resource_group }}" -# name: "{{ redis_name }}" -# reboot: -# reboot_type: all -# register: output + - assert: + that: + - output.changed -# - assert: -# that: -# - output.changed + - name: Wait for Redis provisioning to complete + azure_rm_rediscache_facts: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}" + register: facts + until: facts.rediscaches[0]['provisioning_state'] == 'Succeeded' + retries: 30 + delay: 60 -# - name: Delete the redis cache (Check Mode) -# azure_rm_rediscache: -# resource_group: "{{ resource_group }}" -# name: "{{ redis_name }}" -# state: absent -# check_mode: yes -# register: output + - name: Force reboot redis cache + azure_rm_rediscache: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}" + reboot: + reboot_type: all + register: output -# - name: assert deleting redis cache check mode -# assert: -# that: output.changed + - assert: + that: + - output.changed -# - name: Delete the redis cache -# azure_rm_rediscache: -# resource_group: "{{ resource_group }}" -# name: "{{ redis_name }}" -# state: absent -# register: output + - name: Delete the redis cache (Check Mode) + azure_rm_rediscache: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}" + state: absent + check_mode: yes + register: output + + - name: assert deleting redis cache check mode + assert: + that: output.changed + + - name: Delete the redis cache + azure_rm_rediscache: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}" + state: absent + register: output + + - assert: + that: + - output.changed + tags: [long_run, never] -# - assert: -# that: -# - output.changed - name: Create virtual network azure_rm_virtualnetwork: @@ -203,17 +223,6 @@ - facts.rediscaches[0].subnet != None - facts.rediscaches[0].access_keys.primary != None -- name: Wait for Redis provisioning to complete - azure_rm_rediscache_facts: - resource_group: "{{ resource_group }}" - name: "{{ redis_name }}2" - register: facts - until: "{{ facts.rediscaches[0]['provisioning_state'] == 'Succeeded' }}" - retries: 30 - delay: 60 - tags: - - long_run - - name: Create firewall rule (Check mode) azure_rm_rediscachefirewallrule: resource_group: "{{ resource_group }}" @@ -229,89 +238,83 @@ that: - output.changed + +- name: long-running rediscachefirewallrule tests [run with `--tags long_run,untagged` to enable] # Creating firewall rule need Redis status is running, while creating redis Cache costs about 20 mins async operation, # need to poll status from Creating to Running, then able to perform firewall rule creating, # otherwise, will met error: # "Error creating/updating Firewall rule of Azure Cache for Redis: Azure Error: Conflict\nMessage: The resource # '/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/resourceGroups/myResourceGroup/providers/Microsoft.Cache/Redis/myRedis' is busy processing # a previous update request or is undergoing system maintenance. As such, it is currently unable to accept the update request. Please try again later." -# comment out firewall rule tests for test efficiency. -- name: Create firewall rule - azure_rm_rediscachefirewallrule: - resource_group: "{{ resource_group }}" - cache_name: "{{ redis_name }}2" - name: "{{ rule_name }}" - start_ip_address: 192.168.1.1 - end_ip_address: 192.168.1.4 - register: output - tags: - - long_run + block: + - name: Wait for Redis provisioning to complete + azure_rm_rediscache_facts: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}2" + register: facts + until: facts.rediscaches[0]['provisioning_state'] == 'Succeeded' + retries: 30 + delay: 60 -- name: Assert creation - assert: - that: - - output.changed - - output.id - tags: - - long_run + - name: Create firewall rule + azure_rm_rediscachefirewallrule: + resource_group: "{{ resource_group }}" + cache_name: "{{ redis_name }}2" + name: "{{ rule_name }}" + start_ip_address: 192.168.1.1 + end_ip_address: 192.168.1.4 + register: output -- name: Update firewall rule idempotence - azure_rm_rediscachefirewallrule: - resource_group: "{{ resource_group }}" - cache_name: "{{ redis_name }}2" - name: "{{ rule_name }}" - start_ip_address: 192.168.1.1 - end_ip_address: 192.168.1.4 - register: output - tags: - - long_run + - name: Assert creation + assert: + that: + - output.changed + - output.id -- name: Assert idempotence - assert: - that: - - output.changed == False - tags: - - long_run + - name: Update firewall rule idempotence + azure_rm_rediscachefirewallrule: + resource_group: "{{ resource_group }}" + cache_name: "{{ redis_name }}2" + name: "{{ rule_name }}" + start_ip_address: 192.168.1.1 + end_ip_address: 192.168.1.4 + register: output -- name: Update firewall rule - azure_rm_rediscachefirewallrule: - resource_group: "{{ resource_group }}" - cache_name: "{{ redis_name }}2" - name: "{{ rule_name }}" - end_ip_address: 192.168.1.5 - register: output - tags: - - long_run + - name: Assert idempotence + assert: + that: + - output.changed == False -- name: Assert updating - assert: - that: - - output.changed - tags: - - long_run + - name: Update firewall rule + azure_rm_rediscachefirewallrule: + resource_group: "{{ resource_group }}" + cache_name: "{{ redis_name }}2" + name: "{{ rule_name }}" + end_ip_address: 192.168.1.5 + register: output -- name: Delete firewall rule - azure_rm_rediscachefirewallrule: - resource_group: "{{ resource_group }}" - cache_name: "{{ redis_name }}2" - name: "{{ rule_name }}" - state: absent - register: output - tags: - - long_run + - name: Assert updating + assert: + that: + - output.changed -- name: Assert deletion - assert: - that: - - output.changed - tags: - - long_run + - name: Delete firewall rule + azure_rm_rediscachefirewallrule: + resource_group: "{{ resource_group }}" + cache_name: "{{ redis_name }}2" + name: "{{ rule_name }}" + state: absent + register: output -- name: Delete the redis cache - azure_rm_rediscache: - resource_group: "{{ resource_group }}" - name: "{{ redis_name }}2" - state: absent - register: output - tags: - - long_run + - name: Assert deletion + assert: + that: + - output.changed + + - name: Delete the redis cache + azure_rm_rediscache: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}2" + state: absent + register: output + tags: [long_run, never] \ No newline at end of file