mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
added module mssql_script (#3557)
* added module mssql_script * Add changelog fragment * fixed fragment file (yamllint) * added me as maintainer * minor cleanup. (PR comments) * adjusted for PR comments - changed key for query results depending on output - removed "empty" string defaults * convert unserializable values to string * python 2 support * Apply suggestions from code review Co-authored-by: Felix Fontein <felix@fontein.de> * updates to docs Co-authored-by: Felix Fontein <felix@fontein.de> Co-authored-by: Felix Fontein <felix@fontein.de>
This commit is contained in:
parent
c40db6789a
commit
3a2f52c1db
6 changed files with 538 additions and 0 deletions
3
.github/BOTMETA.yml
vendored
3
.github/BOTMETA.yml
vendored
|
@ -480,6 +480,9 @@ files:
|
||||||
$modules/database/mssql/mssql_db.py:
|
$modules/database/mssql/mssql_db.py:
|
||||||
maintainers: vedit Jmainguy kenichi-ogawa-1988
|
maintainers: vedit Jmainguy kenichi-ogawa-1988
|
||||||
labels: mssql_db
|
labels: mssql_db
|
||||||
|
$modules/database/mssql/mssql_script.py:
|
||||||
|
maintainers: kbudde
|
||||||
|
labels: mssql_script
|
||||||
$modules/database/saphana/hana_query.py:
|
$modules/database/saphana/hana_query.py:
|
||||||
maintainers: rainerleber
|
maintainers: rainerleber
|
||||||
$modules/database/vertica/:
|
$modules/database/vertica/:
|
||||||
|
|
301
plugins/modules/database/mssql/mssql_script.py
Normal file
301
plugins/modules/database/mssql/mssql_script.py
Normal file
|
@ -0,0 +1,301 @@
|
||||||
|
#!/usr/bin/python
|
||||||
|
|
||||||
|
# Copyright: (c) 2021, Kris Budde <kris@budd.ee
|
||||||
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||||
|
|
||||||
|
from __future__ import (absolute_import, division, print_function)
|
||||||
|
__metaclass__ = type
|
||||||
|
|
||||||
|
DOCUMENTATION = r'''
|
||||||
|
---
|
||||||
|
module: mssql_script
|
||||||
|
|
||||||
|
short_description: Execute SQL scripts on a MSSQL database
|
||||||
|
|
||||||
|
version_added: "4.0.0"
|
||||||
|
|
||||||
|
description:
|
||||||
|
- Execute SQL scripts on a MSSQL database.
|
||||||
|
|
||||||
|
options:
|
||||||
|
name:
|
||||||
|
description: Database to run script against.
|
||||||
|
aliases: [ db ]
|
||||||
|
default: ''
|
||||||
|
type: str
|
||||||
|
login_user:
|
||||||
|
description: The username used to authenticate with.
|
||||||
|
type: str
|
||||||
|
login_password:
|
||||||
|
description: The password used to authenticate with.
|
||||||
|
type: str
|
||||||
|
login_host:
|
||||||
|
description: Host running the database.
|
||||||
|
type: str
|
||||||
|
required: true
|
||||||
|
login_port:
|
||||||
|
description: Port of the MSSQL server. Requires I(login_host) be defined as well.
|
||||||
|
default: 1433
|
||||||
|
type: int
|
||||||
|
script:
|
||||||
|
description:
|
||||||
|
- The SQL script to be executed.
|
||||||
|
- Script can contain multiple SQL statements. Multiple Batches can be separated by C(GO) command.
|
||||||
|
- Each batch must return at least one result set.
|
||||||
|
required: true
|
||||||
|
type: str
|
||||||
|
output:
|
||||||
|
description:
|
||||||
|
- With C(default) each row will be returned as a list of values. See C(query_results).
|
||||||
|
- Output format C(dict) will return dictionary with the column names as keys. See C(query_results_dict).
|
||||||
|
- C(dict) requires named columns to be returned by each query otherwise an error is thrown.
|
||||||
|
choices: [ "dict", "default" ]
|
||||||
|
default: 'default'
|
||||||
|
type: str
|
||||||
|
params:
|
||||||
|
description: |
|
||||||
|
Parameters passed to the script as SQL parameters. ('SELECT %(name)s"' with C(example: '{"name": "John Doe"}).)'
|
||||||
|
type: dict
|
||||||
|
notes:
|
||||||
|
- Requires the pymssql Python package on the remote host. For Ubuntu, this
|
||||||
|
is as easy as C(pip install pymssql) (See M(ansible.builtin.pip).)
|
||||||
|
requirements:
|
||||||
|
- python >= 2.7
|
||||||
|
- pymssql
|
||||||
|
|
||||||
|
author:
|
||||||
|
- Kris Budde (@kbudde)
|
||||||
|
'''
|
||||||
|
|
||||||
|
EXAMPLES = r'''
|
||||||
|
- name: Check DB connection
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
db: master
|
||||||
|
script: "SELECT 1"
|
||||||
|
|
||||||
|
- name: Query with parameter
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: |
|
||||||
|
SELECT name, state_desc FROM sys.databases WHERE name = %(dbname)s
|
||||||
|
params:
|
||||||
|
dbname: msdb
|
||||||
|
register: result_params
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- result_params.query_results[0][0][0][0] == 'msdb'
|
||||||
|
- result_params.query_results[0][0][0][1] == 'ONLINE'
|
||||||
|
|
||||||
|
- name: two batches with default output
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: |
|
||||||
|
SELECT 'Batch 0 - Select 0'
|
||||||
|
SELECT 'Batch 0 - Select 1'
|
||||||
|
GO
|
||||||
|
SELECT 'Batch 1 - Select 0'
|
||||||
|
register: result_batches
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- result_batches.query_results | length == 2 # two batch results
|
||||||
|
- result_batches.query_results[0] | length == 2 # two selects in first batch
|
||||||
|
- result_batches.query_results[0][0] | length == 1 # one row in first select
|
||||||
|
- result_batches.query_results[0][0][0] | length == 1 # one column in first row
|
||||||
|
- result_batches.query_results[0][0][0][0] == 'Batch 0 - Select 0' # each row contains a list of values.
|
||||||
|
|
||||||
|
- name: two batches with dict output
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
output: dict
|
||||||
|
script: |
|
||||||
|
SELECT 'Batch 0 - Select 0' as b0s0
|
||||||
|
SELECT 'Batch 0 - Select 1' as b0s1
|
||||||
|
GO
|
||||||
|
SELECT 'Batch 1 - Select 0' as b1s0
|
||||||
|
register: result_batches_dict
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- result_batches_dict.query_results_dict | length == 2 # two batch results
|
||||||
|
- result_batches_dict.query_results_dict[0] | length == 2 # two selects in first batch
|
||||||
|
- result_batches_dict.query_results_dict[0][0] | length == 1 # one row in first select
|
||||||
|
- result_batches_dict.query_results_dict[0][0][0]['b0s0'] == 'Batch 0 - Select 0' # column 'b0s0' of first row
|
||||||
|
'''
|
||||||
|
|
||||||
|
RETURN = r'''
|
||||||
|
query_results:
|
||||||
|
description: List of batches (queries separated by C(GO) keyword).
|
||||||
|
type: list
|
||||||
|
elements: list
|
||||||
|
returned: success and I(output=default)
|
||||||
|
sample: [[[["Batch 0 - Select 0"]], [["Batch 0 - Select 1"]]], [[["Batch 1 - Select 0"]]]]
|
||||||
|
contains:
|
||||||
|
queries:
|
||||||
|
description:
|
||||||
|
- List of result sets of each query.
|
||||||
|
- If a query returns no results, the results of this and all the following queries will not be included in the output.
|
||||||
|
- Use the C(GO) keyword in I(script) to separate queries.
|
||||||
|
type: list
|
||||||
|
elements: list
|
||||||
|
contains:
|
||||||
|
rows:
|
||||||
|
description: List of rows returned by query.
|
||||||
|
type: list
|
||||||
|
elements: list
|
||||||
|
contains:
|
||||||
|
column_value:
|
||||||
|
description:
|
||||||
|
- List of column values.
|
||||||
|
- Any non-standard JSON type is converted to string.
|
||||||
|
type: list
|
||||||
|
example: ["Batch 0 - Select 0"]
|
||||||
|
returned: success, if output is default
|
||||||
|
query_results_dict:
|
||||||
|
description: List of batches (queries separated by C(GO) keyword).
|
||||||
|
type: list
|
||||||
|
elements: list
|
||||||
|
returned: success and I(output=dict)
|
||||||
|
sample: [[[["Batch 0 - Select 0"]], [["Batch 0 - Select 1"]]], [[["Batch 1 - Select 0"]]]]
|
||||||
|
contains:
|
||||||
|
queries:
|
||||||
|
description:
|
||||||
|
- List of result sets of each query.
|
||||||
|
- If a query returns no results, the results of this and all the following queries will not be included in the output.
|
||||||
|
Use 'GO' keyword to separate queries.
|
||||||
|
type: list
|
||||||
|
elements: list
|
||||||
|
contains:
|
||||||
|
rows:
|
||||||
|
description: List of rows returned by query.
|
||||||
|
type: list
|
||||||
|
elements: list
|
||||||
|
contains:
|
||||||
|
column_dict:
|
||||||
|
description:
|
||||||
|
- Dictionary of column names and values.
|
||||||
|
- Any non-standard JSON type is converted to string.
|
||||||
|
type: dict
|
||||||
|
example: {"col_name": "Batch 0 - Select 0"}
|
||||||
|
returned: success, if output is dict
|
||||||
|
'''
|
||||||
|
|
||||||
|
from ansible.module_utils.basic import AnsibleModule, missing_required_lib
|
||||||
|
import traceback
|
||||||
|
import json
|
||||||
|
PYMSSQL_IMP_ERR = None
|
||||||
|
try:
|
||||||
|
import pymssql
|
||||||
|
except ImportError:
|
||||||
|
PYMSSQL_IMP_ERR = traceback.format_exc()
|
||||||
|
MSSQL_FOUND = False
|
||||||
|
else:
|
||||||
|
MSSQL_FOUND = True
|
||||||
|
|
||||||
|
|
||||||
|
def clean_output(o):
|
||||||
|
return str(o)
|
||||||
|
|
||||||
|
|
||||||
|
def run_module():
|
||||||
|
module_args = dict(
|
||||||
|
name=dict(required=False, aliases=['db'], default=''),
|
||||||
|
login_user=dict(),
|
||||||
|
login_password=dict(no_log=True),
|
||||||
|
login_host=dict(required=True),
|
||||||
|
login_port=dict(type='int', default=1433),
|
||||||
|
script=dict(required=True),
|
||||||
|
output=dict(default='default', choices=['dict', 'default']),
|
||||||
|
params=dict(type='dict'),
|
||||||
|
)
|
||||||
|
|
||||||
|
result = dict(
|
||||||
|
changed=False,
|
||||||
|
)
|
||||||
|
|
||||||
|
module = AnsibleModule(
|
||||||
|
argument_spec=module_args,
|
||||||
|
supports_check_mode=True
|
||||||
|
)
|
||||||
|
if not MSSQL_FOUND:
|
||||||
|
module.fail_json(msg=missing_required_lib(
|
||||||
|
'pymssql'), exception=PYMSSQL_IMP_ERR)
|
||||||
|
|
||||||
|
db = module.params['name']
|
||||||
|
login_user = module.params['login_user']
|
||||||
|
login_password = module.params['login_password']
|
||||||
|
login_host = module.params['login_host']
|
||||||
|
login_port = module.params['login_port']
|
||||||
|
script = module.params['script']
|
||||||
|
output = module.params['output']
|
||||||
|
sql_params = module.params['params']
|
||||||
|
|
||||||
|
login_querystring = login_host
|
||||||
|
if login_port != 1433:
|
||||||
|
login_querystring = "%s:%s" % (login_host, login_port)
|
||||||
|
|
||||||
|
if login_user is not None and login_password is None:
|
||||||
|
module.fail_json(
|
||||||
|
msg="when supplying login_user argument, login_password must also be provided")
|
||||||
|
|
||||||
|
try:
|
||||||
|
conn = pymssql.connect(
|
||||||
|
user=login_user, password=login_password, host=login_querystring, database=db)
|
||||||
|
cursor = conn.cursor()
|
||||||
|
except Exception as e:
|
||||||
|
if "Unknown database" in str(e):
|
||||||
|
errno, errstr = e.args
|
||||||
|
module.fail_json(msg="ERROR: %s %s" % (errno, errstr))
|
||||||
|
else:
|
||||||
|
module.fail_json(msg="unable to connect, check login_user and login_password are correct, or alternatively check your "
|
||||||
|
"@sysconfdir@/freetds.conf / ${HOME}/.freetds.conf")
|
||||||
|
|
||||||
|
conn.autocommit(True)
|
||||||
|
|
||||||
|
query_results_key = 'query_results'
|
||||||
|
if output == 'dict':
|
||||||
|
cursor = conn.cursor(as_dict=True)
|
||||||
|
query_results_key = 'query_results_dict'
|
||||||
|
|
||||||
|
queries = script.split('\nGO\n')
|
||||||
|
result['changed'] = True
|
||||||
|
if module.check_mode:
|
||||||
|
module.exit_json(**result)
|
||||||
|
|
||||||
|
query_results = []
|
||||||
|
try:
|
||||||
|
for query in queries:
|
||||||
|
cursor.execute(query, sql_params)
|
||||||
|
qry_result = []
|
||||||
|
rows = cursor.fetchall()
|
||||||
|
while rows:
|
||||||
|
qry_result.append(rows)
|
||||||
|
rows = cursor.fetchall()
|
||||||
|
query_results.append(qry_result)
|
||||||
|
except Exception as e:
|
||||||
|
return module.fail_json(msg="query failed", query=query, error=str(e), **result)
|
||||||
|
|
||||||
|
# ensure that the result is json serializable
|
||||||
|
qry_results = json.loads(json.dumps(query_results, default=clean_output))
|
||||||
|
|
||||||
|
result[query_results_key] = qry_results
|
||||||
|
module.exit_json(**result)
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
run_module()
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
1
plugins/modules/mssql_script.py
Symbolic link
1
plugins/modules/mssql_script.py
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
./database/mssql/mssql_script.py
|
5
tests/integration/targets/mssql_script/aliases
Normal file
5
tests/integration/targets/mssql_script/aliases
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
skip/osx
|
||||||
|
skip/macos
|
||||||
|
skip/freebsd
|
||||||
|
skip/rhel
|
||||||
|
disabled
|
4
tests/integration/targets/mssql_script/defaults/main.yml
Normal file
4
tests/integration/targets/mssql_script/defaults/main.yml
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
mssql_host: localhost
|
||||||
|
mssql_port: 14330
|
||||||
|
mssql_login_user: sa
|
||||||
|
mssql_login_password: "yourStrong(!)Password"
|
224
tests/integration/targets/mssql_script/tasks/main.yml
Normal file
224
tests/integration/targets/mssql_script/tasks/main.yml
Normal file
|
@ -0,0 +1,224 @@
|
||||||
|
####################################################################
|
||||||
|
# WARNING: These are designed specifically for Ansible tests #
|
||||||
|
# and should not be used as examples of how to write Ansible roles #
|
||||||
|
####################################################################
|
||||||
|
|
||||||
|
# TODO: Find out how to setup mssql server for tests
|
||||||
|
# For the moment you have to run the tests locally
|
||||||
|
# docker run --name mssql-test -e "ACCEPT_EULA=Y" -e 'SA_PASSWORD={{ mssql_login_password }}' -p "{ mssql_port }"0:"{ mssql_port }" -d mcr.microsoft.com/mssql/server:2019-latest
|
||||||
|
# ansible-test integration mssql_script -v --allow-disabled
|
||||||
|
|
||||||
|
- name: Check default ports
|
||||||
|
wait_for:
|
||||||
|
host: "{{ mssql_host }}"
|
||||||
|
port: "{{ mssql_port }}"
|
||||||
|
state: started # Port should be open
|
||||||
|
delay: 0 # No wait before first check (sec)
|
||||||
|
timeout: 3 # Stop checking after timeout (sec)
|
||||||
|
|
||||||
|
- name: Check DB connection
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: "SELECT 1"
|
||||||
|
|
||||||
|
- name: two batches with default output
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: |
|
||||||
|
SELECT 'Batch 0 - Select 0'
|
||||||
|
SELECT 'Batch 0 - Select 1'
|
||||||
|
GO
|
||||||
|
SELECT 'Batch 1 - Select 0'
|
||||||
|
register: result_batches
|
||||||
|
# "result_batches.query_results":
|
||||||
|
# [ # batches
|
||||||
|
# [ # selects
|
||||||
|
# [ # Rows
|
||||||
|
# [ # Columns
|
||||||
|
# "Batch 1 - Select 1"
|
||||||
|
# ]
|
||||||
|
# ],
|
||||||
|
# [
|
||||||
|
# [
|
||||||
|
# "Batch 1 - Select 2"
|
||||||
|
# ]
|
||||||
|
# ]
|
||||||
|
# ],
|
||||||
|
# [
|
||||||
|
# [
|
||||||
|
# [
|
||||||
|
# "Batch 2 - Select 1"
|
||||||
|
# ]
|
||||||
|
# ]
|
||||||
|
# ]
|
||||||
|
# ]
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- result_batches.query_results | length == 2 # two batch results
|
||||||
|
- result_batches.query_results[0] | length == 2 # two selects in first batch
|
||||||
|
- result_batches.query_results[0][0] | length == 1 # one row in first select
|
||||||
|
- result_batches.query_results[0][0][0] | length == 1 # one column in first row
|
||||||
|
- result_batches.query_results[0][0][0][0] == 'Batch 0 - Select 0' # first column of first row
|
||||||
|
|
||||||
|
|
||||||
|
- name: two batches with dict output
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
output: dict
|
||||||
|
script: |
|
||||||
|
SELECT 'Batch 0 - Select 0' as b0s0
|
||||||
|
SELECT 'Batch 0 - Select 1' as b0s1
|
||||||
|
GO
|
||||||
|
SELECT 'Batch 1 - Select 0' as b1s0
|
||||||
|
register: result_batches_dict
|
||||||
|
# "result_batches_dict.query_results":
|
||||||
|
# [ # batches
|
||||||
|
# [ # selects
|
||||||
|
# [ # Rows
|
||||||
|
# { # dict columns
|
||||||
|
# "b0s0": "Batch 0 - Select 0"
|
||||||
|
# }
|
||||||
|
# ],
|
||||||
|
# [
|
||||||
|
# {
|
||||||
|
# "b0s1": "Batch 0 - Select 1"
|
||||||
|
# }
|
||||||
|
# ]
|
||||||
|
# ],
|
||||||
|
# [
|
||||||
|
# [
|
||||||
|
# {
|
||||||
|
# "b1s0": "Batch 1 - Select 0"
|
||||||
|
# }
|
||||||
|
# ]
|
||||||
|
# ]
|
||||||
|
# ]
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- result_batches_dict.query_results_dict | length == 2 # two batch results
|
||||||
|
- result_batches_dict.query_results_dict[0] | length == 2 # two selects in first batch
|
||||||
|
- result_batches_dict.query_results_dict[0][0] | length == 1 # one row in first select
|
||||||
|
- result_batches_dict.query_results_dict[0][0][0]['b0s0'] == 'Batch 0 - Select 0' # column 'b0s0' of first row
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
- name: Stored procedure may return multiple result sets
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: sp_spaceused
|
||||||
|
output: dict
|
||||||
|
register: result_spaceused
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- result_spaceused.query_results_dict | length == 1 # one batch
|
||||||
|
- result_spaceused.query_results_dict[0] | length == 2 # stored procedure returns two result sets
|
||||||
|
- result_spaceused.query_results_dict[0][0][0]['database_name'] == 'master' # output dict
|
||||||
|
|
||||||
|
- name: Ensure that passed 'db' is used
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: exec sp_spaceused
|
||||||
|
output: dict
|
||||||
|
db: msdb
|
||||||
|
register: result_db
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- result_db.query_results_dict[0][0][0]['database_name'] == 'msdb'
|
||||||
|
|
||||||
|
- name: pass params to query
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: |
|
||||||
|
SELECT name, state_desc FROM sys.databases WHERE name = %(dbname)s
|
||||||
|
params:
|
||||||
|
dbname: msdb
|
||||||
|
register: result_params
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- result_params.query_results[0][0][0][0] == 'msdb'
|
||||||
|
- result_params.query_results[0][0][0][1] == 'ONLINE'
|
||||||
|
|
||||||
|
- name: check_mode connects but does not run the query
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: SELECT Invalid_Column FROM Does_Not_Exist WITH Invalid Syntax
|
||||||
|
check_mode: yes
|
||||||
|
register: check_mode
|
||||||
|
- assert:
|
||||||
|
that: check_mode.query_results is undefined
|
||||||
|
|
||||||
|
- name: "Test: Value of unknown type: <class 'uuid.UUID'>"
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: |
|
||||||
|
SELECT service_broker_guid, * FROM sys.databases WHERE name = 'master'
|
||||||
|
register: result_databases
|
||||||
|
- debug:
|
||||||
|
var: result_databases
|
||||||
|
- name: check types
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- result_databases.query_results[0][0][0][0] == '00000000-0000-0000-0000-000000000000' # guid
|
||||||
|
- result_databases.query_results[0][0][0][1] == 'master' # string
|
||||||
|
- result_databases.query_results[0][0][0][3] == None # byte string representation
|
||||||
|
- result_databases.query_results[0][0][0][4] == "b'\\x01'" # byte string representation
|
||||||
|
- result_databases.query_results[0][0][0][6] == 150 # int
|
||||||
|
- result_databases.query_results[0][0][0][10] == false # bool
|
||||||
|
|
||||||
|
- name: "Test: Value of unknown type: <class 'uuid.UUID'>-dict"
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
output: dict
|
||||||
|
script: |
|
||||||
|
SELECT service_broker_guid, * FROM sys.databases
|
||||||
|
|
||||||
|
# Known issue: empty result set breaks return values
|
||||||
|
- name: empty result set
|
||||||
|
community.general.mssql_script:
|
||||||
|
login_user: "{{ mssql_login_user }}"
|
||||||
|
login_password: "{{ mssql_login_password }}"
|
||||||
|
login_host: "{{ mssql_host }}"
|
||||||
|
login_port: "{{ mssql_port }}"
|
||||||
|
script: |
|
||||||
|
SELECT name, state_desc FROM sys.databases WHERE name = %(dbname)s
|
||||||
|
SELECT name, state_desc FROM sys.databases WHERE name = 'DoesNotexist'
|
||||||
|
SELECT name, state_desc FROM sys.databases WHERE name = %(dbname)s
|
||||||
|
params:
|
||||||
|
dbname: msdb
|
||||||
|
register: empty_result
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- empty_result.query_results[0] | length == 3 # == 1 ; issue: only first result is returned
|
||||||
|
- empty_result.query_results[0][0][0][0] == 'msdb'
|
||||||
|
- empty_result.query_results[0][1] | length == 0
|
||||||
|
- empty_result.query_results[0][2][0][0] == 'msdb'
|
||||||
|
failed_when: false # known issue
|
||||||
|
|
Loading…
Reference in a new issue