From: David H Date: Thu, 17 Jan 2019 12:16:51 +0000 (+0100) Subject: bpo-35701: Added __weakref__ slot to uuid.UUID (GH-11570) X-Git-Tag: v3.8.0a1~82 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=f1d8e7cf17a010d2657822e06a41b30c9542a8c7;p=python bpo-35701: Added __weakref__ slot to uuid.UUID (GH-11570) Added test for weakreferencing a uuid.UUID object. --- diff --git a/Lib/test/test_uuid.py b/Lib/test/test_uuid.py index 757bf3cc41..992ef0cbf8 100644 --- a/Lib/test/test_uuid.py +++ b/Lib/test/test_uuid.py @@ -9,6 +9,7 @@ import pickle import shutil import subprocess import sys +import weakref from unittest import mock py_uuid = support.import_fresh_module('uuid', blocked=['_uuid']) @@ -657,6 +658,11 @@ class BaseTestUUID: self.assertNotEqual(parent_value, child_value) + def test_uuid_weakref(self): + # bpo-35701: check that weak referencing to a UUID object can be created + strong = self.uuid.uuid4() + weak = weakref.ref(strong) + self.assertIs(strong, weak()) class TestUUIDWithoutExtModule(BaseTestUUID, unittest.TestCase): uuid = py_uuid diff --git a/Lib/uuid.py b/Lib/uuid.py index 4468d4a6c1..ddc63ccd08 100644 --- a/Lib/uuid.py +++ b/Lib/uuid.py @@ -118,7 +118,7 @@ class UUID: uuid_generate_time_safe(3). """ - __slots__ = ('int', 'is_safe') + __slots__ = ('int', 'is_safe', '__weakref__') def __init__(self, hex=None, bytes=None, bytes_le=None, fields=None, int=None, version=None,