mirror of
				https://github.com/ansible-collections/community.mysql.git
				synced 2025-10-26 05:50:39 -07:00 
			
		
		
		
	requested changes pt. 1
This commit is contained in:
		
					parent
					
						
							
								9a8b53dd5a
							
						
					
				
			
			
				commit
				
					
						c35bfb983b
					
				
			
		
					 4 changed files with 203 additions and 53 deletions
				
			
		|  | @ -6,6 +6,18 @@ Community MySQL Collection Release Notes | ||||||
| 
 | 
 | ||||||
| This changelog describes changes after version 2.0.0. | This changelog describes changes after version 2.0.0. | ||||||
| 
 | 
 | ||||||
|  | v3.9.0 | ||||||
|  | ====== | ||||||
|  | 
 | ||||||
|  | This is the minor release of the ``community.mysql`` collection. | ||||||
|  | This changelog contains all changes to the modules and plugins in this | ||||||
|  | collection that have been made after the previous release. | ||||||
|  | 
 | ||||||
|  | Minor Changes | ||||||
|  | ------------- | ||||||
|  | 
 | ||||||
|  | - mysql_user - add user attribute support via the ``attributes`` parameter and return value (https://github.com/ansible-collections/community.mysql/pull/604). | ||||||
|  | 
 | ||||||
| v3.8.0 | v3.8.0 | ||||||
| ====== | ====== | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -155,7 +155,7 @@ def user_add(cursor, user, host, host_all, password, encrypted, | ||||||
|              attributes, tls_requires, reuse_existing_password, module): |              attributes, tls_requires, reuse_existing_password, module): | ||||||
|     # If attributes are set, perform a sanity check to ensure server supports user attributes before creating user |     # If attributes are set, perform a sanity check to ensure server supports user attributes before creating user | ||||||
|     if attributes and not get_attribute_support(cursor): |     if attributes and not get_attribute_support(cursor): | ||||||
|         module.fail_json(msg="user attributes were specified but the mysql server does not support user attributes") |         module.fail_json(msg="user attributes were specified but the server does not support user attributes") | ||||||
| 
 | 
 | ||||||
|     # we cannot create users without a proper hostname |     # we cannot create users without a proper hostname | ||||||
|     if host_all: |     if host_all: | ||||||
|  | @ -431,15 +431,14 @@ def user_mod(cursor, user, host, host_all, password, encrypted, | ||||||
| 
 | 
 | ||||||
|         if attributes: |         if attributes: | ||||||
|             if not attribute_support: |             if not attribute_support: | ||||||
|                 module.fail_json(msg="user attributes were specified but the mysql server does not support user attributes") |                 module.fail_json(msg="user attributes were specified but the server does not support user attributes") | ||||||
|             else: |             else: | ||||||
|                 current_attributes = attributes_get(cursor, user, host) |                 current_attributes = attributes_get(cursor, user, host) | ||||||
|                 attributes_to_change = {} |                 attributes_to_change = {} | ||||||
| 
 | 
 | ||||||
|                 for key, value in attributes.items(): |                 for key, value in attributes.items(): | ||||||
|                     if key not in current_attributes or current_attributes[key] != value: |                     if key not in current_attributes or current_attributes[key] != value: | ||||||
|                         # The mysql null value (None in python) is used to delete an attribute; we use False to represent None in the attributes parameter |                         attributes_to_change[key] = value | ||||||
|                         attributes_to_change[key] = None if not value else value |  | ||||||
| 
 | 
 | ||||||
|                 if attributes_to_change: |                 if attributes_to_change: | ||||||
|                     msg = "Attributes updated: %s" % (", ".join(["%s: %s" % (key, value) for key, value in attributes_to_change.items()])) |                     msg = "Attributes updated: %s" % (", ".join(["%s: %s" % (key, value) for key, value in attributes_to_change.items()])) | ||||||
|  | @ -451,7 +450,7 @@ def user_mod(cursor, user, host, host_all, password, encrypted, | ||||||
|                     else: |                     else: | ||||||
|                         # Final if statements excludes items whose values are None in attributes_to_change, i.e. attributes that will be deleted |                         # Final if statements excludes items whose values are None in attributes_to_change, i.e. attributes that will be deleted | ||||||
|                         final_attributes = {k: v for d in (current_attributes, attributes_to_change) for k, v in d.items() if k not in attributes_to_change or |                         final_attributes = {k: v for d in (current_attributes, attributes_to_change) for k, v in d.items() if k not in attributes_to_change or | ||||||
|                                             attributes_to_change[k]} |                                             attributes_to_change[k] is not None} | ||||||
|                     changed = True |                     changed = True | ||||||
|                 else: |                 else: | ||||||
|                     final_attributes = current_attributes |                     final_attributes = current_attributes | ||||||
|  |  | ||||||
|  | @ -168,7 +168,7 @@ options: | ||||||
|     description: |     description: | ||||||
|       - "Create, update, or delete user attributes (arbitrary 'key: value' comments) for the user." |       - "Create, update, or delete user attributes (arbitrary 'key: value' comments) for the user." | ||||||
|       - MySQL server must support the INFORMATION_SCHEMA.USER_ATTRIBUTES table. Provided since MySQL 8.0. |       - MySQL server must support the INFORMATION_SCHEMA.USER_ATTRIBUTES table. Provided since MySQL 8.0. | ||||||
|       - To delete an existing attribute, set its value to False. |       - To delete an existing attribute, set its value to null. | ||||||
|     type: dict |     type: dict | ||||||
|     version_added: '3.9.0' |     version_added: '3.9.0' | ||||||
| 
 | 
 | ||||||
|  | @ -268,7 +268,7 @@ EXAMPLES = r''' | ||||||
|     name: bob |     name: bob | ||||||
|     attributes: |     attributes: | ||||||
|       foo: "foo" |       foo: "foo" | ||||||
|       bar: False |       bar: null | ||||||
| 
 | 
 | ||||||
| - name: Modify user to require TLS connection with a valid client certificate | - name: Modify user to require TLS connection with a valid client certificate | ||||||
|   community.mysql.mysql_user: |   community.mysql.mysql_user: | ||||||
|  |  | ||||||
|  | @ -11,6 +11,11 @@ | ||||||
|     - when: db_engine == 'mariadb' |     - when: db_engine == 'mariadb' | ||||||
|       block: |       block: | ||||||
| 
 | 
 | ||||||
|  |       # ============================================================ | ||||||
|  |       # Fail creating a user with mariadb | ||||||
|  |       # | ||||||
|  | 
 | ||||||
|  |       # Check mode | ||||||
|       - name: Attributes | Attempt to create user with attributes with mariadb in check mode |       - name: Attributes | Attempt to create user with attributes with mariadb in check mode | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -20,14 +25,23 @@ | ||||||
|           attributes: |           attributes: | ||||||
|             key1: "value1" |             key1: "value1" | ||||||
|         ignore_errors: yes |         ignore_errors: yes | ||||||
|         register: result |         register: result_module | ||||||
|         check_mode: yes |         check_mode: yes | ||||||
| 
 | 
 | ||||||
|       - name: Attributes | Assert that creating user with attributes fails with mariadb |       - name: Attributes | Run query to verify user creation with attributes fails with mariadb in check mode | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT user FROM mysql.user WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         ignore_errors: yes | ||||||
|  |         register: result_query | ||||||
|  | 
 | ||||||
|  |       - name: Attributes | Assert that creating user with attributes fails with mariadb in check mode | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is failed |             - result_module is failed | ||||||
|  |             - not result_query.query_result[0] | ||||||
| 
 | 
 | ||||||
|  |       # Real mode | ||||||
|       - name: Attributes | Attempt to create user with attributes with mariadb |       - name: Attributes | Attempt to create user with attributes with mariadb | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -37,17 +51,28 @@ | ||||||
|           attributes: |           attributes: | ||||||
|             key1: "value1" |             key1: "value1" | ||||||
|         ignore_errors: yes |         ignore_errors: yes | ||||||
|         register: result |         register: result_module | ||||||
|  | 
 | ||||||
|  |       - name: Attributes | Run query to verify user creation with attributes fails with mariadb | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT user FROM mysql.user WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
| 
 | 
 | ||||||
|       - name: Attributes | Assert that creating user with attributes fails with mariadb |       - name: Attributes | Assert that creating user with attributes fails with mariadb | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is failed |             - result_module is failed | ||||||
|  |             - not result_query.query_result[0] | ||||||
| 
 | 
 | ||||||
|     - when: db_engine == 'mysql' |     - when: db_engine == 'mysql' | ||||||
|       block: |       block: | ||||||
| 
 | 
 | ||||||
|  |       # ============================================================ | ||||||
|       # Create user with attributes |       # Create user with attributes | ||||||
|  |       # | ||||||
|  | 
 | ||||||
|  |       # Check mode | ||||||
|       - name: Attributes | Test creating a user with attributes in check mode |       - name: Attributes | Test creating a user with attributes in check mode | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -56,15 +81,23 @@ | ||||||
|           password: '{{ user_password_2 }}' |           password: '{{ user_password_2 }}' | ||||||
|           attributes: |           attributes: | ||||||
|             key1: "value1" |             key1: "value1" | ||||||
|         register: result |         register: result_module | ||||||
|         check_mode: yes |         check_mode: yes | ||||||
| 
 | 
 | ||||||
|  |       - name: Attributes | Run query to verify user creation did not take place in check mode | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT user FROM mysql.user WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
|  | 
 | ||||||
|       - name: Attributes | Assert that user would have been created with attributes |       - name: Attributes | Assert that user would have been created with attributes | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is changed |             - result_module is changed | ||||||
|             - result.attributes.key1 == "value1" |             - result_module.attributes.key1 == "value1" | ||||||
|  |             - not result_query.query_result[0] | ||||||
| 
 | 
 | ||||||
|  |       # Real mode | ||||||
|       - name: Attributes | Test creating a user with attributes |       - name: Attributes | Test creating a user with attributes | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -73,15 +106,26 @@ | ||||||
|           password: '{{ user_password_2 }}' |           password: '{{ user_password_2 }}' | ||||||
|           attributes: |           attributes: | ||||||
|             key1: "value1" |             key1: "value1" | ||||||
|         register: result |         register: result_module | ||||||
|  | 
 | ||||||
|  |       - name: Attributes | Run query to verify created user attributes | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
| 
 | 
 | ||||||
|       - name: Attributes | Assert that user was created with attributes |       - name: Attributes | Assert that user was created with attributes | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is changed |             - result_module is changed | ||||||
|             - result.attributes.key1 == "value1" |             - result_module.attributes.key1 == "value1" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key1'] == "value1" | ||||||
| 
 | 
 | ||||||
|  |       # ============================================================ | ||||||
|       # Append attributes on an existing user |       # Append attributes on an existing user | ||||||
|  |       # | ||||||
|  | 
 | ||||||
|  |       # Check mode | ||||||
|       - name: Attributes | Test appending attributes to an existing user in check mode |       - name: Attributes | Test appending attributes to an existing user in check mode | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -89,16 +133,24 @@ | ||||||
|           host: '%' |           host: '%' | ||||||
|           attributes: |           attributes: | ||||||
|             key2: "value2" |             key2: "value2" | ||||||
|         register: result |         register: result_module | ||||||
|         check_mode: yes |         check_mode: yes | ||||||
| 
 | 
 | ||||||
|  |       - name: Attributes | Run query to check appended attributes in check mode | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
|  | 
 | ||||||
|       - name: Attributes | Assert that attribute would have been appended and existing attribute stays |       - name: Attributes | Assert that attribute would have been appended and existing attribute stays | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is changed |             - result_module is changed | ||||||
|             - result.attributes.key1 == "value1" |             - result_module.attributes.key1 == "value1" | ||||||
|             - result.attributes.key2 == "value2" |             - result_module.attributes.key2 == "value2" | ||||||
|  |             - "'key2' not in result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml" | ||||||
| 
 | 
 | ||||||
|  |       # Real mode | ||||||
|       - name: Attributes | Test appending attributes to an existing user |       - name: Attributes | Test appending attributes to an existing user | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -106,16 +158,28 @@ | ||||||
|           host: '%' |           host: '%' | ||||||
|           attributes: |           attributes: | ||||||
|             key2: "value2" |             key2: "value2" | ||||||
|         register: result |         register: result_module | ||||||
|  | 
 | ||||||
|  |       - name: Attributes | Run query to check appended attributes | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
| 
 | 
 | ||||||
|       - name: Attributes | Assert that new attribute was appended and existing attribute stays |       - name: Attributes | Assert that new attribute was appended and existing attribute stays | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is changed |             - result_module is changed | ||||||
|             - result.attributes.key1 == "value1" |             - result_module.attributes.key1 == "value1" | ||||||
|             - result.attributes.key2 == "value2" |             - result_module.attributes.key2 == "value2" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key1'] == "value1" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key2'] == "value2" | ||||||
| 
 | 
 | ||||||
|  |       # ============================================================ | ||||||
|       # Test updating existing attributes |       # Test updating existing attributes | ||||||
|  |       # | ||||||
|  | 
 | ||||||
|  |       # Check mode | ||||||
|       - name: Attributes | Test updating attributes on an existing user in check mode |       - name: Attributes | Test updating attributes on an existing user in check mode | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -124,14 +188,22 @@ | ||||||
|           attributes: |           attributes: | ||||||
|             key2: "new_value2" |             key2: "new_value2" | ||||||
|         check_mode: yes |         check_mode: yes | ||||||
|         register: result |         register: result_module | ||||||
|  | 
 | ||||||
|  |       - name: Attributes | Run query to verify updated attribute in check mode | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
| 
 | 
 | ||||||
|       - name: Attributes | Assert that attribute would have been updated |       - name: Attributes | Assert that attribute would have been updated | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is changed |             - result_module is changed | ||||||
|             - result.attributes.key2 == "new_value2" |             - result_module.attributes.key2 == "new_value2" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key2'] == "value2" | ||||||
| 
 | 
 | ||||||
|  |       # Real mode | ||||||
|       - name: Attributes | Test updating attributes on an existing user |       - name: Attributes | Test updating attributes on an existing user | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -139,47 +211,77 @@ | ||||||
|           host: '%' |           host: '%' | ||||||
|           attributes: |           attributes: | ||||||
|             key2: "new_value2" |             key2: "new_value2" | ||||||
|         register: result |         register: result_module | ||||||
|  | 
 | ||||||
|  |       - name: Attributes | Run query to verify updated attribute | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
| 
 | 
 | ||||||
|       - name: Attributes | Assert that attribute was updated |       - name: Attributes | Assert that attribute was updated | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is changed |             - result_module is changed | ||||||
|             - result.attributes.key2 == "new_value2" |             - result_module.attributes.key2 == "new_value2" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key2'] == "new_value2" | ||||||
| 
 | 
 | ||||||
|  |       # ============================================================ | ||||||
|       # Test deleting attributes |       # Test deleting attributes | ||||||
|  |       # | ||||||
|  | 
 | ||||||
|  |       # Check mode | ||||||
|       - name: Attributes | Test deleting attributes on an existing user in check mode |       - name: Attributes | Test deleting attributes on an existing user in check mode | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|           name: '{{ user_name_2 }}' |           name: '{{ user_name_2 }}' | ||||||
|           host: '%' |           host: '%' | ||||||
|           attributes: |           attributes: | ||||||
|             key2: False |             key2: null | ||||||
|         register: result |         register: result_module | ||||||
|         check_mode: yes |         check_mode: yes | ||||||
| 
 | 
 | ||||||
|  |       - name: Attributes | Run query to verify deleted attribute in check mode | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
|  | 
 | ||||||
|       - name: Attributes | Assert that attribute would have been deleted |       - name: Attributes | Assert that attribute would have been deleted | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is changed |             - result_module is changed | ||||||
|             - "'key2' not in result.attributes" |             - "'key2' not in result_module.attributes" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key2'] == "new_value2" | ||||||
| 
 | 
 | ||||||
|  |       # Real mode | ||||||
|       - name: Attributes | Test deleting attributes on an existing user |       - name: Attributes | Test deleting attributes on an existing user | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|           name: '{{ user_name_2 }}' |           name: '{{ user_name_2 }}' | ||||||
|           host: '%' |           host: '%' | ||||||
|           attributes: |           attributes: | ||||||
|             key2: False |             key2: null | ||||||
|         register: result |         register: result_module | ||||||
|  | 
 | ||||||
|  |       - name: Attributes | Run query to verify deleted attribute | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
| 
 | 
 | ||||||
|       - name: Attributes | Assert that attribute was deleted |       - name: Attributes | Assert that attribute was deleted | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is changed |             - result_module is changed | ||||||
|             - "'key2' not in result.attributes" |             - "'key2' not in result_module.attributes" | ||||||
|  |             - "'key2' not in result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml" | ||||||
| 
 | 
 | ||||||
|       # Test attribute idempotency |       # ============================================================ | ||||||
|  |       # Test attribute idempotency when specifying attributes | ||||||
|  |       # | ||||||
|  | 
 | ||||||
|  |       # Check mode | ||||||
|       - name: Attributes | Test attribute idempotency by trying to change an already correct attribute in check mode |       - name: Attributes | Test attribute idempotency by trying to change an already correct attribute in check mode | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -187,15 +289,23 @@ | ||||||
|           host: '%' |           host: '%' | ||||||
|           attributes: |           attributes: | ||||||
|             key1: "value1" |             key1: "value1" | ||||||
|         register: result |         register: result_module | ||||||
|         check_mode: yes |         check_mode: yes | ||||||
| 
 | 
 | ||||||
|  |       - name: Attributes | Run query to verify idempotency of already correct attribute in check mode | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
|  | 
 | ||||||
|       - name: Attributes | Assert that attribute would not have been updated |       - name: Attributes | Assert that attribute would not have been updated | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is not changed |             - result_module is not changed | ||||||
|             - result.attributes.key1 == "value1" |             - result_module.attributes.key1 == "value1" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key1'] == "value1" | ||||||
| 
 | 
 | ||||||
|  |       # Real mode | ||||||
|       - name: Attributes | Test attribute idempotency by trying to change an already correct attribute |       - name: Attributes | Test attribute idempotency by trying to change an already correct attribute | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|  | @ -203,42 +313,71 @@ | ||||||
|           host: '%' |           host: '%' | ||||||
|           attributes: |           attributes: | ||||||
|             key1: "value1" |             key1: "value1" | ||||||
|         register: result |         register: result_module | ||||||
|  | 
 | ||||||
|  |       - name: Attributes | Run query to verify idempotency of already correct attribute | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
| 
 | 
 | ||||||
|       - name: Attributes | Assert that attribute was not updated |       - name: Attributes | Assert that attribute was not updated | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is not changed |             - result_module is not changed | ||||||
|             - result.attributes.key1 == "value1" |             - result_module.attributes.key1 == "value1" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key1'] == "value1" | ||||||
| 
 | 
 | ||||||
|  |       # ============================================================ | ||||||
|  |       # Test attribute idempotency when not specifying attribute parameter | ||||||
|  |       # | ||||||
|  | 
 | ||||||
|  |       # Check mode | ||||||
|       - name: Attributes | Test attribute idempotency by not specifying attribute parameter in check mode |       - name: Attributes | Test attribute idempotency by not specifying attribute parameter in check mode | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|           name: '{{ user_name_2 }}' |           name: '{{ user_name_2 }}' | ||||||
|           host: '%' |           host: '%' | ||||||
|         register: result |         register: result_module | ||||||
|         check_mode: yes |         check_mode: yes | ||||||
| 
 | 
 | ||||||
|  |       - name: Attributes | Run query to verify idempotency when not specifying attribute parameter in check mode | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
|  | 
 | ||||||
|       - name: Attributes | Assert that attribute is returned in check mode |       - name: Attributes | Assert that attribute is returned in check mode | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is not changed |             - result_module is not changed | ||||||
|             - result.attributes.key1 == "value1" |             - result_module.attributes.key1 == "value1" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key1'] == "value1" | ||||||
| 
 | 
 | ||||||
|  |       # Real mode | ||||||
|       - name: Attributes | Test attribute idempotency by not specifying attribute parameter |       - name: Attributes | Test attribute idempotency by not specifying attribute parameter | ||||||
|         mysql_user: |         mysql_user: | ||||||
|           <<: *mysql_params |           <<: *mysql_params | ||||||
|           name: '{{ user_name_2 }}' |           name: '{{ user_name_2 }}' | ||||||
|           host: '%' |           host: '%' | ||||||
|         register: result |         register: result_module | ||||||
|  | 
 | ||||||
|  |       - name: Attributes | Run query to verify idempotency when not specifying attribute parameter | ||||||
|  |         mysql_query: | ||||||
|  |           <<: *mysql_params | ||||||
|  |           query: 'SELECT attribute FROM INFORMATION_SCHEMA.USER_ATTRIBUTES WHERE user = "{{ user_name_2 }}" AND host = "%"' | ||||||
|  |         register: result_query | ||||||
| 
 | 
 | ||||||
|       - name: Attributes | Assert that attribute is returned |       - name: Attributes | Assert that attribute is returned | ||||||
|         assert: |         assert: | ||||||
|           that: |           that: | ||||||
|             - result is not changed |             - result_module is not changed | ||||||
|             - result.attributes.key1 == "value1" |             - result_module.attributes.key1 == "value1" | ||||||
|  |             - (result_query.query_result[0][0]['ATTRIBUTE'] | from_yaml)['key1'] == "value1" | ||||||
| 
 | 
 | ||||||
|  |       # ============================================================ | ||||||
|       # Cleanup |       # Cleanup | ||||||
|  |       # | ||||||
|       - include_tasks: utils/remove_user.yml |       - include_tasks: utils/remove_user.yml | ||||||
|         vars: |         vars: | ||||||
|           user_name: "{{ user_name_2 }}" |           user_name: "{{ user_name_2 }}" | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue