From 19ab8827907cc6612537110cedb528bcb1980cdd Mon Sep 17 00:00:00 2001 From: Matt Martz Date: Mon, 15 Jan 2018 18:29:20 -0600 Subject: [PATCH] Fix inconsitencies between code assumptions and schema (#34901) * Fix inconsitencies between code assumptions and schema * Address a couple of RETURN issues, where the description was parsed as a dict --- lib/ansible/modules/cloud/azure/azure_rm_mysqlserver.py | 4 ++-- .../modules/cloud/azure/azure_rm_postgresqlserver.py | 4 ++-- test/sanity/validate-modules/main.py | 2 +- test/sanity/validate-modules/schema.py | 6 +++--- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/lib/ansible/modules/cloud/azure/azure_rm_mysqlserver.py b/lib/ansible/modules/cloud/azure/azure_rm_mysqlserver.py index 09f1fef6581..a6c0a696941 100644 --- a/lib/ansible/modules/cloud/azure/azure_rm_mysqlserver.py +++ b/lib/ansible/modules/cloud/azure/azure_rm_mysqlserver.py @@ -102,13 +102,13 @@ id: sample: /subscriptions/12345678-1234-1234-1234-123412341234/testrg/providers/Microsoft.DBforMySQL/servers/mysqlsrv1b6dd89593 version: description: - - Server version. Possible values include: C(5.6), C(5.7) + - 'Server version. Possible values include: C(5.6), C(5.7)' returned: always type: str sample: 5.6 state: description: - - A state of a server that is visible to user. Possible values include: C(Ready), C(Dropping), C(Disabled) + - 'A state of a server that is visible to user. Possible values include: C(Ready), C(Dropping), C(Disabled)' returned: always type: str sample: Ready diff --git a/lib/ansible/modules/cloud/azure/azure_rm_postgresqlserver.py b/lib/ansible/modules/cloud/azure/azure_rm_postgresqlserver.py index ca464e3ae15..bc0b5322fc7 100644 --- a/lib/ansible/modules/cloud/azure/azure_rm_postgresqlserver.py +++ b/lib/ansible/modules/cloud/azure/azure_rm_postgresqlserver.py @@ -102,13 +102,13 @@ id: sample: /subscriptions/12345678-1234-1234-1234-123412341234/resourceGroups/samplerg/providers/Microsoft.DBforPostgreSQL/servers/mysqlsrv1b6dd89593 version: description: - - Server version. Possible values include: C(9.5), C(9.6) + - 'Server version. Possible values include: C(9.5), C(9.6)' returned: always type: str sample: 9.6 state: description: - - A state of a server that is visible to user. Possible values include: C(Ready), C(Dropping), C(Disabled) + - 'A state of a server that is visible to user. Possible values include: C(Ready), C(Dropping), C(Disabled)' returned: always type: str sample: Ready diff --git a/test/sanity/validate-modules/main.py b/test/sanity/validate-modules/main.py index c1ed89cdf3d..eb6759ae189 100755 --- a/test/sanity/validate-modules/main.py +++ b/test/sanity/validate-modules/main.py @@ -1065,7 +1065,7 @@ class ModuleValidator(Validator): for option, details in options.items(): try: names = [option] + details.get('aliases', []) - except AttributeError: + except (TypeError, AttributeError): # Reporting of this syntax error will be handled by schema validation. continue diff --git a/test/sanity/validate-modules/schema.py b/test/sanity/validate-modules/schema.py index ae94493ee9d..8dbcf62a2b2 100644 --- a/test/sanity/validate-modules/schema.py +++ b/test/sanity/validate-modules/schema.py @@ -25,7 +25,7 @@ suboption_schema = Schema( Required('description'): Any(list_string_types, *string_types), 'required': bool, 'choices': list, - 'aliases': Any(list, *string_types), + 'aliases': Any(list_string_types), 'version_added': Any(float, *string_types), 'default': Any(None, float, int, bool, list, dict, *string_types), # Note: Types are strings, not literal bools, such as True or False @@ -43,7 +43,7 @@ option_schema = Schema( Required('description'): Any(list_string_types, *string_types), 'required': bool, 'choices': list, - 'aliases': Any(list, *string_types), + 'aliases': Any(list_string_types), 'version_added': Any(float, *string_types), 'default': Any(None, float, int, bool, list, dict, *string_types), 'suboptions': Any(None, *list_dict_suboption_schema), @@ -61,7 +61,7 @@ list_dict_option_schema = [{str_type: option_schema} for str_type in string_type def return_schema(data): return_schema_dict = { - Required('description'): Any(list, *string_types), + Required('description'): Any(list_string_types, *string_types), Required('returned'): Any(*string_types), Required('type'): Any('string', 'list', 'boolean', 'dict', 'complex', 'bool', 'float', 'int', 'dictionary', 'str'), 'version_added': Any(float, *string_types),