From c0fe9c04df46fb02287cce8e7847380ba3259ae0 Mon Sep 17 00:00:00 2001 From: Lars Holmberg Date: Wed, 11 Dec 2024 10:44:34 +0100 Subject: [PATCH] Add test case for exceptions in init handler --- locust/test/test_main.py | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/locust/test/test_main.py b/locust/test/test_main.py index 8f6d4b8501..4ed88b8e2b 100644 --- a/locust/test/test_main.py +++ b/locust/test/test_main.py @@ -1442,6 +1442,39 @@ def my_task(self): # ensure stats printer printed at least one report before shutting down and that there was a final report printed as well self.assertRegex(stderr, r".*Aggregated[\S\s]*Shutting down[\S\s]*Aggregated.*") + def test_exception_in_init_event(self): + with mock_locustfile( + content=textwrap.dedent( + """ + from locust import User, task, constant, events + @events.init.add_listener + def _(*args, **kw): + raise Exception("something went wrong") + + class TestUser(User): + wait_time = constant(10) + @task + def my_task(self): + pass + """ + ) + ) as mocked: + proc = subprocess.Popen( + [ + "locust", + "-f", + mocked.file_path, + "--host", + "https://test.com/", + ], + stdout=PIPE, + stderr=PIPE, + text=True, + ) + stdout, stderr = proc.communicate(timeout=3) + self.assertIn("something went wrong", stderr) + self.assertEqual(1, proc.returncode) + class DistributedIntegrationTests(ProcessIntegrationTest): failed_port_check = False