mirror of
https://github.com/ansible-collections/community.mysql.git
synced 2025-04-04 17:50:32 -07:00
mysql_variables: fix boolean value handling (#653)
* mysql_variables: fix boolean value handling * fix * Fix tests * Fix tests * Fix * Fix * Fix * Fix comment
This commit is contained in:
parent
33e8754c4e
commit
4912f1a41b
4 changed files with 142 additions and 0 deletions
2
changelogs/fragments/2-mysql_variables.yml
Normal file
2
changelogs/fragments/2-mysql_variables.yml
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
bugfixes:
|
||||||
|
- mysql_variables - fix the module always changes on boolean values (https://github.com/ansible-collections/community.mysql/issues/652).
|
|
@ -26,6 +26,7 @@ options:
|
||||||
value:
|
value:
|
||||||
description:
|
description:
|
||||||
- If set, then sets variable value to this.
|
- If set, then sets variable value to this.
|
||||||
|
- With boolean values, use C(0)|C(1) or quoted C("ON")|C("OFF").
|
||||||
type: str
|
type: str
|
||||||
mode:
|
mode:
|
||||||
description:
|
description:
|
||||||
|
@ -74,6 +75,11 @@ EXAMPLES = r'''
|
||||||
variable: read_only
|
variable: read_only
|
||||||
value: 1
|
value: 1
|
||||||
mode: persist
|
mode: persist
|
||||||
|
|
||||||
|
- name: Set a boolean using ON/OFF notation
|
||||||
|
mysql_variables:
|
||||||
|
variable: log_slow_replica_statements
|
||||||
|
value: "ON" # Make sure it's quoted
|
||||||
'''
|
'''
|
||||||
|
|
||||||
RETURN = r'''
|
RETURN = r'''
|
||||||
|
@ -176,6 +182,18 @@ def setvariable(cursor, mysqlvar, value, mode='global'):
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
|
def convert_bool_setting_value_wanted(val):
|
||||||
|
"""Converts passed value from 0,1,on,off to ON/OFF
|
||||||
|
as it's represented in the server.
|
||||||
|
"""
|
||||||
|
if val in ('on', 1):
|
||||||
|
val = 'ON'
|
||||||
|
elif val in ('off', 0):
|
||||||
|
val = 'OFF'
|
||||||
|
|
||||||
|
return val
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
argument_spec = mysql_common_argument_spec()
|
argument_spec = mysql_common_argument_spec()
|
||||||
argument_spec.update(
|
argument_spec.update(
|
||||||
|
@ -243,6 +261,9 @@ def main():
|
||||||
# Type values before using them
|
# Type values before using them
|
||||||
value_wanted = typedvalue(value)
|
value_wanted = typedvalue(value)
|
||||||
value_actual = typedvalue(mysqlvar_val)
|
value_actual = typedvalue(mysqlvar_val)
|
||||||
|
if value_actual in ('ON', 'OFF') and value_wanted not in ('ON', 'OFF'):
|
||||||
|
value_wanted = convert_bool_setting_value_wanted(value_wanted)
|
||||||
|
|
||||||
value_in_auto_cnf = None
|
value_in_auto_cnf = None
|
||||||
if var_in_mysqld_auto_cnf is not None:
|
if var_in_mysqld_auto_cnf is not None:
|
||||||
value_in_auto_cnf = typedvalue(var_in_mysqld_auto_cnf)
|
value_in_auto_cnf = typedvalue(var_in_mysqld_auto_cnf)
|
||||||
|
|
|
@ -287,6 +287,99 @@
|
||||||
var_name: "{{set_name}}"
|
var_name: "{{set_name}}"
|
||||||
var_value: '{{set_value}}'
|
var_value: '{{set_value}}'
|
||||||
|
|
||||||
|
#=========================================================================
|
||||||
|
# Bugfix https://github.com/ansible-collections/community.mysql/issues/652
|
||||||
|
|
||||||
|
- name: Get server version
|
||||||
|
register: result
|
||||||
|
mysql_info:
|
||||||
|
<<: *mysql_params
|
||||||
|
|
||||||
|
- name: Set variable name when running on MySQL
|
||||||
|
set_fact:
|
||||||
|
log_slow_statements: log_slow_replica_statements
|
||||||
|
when: result.server_engine == 'MySQL'
|
||||||
|
|
||||||
|
- name: Set variable name when running on MariaDB
|
||||||
|
set_fact:
|
||||||
|
log_slow_statements: log_slow_slave_statements
|
||||||
|
when: result.server_engine == 'MariaDB'
|
||||||
|
|
||||||
|
- name: Set a boolean value using ON
|
||||||
|
mysql_variables:
|
||||||
|
<<: *mysql_params
|
||||||
|
variable: "{{ log_slow_statements }}"
|
||||||
|
value: "ON"
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- name: Check that it changed
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result is changed or result.msg == "Variable is already set to requested value."
|
||||||
|
- result.msg == "Variable is already set to requested value." or result.queries == ["SET GLOBAL `{{ log_slow_statements }}` = ON"]
|
||||||
|
|
||||||
|
- name: Set a boolean value again using ON
|
||||||
|
mysql_variables:
|
||||||
|
<<: *mysql_params
|
||||||
|
variable: "{{ log_slow_statements }}"
|
||||||
|
value: "ON"
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- name: Check that it didn't change
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result is not changed
|
||||||
|
|
||||||
|
- name: Set a boolean value again using 1
|
||||||
|
mysql_variables:
|
||||||
|
<<: *mysql_params
|
||||||
|
variable: "{{ log_slow_statements }}"
|
||||||
|
value: 1
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- name: Check that it didn't change
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result is not changed
|
||||||
|
|
||||||
|
- name: Set a boolean value using OFF
|
||||||
|
mysql_variables:
|
||||||
|
<<: *mysql_params
|
||||||
|
variable: "{{ log_slow_statements }}"
|
||||||
|
value: "OFF"
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- name: Check that it changed
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result is changed
|
||||||
|
- result.queries == ["SET GLOBAL `{{ log_slow_statements }}` = OFF"]
|
||||||
|
|
||||||
|
- name: Set a boolean value again using 0
|
||||||
|
mysql_variables:
|
||||||
|
<<: *mysql_params
|
||||||
|
variable: "{{ log_slow_statements }}"
|
||||||
|
value: 0
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- name: Check that it didn't change
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result is not changed
|
||||||
|
|
||||||
|
- name: Set a boolean value using on
|
||||||
|
mysql_variables:
|
||||||
|
<<: *mysql_params
|
||||||
|
variable: "{{ log_slow_statements }}"
|
||||||
|
value: "on"
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- name: Check that it changed
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result is changed
|
||||||
|
- result.queries == ["SET GLOBAL `{{ log_slow_statements }}` = ON"]
|
||||||
|
|
||||||
#============================================================
|
#============================================================
|
||||||
# Verify mysql_variable fails with an incorrect login_password parameter
|
# Verify mysql_variable fails with an incorrect login_password parameter
|
||||||
#
|
#
|
||||||
|
|
26
tests/unit/plugins/modules/test_mysql_variables.py
Normal file
26
tests/unit/plugins/modules/test_mysql_variables.py
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
from __future__ import (absolute_import, division, print_function)
|
||||||
|
__metaclass__ = type
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
from ansible_collections.community.mysql.plugins.modules.mysql_variables import (
|
||||||
|
convert_bool_setting_value_wanted,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.parametrize(
|
||||||
|
'value,output',
|
||||||
|
[
|
||||||
|
(1, 'ON'),
|
||||||
|
(0, 'OFF'),
|
||||||
|
(2, 2),
|
||||||
|
('on', 'ON'),
|
||||||
|
('off', 'OFF'),
|
||||||
|
('ON', 'ON'),
|
||||||
|
('OFF', 'OFF'),
|
||||||
|
]
|
||||||
|
)
|
||||||
|
def test_convert_bool_value(value, output):
|
||||||
|
assert convert_bool_setting_value_wanted(value) == output
|
Loading…
Add table
Reference in a new issue