From af6b4068859a5d0c8afd696f3c0c0155660211a4 Mon Sep 17 00:00:00 2001 From: Kumar Aditya Date: Thu, 9 Dec 2021 18:46:45 +0530 Subject: bpo-25066: Added repr for multiprocessing.Event (GH-29749) Co-authored-by: Pablo Galindo Salgado --- Lib/multiprocessing/synchronize.py | 3 +++ Lib/test/_test_multiprocessing.py | 15 ++++++++++++++- .../next/Library/2021-11-24-12-25-42.bpo-25066.YIcIkn.rst | 1 + 3 files changed, 18 insertions(+), 1 deletion(-) create mode 100644 Misc/NEWS.d/next/Library/2021-11-24-12-25-42.bpo-25066.YIcIkn.rst diff --git a/Lib/multiprocessing/synchronize.py b/Lib/multiprocessing/synchronize.py index d0be48f1fd..42624b5436 100644 --- a/Lib/multiprocessing/synchronize.py +++ b/Lib/multiprocessing/synchronize.py @@ -353,6 +353,9 @@ class Event(object): return True return False + def __repr__(self) -> str: + set_status = 'set' if self.is_set() else 'unset' + return f"<{type(self).__qualname__} at {id(self):#x} {set_status}>" # # Barrier # diff --git a/Lib/test/_test_multiprocessing.py b/Lib/test/_test_multiprocessing.py index 3bc5b8f3d7..b2d656ab42 100644 --- a/Lib/test/_test_multiprocessing.py +++ b/Lib/test/_test_multiprocessing.py @@ -1645,7 +1645,20 @@ class _TestEvent(BaseTestCase): self.assertEqual(wait(), True) p.join() -# + def test_repr(self) -> None: + event = self.Event() + if self.TYPE == 'processes': + self.assertRegex(repr(event), r"") + event.set() + self.assertRegex(repr(event), r"") + event.clear() + self.assertRegex(repr(event), r"") + elif self.TYPE == 'manager': + self.assertRegex(repr(event), r"