mirror of https://github.com/python/cpython.git
[3.13] gh-127316: fix incorrect assertion in setting `__class__` in free-threading (GH-127399) (#127422)
gh-127316: fix incorrect assertion in setting `__class__` in free-threading (GH-127399)
(cherry picked from commit 45c5cba318
)
Co-authored-by: Kumar Aditya <kumaraditya@python.org>
This commit is contained in:
parent
ee57221872
commit
2f56c68dec
|
@ -125,6 +125,21 @@ def work():
|
|||
for thread in threads:
|
||||
thread.join()
|
||||
|
||||
def test_object_class_change(self):
|
||||
class Base:
|
||||
def __init__(self):
|
||||
self.attr = 123
|
||||
class ClassA(Base):
|
||||
pass
|
||||
class ClassB(Base):
|
||||
pass
|
||||
|
||||
obj = ClassA()
|
||||
# keep reference to __dict__
|
||||
d = obj.__dict__
|
||||
obj.__class__ = ClassB
|
||||
|
||||
|
||||
def run_one(self, writer_func, reader_func):
|
||||
writer = Thread(target=writer_func)
|
||||
readers = []
|
||||
|
|
|
@ -7190,7 +7190,7 @@ _PyDict_DetachFromObject(PyDictObject *mp, PyObject *obj)
|
|||
|
||||
// We could be called with an unlocked dict when the caller knows the
|
||||
// values are already detached, so we assert after inline values check.
|
||||
_Py_CRITICAL_SECTION_ASSERT_OBJECT_LOCKED(mp);
|
||||
ASSERT_WORLD_STOPPED_OR_OBJ_LOCKED(mp);
|
||||
assert(mp->ma_values->embedded == 1);
|
||||
assert(mp->ma_values->valid == 1);
|
||||
assert(Py_TYPE(obj)->tp_flags & Py_TPFLAGS_INLINE_VALUES);
|
||||
|
|
Loading…
Reference in New Issue