From 36a8e1a990db9b800e9904f60788c8cc1b1b8709 Mon Sep 17 00:00:00 2001 From: Tony Meyer Date: Wed, 25 Sep 2024 19:43:31 +1200 Subject: [PATCH] Fix the unreferenced event object. --- interface_tester/interface_test.py | 2 ++ pyproject.toml | 2 +- tests/unit/test_e2e.py | 27 +++++++++++++++++++++++++++ 3 files changed, 30 insertions(+), 1 deletion(-) diff --git a/interface_tester/interface_test.py b/interface_tester/interface_test.py index f0e2258..e26f4b6 100644 --- a/interface_tester/interface_test.py +++ b/interface_tester/interface_test.py @@ -435,6 +435,8 @@ def _cast_event(self, raw_event: Union[str, _Event], relation: Relation): raise InvalidTestCaseError( f"Bad interface test specification: event {raw_event} is not a relation event." ) + else: + event = raw_event # todo: if the user passes a relation event that is NOT about the relation # interface that this test is about, at this point we are injecting the wrong diff --git a/pyproject.toml b/pyproject.toml index fb40f97..9125096 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -11,7 +11,7 @@ build-backend = "setuptools.build_meta" [project] name = "pytest-interface-tester" -version = "3.1.1" +version = "3.1.2" authors = [ { name = "Pietro Pasotti", email = "pietro.pasotti@canonical.com" }, ] diff --git a/tests/unit/test_e2e.py b/tests/unit/test_e2e.py index 3653b5c..aefe229 100644 --- a/tests/unit/test_e2e.py +++ b/tests/unit/test_e2e.py @@ -208,6 +208,33 @@ def test_data_on_changed(): tester.run() +def test_run_with_charmevents(): + tester = _setup_with_test_file( + dedent( + """ +from scenario import State, Relation +from scenario.context import CharmEvents + +from interface_tester.interface_test import Tester + +def test_data_on_changed(): + relation = Relation( + endpoint='foobadooble', + interface='tracing', + remote_app_name='remote', + local_app_data={}, + ) + t = Tester(State(relations={relation})) + state_out = t.run(CharmEvents.relation_changed(relation)) + t.assert_schema_valid() +""" + ) + ) + + with pytest.raises(NoSchemaError): + tester.run() + + def test_error_if_assert_schema_without_schema(): tester = _setup_with_test_file( dedent(