mirror of
https://github.com/ansible-collections/community.mysql.git
synced 2025-04-06 02:30:32 -07:00
* Add default database "mysql" to mysql_user Since permissions are stored in the "mysql" database anyway this should not change the behaviour of the module. But replication / binlog filters which rely on the current database will be able to filter the statements correctly afterwards. Prior to this change they were not executed in any database context and could not be filtered in any way by the existing methods in MySQL. * Added changelog fragment * Update changelogs/fragments/266-default-database-for-mysql-user Thanks! Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> * Update mysql_user.py Make the change a configureable boolean * Update 266-default-database-for-mysql-user update changelog fragment * Update 266-default-database-for-mysql-user it´s not a bugfix anymore * Update plugins/modules/mysql_user.py Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> * Update plugins/modules/mysql_user.py Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> * Update plugins/modules/mysql_user.py Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> * Update plugins/modules/mysql_user.py Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> * renamed new option to force_context enhanced description added tests * fixed changelog * Update plugins/modules/mysql_user.py Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> * Update plugins/modules/mysql_user.py Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> * added more tests * removed first test attempts again (from issue-28.yml) created new tests for testing with and without replication * added force_context: no testing * forgot to add the new part to main.yml * found a copy&paste issue * fix include naming * Made sure the tests work in local testing * MariaDB handles online replication filters differently * fix changelog * Update changelogs/fragments/266-default-database-for-mysql-user.yml Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> * Update changelogs/fragments/266-default-database-for-mysql-user.yml Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru>
168 lines
4.2 KiB
YAML
168 lines
4.2 KiB
YAML
---
|
|
- vars:
|
|
mysql_parameters: &mysql_params
|
|
login_user: '{{ mysql_user }}'
|
|
login_password: '{{ mysql_password }}'
|
|
login_host: 127.0.0.1
|
|
login_port: '{{ mysql_primary_port }}'
|
|
|
|
block:
|
|
- name: Drop mysql user if exists
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
name: '{{ user_name_1 }}'
|
|
state: absent
|
|
ignore_errors: yes
|
|
|
|
# Tests with force_context: yes
|
|
# Test user creation
|
|
- name: create mysql user {{user_name_1}}
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
name: '{{ user_name_1 }}'
|
|
password: '{{ user_password_1 }}'
|
|
state: present
|
|
force_context: yes
|
|
register: result
|
|
|
|
- name: assert output message mysql user was created
|
|
assert:
|
|
that:
|
|
- "result.changed == true"
|
|
|
|
- include: assert_user.yml user_name={{user_name_1}}
|
|
|
|
# Test user removal
|
|
- name: remove mysql user {{user_name_1}}
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
name: '{{user_name_1}}'
|
|
password: '{{user_password_1}}'
|
|
state: absent
|
|
force_context: yes
|
|
register: result
|
|
|
|
- name: assert output message mysql user was removed
|
|
assert:
|
|
that:
|
|
- "result.changed == true"
|
|
|
|
# Test blank user removal
|
|
- name: create blank mysql user to be removed later
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
name: ""
|
|
state: present
|
|
force_context: yes
|
|
password: 'KJFDY&D*Sfuydsgf'
|
|
|
|
- name: remove blank mysql user with hosts=all (expect changed)
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
user: ""
|
|
host_all: true
|
|
state: absent
|
|
force_context: yes
|
|
register: result
|
|
|
|
- name: assert changed is true for removing all blank users
|
|
assert:
|
|
that:
|
|
- "result.changed == true"
|
|
|
|
- name: remove blank mysql user with hosts=all (expect ok)
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
user: ""
|
|
host_all: true
|
|
force_context: yes
|
|
state: absent
|
|
register: result
|
|
|
|
- name: assert changed is true for removing all blank users
|
|
assert:
|
|
that:
|
|
- "result.changed == false"
|
|
|
|
- include: assert_no_user.yml user_name={{user_name_1}}
|
|
|
|
# Tests with force_context: no
|
|
# Test user creation
|
|
- name: Drop mysql user if exists
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
name: '{{ user_name_1 }}'
|
|
state: absent
|
|
ignore_errors: yes
|
|
|
|
# Tests with force_context: yes
|
|
# Test user creation
|
|
- name: create mysql user {{user_name_1}}
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
name: '{{ user_name_1 }}'
|
|
password: '{{ user_password_1 }}'
|
|
state: present
|
|
force_context: yes
|
|
register: result
|
|
|
|
- name: assert output message mysql user was created
|
|
assert:
|
|
that:
|
|
- "result.changed == true"
|
|
|
|
- include: assert_user.yml user_name={{user_name_1}}
|
|
|
|
# Test user removal
|
|
- name: remove mysql user {{user_name_1}}
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
name: '{{user_name_1}}'
|
|
password: '{{user_password_1}}'
|
|
state: absent
|
|
force_context: no
|
|
register: result
|
|
|
|
- name: assert output message mysql user was removed
|
|
assert:
|
|
that:
|
|
- "result.changed == true"
|
|
|
|
# Test blank user removal
|
|
- name: create blank mysql user to be removed later
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
name: ""
|
|
state: present
|
|
force_context: no
|
|
password: 'KJFDY&D*Sfuydsgf'
|
|
|
|
- name: remove blank mysql user with hosts=all (expect changed)
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
user: ""
|
|
host_all: true
|
|
state: absent
|
|
force_context: no
|
|
register: result
|
|
|
|
- name: assert changed is true for removing all blank users
|
|
assert:
|
|
that:
|
|
- "result.changed == true"
|
|
|
|
- name: remove blank mysql user with hosts=all (expect ok)
|
|
mysql_user:
|
|
<<: *mysql_params
|
|
user: ""
|
|
host_all: true
|
|
force_context: no
|
|
state: absent
|
|
register: result
|
|
|
|
- name: assert changed is true for removing all blank users
|
|
assert:
|
|
that:
|
|
- "result.changed == false"
|
|
|
|
- include: assert_no_user.yml user_name={{user_name_1}}
|