Skip to content

Commit

Permalink
Merge pull request #27 from macisamuele/maci-add-test-to-ensure-that-…
Browse files Browse the repository at this point in the history
…tester-are-testing-the-correct-rule

Add test case that ensures that examples are triggering the desired rule
  • Loading branch information
macisamuele authored Feb 14, 2020
2 parents 580b6c2 + 758243b commit 6c4ce48
Showing 1 changed file with 28 additions and 8 deletions.
36 changes: 28 additions & 8 deletions tests/docs_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,8 +68,8 @@ def _contain_docstring_or_code(path):
iglob(os.path.join(DOC_DIR, '**', '**.rst')),
))
DOCUMENTED_MODULES = set(_extract_documented_models(os.path.join(DOC_DIR, 'swagger_spec_compatibility.rst')))
BACKWARD_INCOMPATIBILITY_TESTERS = sorted(
iglob(os.path.join(DOC_DIR, 'rules', 'examples', '*', 'tester.py')),
BACKWARD_INCOMPATIBILITY_EXAMPLES = sorted(
iglob(os.path.join(DOC_DIR, 'rules', 'examples', '*')),
)


Expand All @@ -83,14 +83,34 @@ def test_ensure_all_modules_are_available_in_documentation():


@pytest.mark.parametrize(
'backward_incompatibility_tester',
BACKWARD_INCOMPATIBILITY_TESTERS,
'backward_incompatibility_example_dir',
BACKWARD_INCOMPATIBILITY_EXAMPLES,
)
def test_backward_incompatibility_testers_are_not_failing(backward_incompatibility_tester):
def test_backward_incompatibility_testers_are_not_failing(backward_incompatibility_example_dir):
tester = os.path.join(backward_incompatibility_example_dir, 'tester.py')
try:
check_call(
[sys.executable, backward_incompatibility_tester],
cwd=os.path.dirname(backward_incompatibility_tester),
[sys.executable, tester],
cwd=backward_incompatibility_example_dir,
)
except CalledProcessError: # pragma: no cover
pytest.fail('{} has failed to run.'.format(backward_incompatibility_tester))
pytest.fail('{} has failed to run.'.format(tester))


@pytest.mark.parametrize(
'backward_incompatibility_example_dir',
BACKWARD_INCOMPATIBILITY_EXAMPLES,
)
def test_ensure_that_examples_are_covering_the_correct_rule(backward_incompatibility_example_dir):
old_spec = os.path.join(backward_incompatibility_example_dir, 'old.yaml')
new_spec = os.path.join(backward_incompatibility_example_dir, 'new.yaml')
rule_name = os.path.basename(backward_incompatibility_example_dir)
try:
check_call(
[sys.executable, '-m', 'swagger_spec_compatibility', 'run', old_spec, new_spec, '--rule', rule_name],
cwd=backward_incompatibility_example_dir,
)
pytest.fail('{} has failed to highlight rule {}.'.format(backward_incompatibility_example_dir, rule_name))
except CalledProcessError: # pragma: no cover
# Not clean exit is expected as we are running the compatibility tool to verify that it exits with non 0 value
pass

0 comments on commit 6c4ce48

Please sign in to comment.