From 277a3f783ab75adca478b909279bd653fad10478 Mon Sep 17 00:00:00 2001 From: Brett Date: Tue, 20 Feb 2024 13:54:35 -0500 Subject: [PATCH] remove uses of jsonschema in tests --- pyproject.toml | 3 +-- tests/conftest.py | 18 ------------------ tests/test_asdf_schema.py | 7 ++++--- tests/test_yaml_schema.py | 7 ++++--- 4 files changed, 9 insertions(+), 26 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index d6e248f3..96f4642f 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -30,9 +30,8 @@ docs = [ test = [ 'pytest', 'pyyaml', - 'asdf >= 2.8.0', + 'asdf >= 3.0.0', 'packaging>=16.0', - 'jsonschema<4.18', ] [project.urls] diff --git a/tests/conftest.py b/tests/conftest.py index b644c116..97bd40c0 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -22,7 +22,6 @@ ref_to_id, split_id, ) -from jsonschema.validators import Draft4Validator, RefResolver @pytest.fixture(scope="session") @@ -205,20 +204,3 @@ def _assert_latest_schema_correct(path): ) return _assert_latest_schema_correct - - -@pytest.fixture(scope="session") -def create_validator(schemas, yaml_schemas): - """ - Fixture method that creates validators with access to schemas in - this repository. - """ - - def _create_validator(schema): - store = {s["id"]: s for s in schemas + yaml_schemas} - - resolver = RefResolver.from_schema(schema, id_of=Draft4Validator.ID_OF, store=store) - - return Draft4Validator(schema, resolver=resolver) - - return _create_validator diff --git a/tests/test_asdf_schema.py b/tests/test_asdf_schema.py index c614a166..8f7ad76d 100644 --- a/tests/test_asdf_schema.py +++ b/tests/test_asdf_schema.py @@ -1,6 +1,7 @@ +import asdf import pytest +from asdf.exceptions import ValidationError from common import SCHEMAS_PATH, assert_yaml_header_and_footer, load_yaml -from jsonschema import ValidationError @pytest.mark.parametrize("path", SCHEMAS_PATH.glob("asdf-schema-*.yaml")) @@ -12,12 +13,12 @@ def test_asdf_schema(path): @pytest.mark.parametrize("path", SCHEMAS_PATH.glob("asdf-schema-*.yaml")) -def test_nested_object_validation(path, create_validator): +def test_nested_object_validation(path): """ Test that the validations are applied to nested objects. """ metaschema = load_yaml(path) - validator = create_validator(metaschema) + validator = asdf.schema.get_validator(schema=metaschema) schema = {"$schema": metaschema["id"], "type": "object", "properties": {"foo": {"datatype": "float32"}}} # No error here diff --git a/tests/test_yaml_schema.py b/tests/test_yaml_schema.py index 66b565e8..46c30c37 100644 --- a/tests/test_yaml_schema.py +++ b/tests/test_yaml_schema.py @@ -1,6 +1,7 @@ +import asdf import pytest +from asdf.exceptions import ValidationError from common import YAML_SCHEMA_PATH, assert_yaml_header_and_footer, list_schema_paths, load_yaml -from jsonschema import ValidationError @pytest.mark.parametrize("path", list_schema_paths(YAML_SCHEMA_PATH)) @@ -12,12 +13,12 @@ def test_yaml_schema(path): @pytest.mark.parametrize("path", YAML_SCHEMA_PATH.glob("*.yaml")) -def test_nested_object_validation(path, create_validator): +def test_nested_object_validation(path): """ Test that the validations are applied to nested objects. """ metaschema = load_yaml(path) - validator = create_validator(metaschema) + validator = asdf.schema.get_validator(schema=metaschema) schema = {"$schema": metaschema["id"], "type": "object", "properties": {"foo": {"flowStyle": "block"}}} # No error here