Patch #1674228: when assigning a slice (old-style), check for the
sq_ass_slice instead of the sq_slice slot.
(backport from rev. 54139)
diff --git a/Lib/test/test_descr.py b/Lib/test/test_descr.py
index b108395..0981f09 100644
--- a/Lib/test/test_descr.py
+++ b/Lib/test/test_descr.py
@@ -4143,6 +4143,19 @@
check(iexpr, c, N1)
check(iexpr, c, N2)
+def test_assign_slice():
+ # ceval.c's assign_slice used to check for
+ # tp->tp_as_sequence->sq_slice instead of
+ # tp->tp_as_sequence->sq_ass_slice
+
+ class C(object):
+ def __setslice__(self, start, stop, value):
+ self.value = value
+
+ c = C()
+ c[1:2] = 3
+ vereq(c.value, 3)
+
def test_main():
weakref_segfault() # Must be first, somehow
wrapper_segfault()
@@ -4239,6 +4252,7 @@
test_init()
methodwrapper()
notimplemented()
+ test_assign_slice()
if verbose: print "All OK"