mirror of
https://github.com/ansible-collections/community.mysql.git
synced 2025-04-06 10:40:36 -07:00
Fix privilege changing everytime (#438)
* Compare privileges from before and after manipulation * Add unit tests * Fix FIXME integration tests related to this issue * Fix sanity check * Fix assertion when appending privs in mysql_role_initial integration tests * Fix pylint * [ci-skip] Add changelog fragment * Fix: missing fragment file extension * Replace privileges_equal() by a comparison * Fix: sanity pylint * Fix: forgot to remove privileges_equal import from unit tests
This commit is contained in:
parent
ea73d408c3
commit
2d75bc19b8
4 changed files with 13 additions and 13 deletions
|
@ -0,0 +1,7 @@
|
||||||
|
---
|
||||||
|
bugfixes:
|
||||||
|
- mysql_user, mysql_role - mysql/mariadb recent versions translate 'ALL
|
||||||
|
PRIVILEGES' to a list of specific privileges. That caused a change every time
|
||||||
|
we modified user privileges. This fix compares privs before and after user
|
||||||
|
modification to avoid this infinite change
|
||||||
|
(https://github.com/ansible-collections/community.mysql/issues/77).
|
|
@ -385,7 +385,10 @@ def user_mod(cursor, user, host, host_all, password, encrypted,
|
||||||
privileges_revoke(cursor, user, host, db_table, revoke_privs, grant_option, maria_role)
|
privileges_revoke(cursor, user, host, db_table, revoke_privs, grant_option, maria_role)
|
||||||
if len(grant_privs) > 0:
|
if len(grant_privs) > 0:
|
||||||
privileges_grant(cursor, user, host, db_table, grant_privs, tls_requires, maria_role)
|
privileges_grant(cursor, user, host, db_table, grant_privs, tls_requires, maria_role)
|
||||||
changed = True
|
|
||||||
|
# after privilege manipulation, compare privileges from before and now
|
||||||
|
after_priv = privileges_get(cursor, user, host, maria_role)
|
||||||
|
changed = changed or (curr_priv != after_priv)
|
||||||
|
|
||||||
if role:
|
if role:
|
||||||
continue
|
continue
|
||||||
|
|
|
@ -1491,16 +1491,10 @@
|
||||||
priv: '{{ test_db1 }}.{{ test_table }}:SELECT,INSERT/{{ test_db2 }}.{{ test_table }}:DELETE'
|
priv: '{{ test_db1 }}.{{ test_table }}:SELECT,INSERT/{{ test_db2 }}.{{ test_table }}:DELETE'
|
||||||
append_privs: yes
|
append_privs: yes
|
||||||
|
|
||||||
# TODO it must be changed. The module uses user_mod function
|
- name: Check that there's no change
|
||||||
# taken from mysql_user module. It's a bug / expected behavior
|
|
||||||
# because I added a similar tasks to mysql_user tests
|
|
||||||
# https://github.com/ansible-collections/community.mysql/issues/50#issuecomment-871216825
|
|
||||||
# and it's also failed. Create an issue after the module is merged to avoid conflicts.
|
|
||||||
# TODO Fix this after user_mod is fixed.
|
|
||||||
- name: Check
|
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- result is changed
|
- result is not changed
|
||||||
|
|
||||||
- name: Rewrite privs
|
- name: Rewrite privs
|
||||||
<<: *task_params
|
<<: *task_params
|
||||||
|
|
|
@ -179,8 +179,6 @@
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- result is not changed
|
- result is not changed
|
||||||
when: (install_type == 'mysql' and mysql_version is version('8', '<')) or
|
|
||||||
(install_type == 'mariadb' and mariadb_version is version('10.5', '<'))
|
|
||||||
|
|
||||||
- name: remove username
|
- name: remove username
|
||||||
mysql_user:
|
mysql_user:
|
||||||
|
@ -229,8 +227,6 @@
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- result is not changed
|
- result is not changed
|
||||||
when: (install_type == 'mysql' and mysql_version is version('8', '<')) or
|
|
||||||
(install_type == 'mariadb')
|
|
||||||
|
|
||||||
- name: Collect user info by host
|
- name: Collect user info by host
|
||||||
community.mysql.mysql_info:
|
community.mysql.mysql_info:
|
||||||
|
|
Loading…
Add table
Reference in a new issue