tasks: cinder_qos: Use exact match for QoS rules
The default grep behavior will match any part of the string which means that rules like 'foo' and 'foo-plus' will be matched if we are only interested in 'foo'. As such, this is causing problems with QoS rules which happen to have overlapping names. It's best to use 'grep -x' to only match the rule we are interested in. Closes-Bug: #1741990 Change-Id: I26f7f4a933e1b96ba7a92efc79f1b87c806ccdc3
This commit is contained in:
parent
f807cdccfb
commit
4a9a00fb3b
@ -17,7 +17,7 @@
|
||||
shell: |
|
||||
. {{ ansible_env.HOME }}/openrc
|
||||
CLI_OPTIONS="{{ ((keystone_service_adminuri_insecure | bool) or (cinder_service_internaluri_insecure | bool)) | ternary('--insecure','') }}"
|
||||
{{ cinder_bin }}/cinder qos-list | grep {{ item.name }} || \
|
||||
{{ cinder_bin }}/cinder qos-list | grep -x {{ item.name }} || \
|
||||
{{ cinder_bin }}/cinder qos-create {{ item.name }}\
|
||||
{% for k,v in item.options.items() %} {{ k }}={{ v }}{% endfor %}
|
||||
args:
|
||||
@ -33,8 +33,8 @@
|
||||
CLI_OPTIONS="{{ ((keystone_service_adminuri_insecure | bool) or (cinder_service_internaluri_insecure | bool)) | ternary('--insecure','') }}"
|
||||
{% for vtype in item.cinder_volume_types %}
|
||||
{{ cinder_bin }}/cinder qos-associate \
|
||||
$({{ cinder_bin }}/cinder qos-list | grep {{ item.name }} | grep -oE "{{ _UUID_regex }}") \
|
||||
$({{ cinder_bin }}/cinder type-list | grep {{ vtype }} | grep -oE "{{ _UUID_regex }}")
|
||||
$({{ cinder_bin }}/cinder qos-list | grep -x {{ item.name }} | grep -oE "{{ _UUID_regex }}") \
|
||||
$({{ cinder_bin }}/cinder type-list | grep -x {{ vtype }} | grep -oE "{{ _UUID_regex }}")
|
||||
{% endfor %}
|
||||
args:
|
||||
executable: /bin/bash
|
||||
|
Loading…
Reference in New Issue
Block a user