From a0eda92044242985694df7e714160ade6778d4ab Mon Sep 17 00:00:00 2001 From: Arnaud Patard Date: Mon, 26 Sep 2022 14:58:08 +0200 Subject: [PATCH 1/2] Fix import of molecule schema. Commit "Adopt molecule config JSON schema (#3668)" (acb9ae082757) has imported the molecule schema into data/ but everything is using src/molecule/schemas/ as directory for the schema. So: - Update src/molecule/data/molecule.json with parts of src/molecule/schemas/molecule.json content with the one. The update/ replacement was partial as the local schema handles in a better way the MoleculeDependencyModel. The new schema was allowing to use the "shell" dependency with an empty command. - Update schema $id to point to the correct location - Fix test link to point to the correct schema file. - Fix path to the schema in schema_v3.py Signed-off-by: Arnaud Patard --- src/molecule/data/__init__.py | 1 + src/molecule/data/molecule.json | 19 +- src/molecule/model/schema_v3.py | 4 +- src/molecule/schemas/__init__.py | 1 - src/molecule/schemas/molecule.json | 540 ----------------------------- 5 files changed, 16 insertions(+), 549 deletions(-) create mode 100644 src/molecule/data/__init__.py delete mode 100644 src/molecule/schemas/__init__.py delete mode 100644 src/molecule/schemas/molecule.json diff --git a/src/molecule/data/__init__.py b/src/molecule/data/__init__.py new file mode 100644 index 0000000000..c8bac582bc --- /dev/null +++ b/src/molecule/data/__init__.py @@ -0,0 +1 @@ +"""Module containing molecule data files.""" diff --git a/src/molecule/data/molecule.json b/src/molecule/data/molecule.json index 1104783e81..71bfb52b7a 100644 --- a/src/molecule/data/molecule.json +++ b/src/molecule/data/molecule.json @@ -13,12 +13,8 @@ "type": "object" }, "MoleculeDependencyModel": { - "additionalProperties": false, + "unevaluatedProperties": false, "properties": { - "command": { - "title": "Command", - "type": ["string", "null"] - }, "enabled": { "default": true, "title": "Enabled", @@ -38,6 +34,17 @@ "type": "object" } }, + "if": { + "properties": { "name": { "const": "galaxy" } } + }, + "then": { + "properties": { + "command": { "title": "Command", "type": ["string", "null"] } + } + }, + "else": { + "properties": { "command": { "title": "Command", "type": "string" } } + }, "required": ["name"], "title": "MoleculeDependencyModel", "type": "object" @@ -509,7 +516,7 @@ "type": "object" } }, - "$id": "https://raw.githubusercontent.com/ansible/schemas/main/f/molecule.json", + "$id": "https://raw.githubusercontent.com/ansible-community/molecule/main/src/molecule/data/molecule.json", "$schema": "http://json-schema.org/draft-07/schema", "additionalProperties": false, "examples": ["molecule/*/molecule.yml"], diff --git a/src/molecule/model/schema_v3.py b/src/molecule/model/schema_v3.py index cfb2a755af..6f7944c8e9 100644 --- a/src/molecule/model/schema_v3.py +++ b/src/molecule/model/schema_v3.py @@ -25,13 +25,13 @@ from jsonschema import validate as jsonschema_validate from jsonschema.exceptions import ValidationError -from molecule.schemas import __file__ as schemas_module +from molecule.data import __file__ as data_module def validate(c): """Perform schema validation.""" result = [] - schema_file = os.path.dirname(schemas_module) + "/molecule.json" + schema_file = os.path.dirname(data_module) + "/molecule.json" with open(schema_file, encoding="utf-8") as f: schema = json.load(f) diff --git a/src/molecule/schemas/__init__.py b/src/molecule/schemas/__init__.py deleted file mode 100644 index f1dad4824d..0000000000 --- a/src/molecule/schemas/__init__.py +++ /dev/null @@ -1 +0,0 @@ -"""Module containing cached JSON schemas.""" diff --git a/src/molecule/schemas/molecule.json b/src/molecule/schemas/molecule.json deleted file mode 100644 index d55cb01086..0000000000 --- a/src/molecule/schemas/molecule.json +++ /dev/null @@ -1,540 +0,0 @@ -{ - "$defs": { - "ContainerRegistryModel": { - "additionalProperties": false, - "properties": { - "url": { - "title": "Url", - "type": "string" - } - }, - "required": ["url"], - "title": "ContainerRegistryModel", - "type": "object" - }, - "MoleculeDependencyModel": { - "unevaluatedProperties": false, - "properties": { - "enabled": { - "default": true, - "title": "Enabled", - "type": "boolean" - }, - "env": { - "title": "Env", - "type": "object" - }, - "name": { - "enum": ["galaxy", "shell"], - "title": "Name", - "type": "string" - }, - "options": { - "title": "Options", - "type": "object" - } - }, - "if": { - "properties": { "name": { "const": "galaxy" } } - }, - "then": { - "properties": { - "command": { "title": "Command", "type": ["string", "null"] } - } - }, - "else": { - "properties": { "command": { "title": "Command", "type": "string" } } - }, - "required": ["name"], - "title": "MoleculeDependencyModel", - "type": "object" - }, - "MoleculeDriverModel": { - "additionalProperties": false, - "properties": { - "name": { - "enum": [ - "azure", - "ec2", - "delegated", - "docker", - "containers", - "openstack", - "podman", - "vagrant", - "digitalocean", - "gce", - "libvirt", - "lxd" - ], - "title": "Name", - "type": "string" - }, - "options": { - "$ref": "#/$defs/MoleculeDriverOptionsModel" - }, - "provider": { - "title": "Provider", - "type": "object" - }, - "safe_files": { - "items": { - "type": "string" - }, - "title": "SafeFiles", - "type": "array" - }, - "ssh_connection_options": { - "items": { - "type": "string" - }, - "title": "SshConnectionOptions", - "type": "array" - } - }, - "title": "MoleculeDriverModel", - "type": "object" - }, - "MoleculeDriverOptionsModel": { - "additionalProperties": false, - "properties": { - "ansible_connection_options": { - "additionalProperties": { - "type": "string" - }, - "title": "Ansible Connection Options", - "type": "object" - }, - "login_cmd_template": { - "title": "Login Cmd Template", - "type": "string" - }, - "managed": { - "title": "Managed", - "type": "boolean" - } - }, - "title": "MoleculeDriverOptionsModel", - "type": "object" - }, - "MoleculePlatformModel": { - "additionalProperties": true, - "properties": { - "box": { - "title": "Box", - "type": "string" - }, - "children": { - "items": { - "type": "string" - }, - "type": "array" - }, - "command": { - "title": "Command", - "type": "string" - }, - "cpus": { - "title": "Cpus", - "type": "integer" - }, - "dockerfile": { - "title": "Dockerfile", - "type": "string" - }, - "env": { - "items": { - "type": "object" - }, - "title": "Platform Environment Variables", - "type": "array" - }, - "environment": { - "additionalProperties": { - "type": "string" - }, - "title": "Environment", - "type": "object" - }, - "groups": { - "items": { - "type": "string" - }, - "title": "Groups", - "type": "array" - }, - "hostname": { - "title": "Hostname", - "type": "string" - }, - "image": { - "title": "Image", - "type": ["string", "null"] - }, - "memory": { - "title": "Memory", - "type": "integer" - }, - "name": { - "title": "Name", - "type": "string" - }, - "network_mode": { - "anyOf": [ - { - "enum": ["bridge", "host", "none"], - "type": "string" - }, - { - "pattern": "^service:[a-zA-Z0-9:_.\\\\-]+$", - "type": "string" - }, - { - "pattern": "^container:[a-zA-Z0-9][a-zA-Z0-9_.-]+$", - "type": "string" - } - ], - "title": "Network Mode" - }, - "networks": { - "items": { - "$ref": "#/$defs/platform-network" - }, - "markdownDescription": "Used by docker and podman drivers.", - "title": "Networks", - "type": "array" - }, - "pkg_extras": { - "title": "Pkg Extras", - "type": "string" - }, - "pre_build_image": { - "title": "Pre Build Image", - "type": "boolean" - }, - "privileged": { - "title": "Privileged", - "type": "boolean" - }, - "provider_raw_config_args": { - "items": { - "type": "string" - }, - "title": "Provider Raw Config Args", - "type": "array" - }, - "registry": { - "$ref": "#/$defs/ContainerRegistryModel" - }, - "tmpfs": { - "items": { - "type": "string" - }, - "title": "Tmpfs", - "type": "array" - }, - "ulimits": { - "items": { - "type": "string" - }, - "title": "Ulimits", - "type": "array" - }, - "volumes": { - "items": { - "type": "string" - }, - "title": "Volumes", - "type": "array" - } - }, - "required": ["name"], - "title": "MoleculePlatformModel", - "type": "object" - }, - "MoleculeScenarioModel": { - "additionalProperties": false, - "properties": { - "check_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "cleanup_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "converge_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "create_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "dependency_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "destroy_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "idempotence_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "lint_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "name": { - "title": "Name", - "type": "string" - }, - "prepare_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "side_effect_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "syntax_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "test_sequence": { - "$ref": "#/$defs/ScenarioSequence" - }, - "verify_sequence": { - "$ref": "#/$defs/ScenarioSequence" - } - }, - "title": "MoleculeScenarioModel", - "type": "object" - }, - "ProvisionerConfigOptionsDefaultsModel": { - "additionalProperties": true, - "properties": { - "ansible_managed": { - "default": "Ansible managed: Do NOT edit this file manually!", - "title": "Ansible Managed", - "type": "string" - }, - "display_failed_stderr": { - "default": true, - "title": "Display Failed Stderr", - "type": "boolean" - }, - "fact_caching": { - "title": "Fact Caching", - "type": "string" - }, - "fact_caching_connection": { - "title": "Fact Caching Connection", - "type": "string" - }, - "forks": { - "default": 50, - "title": "Forks", - "type": "integer" - }, - "host_key_checking": { - "default": false, - "title": "Host Key Checking", - "type": "boolean" - }, - "interpreter_python": { - "default": "auto_silent", - "description": "See https://docs.ansible.com/ansible/devel/reference_appendices/interpreter_discovery.html", - "title": "Interpreter Python", - "type": "string" - }, - "nocows": { - "default": 1, - "title": "Nocows", - "type": "integer" - }, - "retry_files_enabled": { - "default": false, - "title": "Retry Files Enabled", - "type": "boolean" - } - }, - "title": "ProvisionerConfigOptionsDefaultsModel", - "type": "object" - }, - "ProvisionerConfigOptionsModel": { - "additionalProperties": true, - "properties": { - "defaults": { - "$ref": "#/$defs/ProvisionerConfigOptionsDefaultsModel" - }, - "ssh_connection": { - "$ref": "#/$defs/ProvisionerConfigOptionsSshConnectionModel" - } - }, - "title": "ProvisionerConfigOptionsModel", - "type": "object" - }, - "ProvisionerConfigOptionsSshConnectionModel": { - "additionalProperties": false, - "properties": { - "control_path": { - "default": "%(directory)s/%%h-%%p-%%r", - "title": "Control Path", - "type": "string" - }, - "scp_if_ssh": { - "default": true, - "title": "Scp If Ssh", - "type": "boolean" - } - }, - "title": "ProvisionerConfigOptionsSshConnectionModel", - "type": "object" - }, - "ProvisionerModel": { - "additionalProperties": true, - "properties": { - "config_options": { - "$ref": "#/$defs/ProvisionerConfigOptionsModel" - }, - "env": { - "title": "Env", - "type": "object" - }, - "inventory": { - "title": "Inventory", - "type": "object" - }, - "log": { - "title": "Log", - "type": "boolean" - }, - "name": { - "enum": ["ansible"], - "title": "Name", - "type": "string" - }, - "playbooks": { - "title": "Playbooks", - "type": "object" - } - }, - "title": "ProvisionerModel", - "type": "object" - }, - "ScenarioSequence": { - "additionalProperties": false, - "items": { - "enum": [ - "check", - "cleanup", - "converge", - "create", - "dependency", - "destroy", - "idempotence", - "lint", - "prepare", - "side_effect", - "syntax", - "test", - "verify" - ], - "type": "string" - }, - "title": "ScenarioSequence", - "type": "array" - }, - "VerifierModel": { - "additionalProperties": false, - "properties": { - "additional_files_or_dirs": { - "items": { - "type": "string" - }, - "title": "AdditionalFilesOrDirs", - "type": "array" - }, - "enabled": { - "title": "Enabled", - "type": "boolean" - }, - "env": { - "title": "Env", - "type": "object" - }, - "name": { - "default": "ansible", - "enum": ["ansible", "goss", "inspec", "testinfra"], - "title": "Name", - "type": "string" - }, - "options": { - "title": "Options", - "type": "object" - } - }, - "title": "VerifierModel", - "type": "object" - }, - "platform-network": { - "properties": { - "aliases": { - "items": { - "type": "string" - }, - "type": "array" - }, - "ipv4_address": { - "type": "string" - }, - "name": { - "type": "string" - } - }, - "required": ["name"], - "type": "object" - } - }, - "$id": "https://raw.githubusercontent.com/ansible/schemas/main/f/molecule.json", - "$schema": "https://json-schema.org/draft/2020-12/schema", - "additionalProperties": false, - "examples": ["molecule/*/molecule.yml"], - "properties": { - "dependency": { - "$ref": "#/$defs/MoleculeDependencyModel" - }, - "driver": { - "$ref": "#/$defs/MoleculeDriverModel" - }, - "lint": { - "title": "Lint", - "type": "string" - }, - "log": { - "default": true, - "title": "Log", - "type": "boolean" - }, - "platforms": { - "items": { - "$ref": "#/$defs/MoleculePlatformModel" - }, - "title": "Platforms", - "type": "array" - }, - "prerun": { - "title": "Prerun", - "type": "boolean" - }, - "provisioner": { - "$ref": "#/$defs/ProvisionerModel" - }, - "role_name_check": { - "enum": [0, 1, 2], - "title": "RoleNameCheck", - "type": "integer" - }, - "scenario": { - "$ref": "#/$defs/MoleculeScenarioModel" - }, - "verifier": { - "$ref": "#/$defs/VerifierModel" - } - }, - "required": ["driver", "platforms"], - "title": "Molecule Scenario Schema", - "type": "object" -} From 6ddc36366ec06b243a550f1ebac365988e85f92e Mon Sep 17 00:00:00 2001 From: Arnaud Patard Date: Mon, 26 Sep 2022 16:05:59 +0200 Subject: [PATCH 2/2] rc/molecule/test/unit/model/v2/test_dependency_section.py: Fix checks With the new schema file, the schema check doesn't return the same error strings, so update them. Signed-off-by: Arnaud Patard --- src/molecule/test/unit/model/v2/test_dependency_section.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/molecule/test/unit/model/v2/test_dependency_section.py b/src/molecule/test/unit/model/v2/test_dependency_section.py index 9d61586578..e453a3b21f 100644 --- a/src/molecule/test/unit/model/v2/test_dependency_section.py +++ b/src/molecule/test/unit/model/v2/test_dependency_section.py @@ -49,7 +49,7 @@ def _model_dependency_errors_section_data(): "_config", ["_model_dependency_errors_section_data"], indirect=True ) def test_dependency_has_errors(_config): - x = ["Unevaluated properties are not allowed ('name' was unexpected)"] + x = ["0 is not one of ['galaxy', 'shell']"] assert x == schema_v3.validate(_config) @@ -85,6 +85,6 @@ def _model_dependency_shell_errors_section_data(): "_config", ["_model_dependency_shell_errors_section_data"], indirect=True ) def test_dependency_shell_has_errors(_config): - x = ["Unevaluated properties are not allowed ('command' was unexpected)"] + x = ["None is not of type 'string'"] assert x == schema_v3.validate(_config)