summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2018-12-17 16:43:14 +0200
committerGitHub <noreply@github.com>2018-12-17 16:43:14 +0200
commite2af34fcf84b41189b54e1f2912faded5daabaca (patch)
tree14ddbfbc1b3ba0cac52df2889140f81adf98758c
parentfae95874b729dfe62a7a40625f8717aed20b0fca (diff)
downloadcpython-git-e2af34fcf84b41189b54e1f2912faded5daabaca.tar.gz
bpo-35504: Fix a SystemError when delete the characters_written attribute of an OSError. (GH-11172)
-rw-r--r--Lib/test/test_exception_hierarchy.py5
-rw-r--r--Misc/NEWS.d/next/Core and Builtins/2018-12-15-00-47-41.bpo-35504.9gVuen.rst1
-rw-r--r--Objects/exceptions.c8
3 files changed, 14 insertions, 0 deletions
diff --git a/Lib/test/test_exception_hierarchy.py b/Lib/test/test_exception_hierarchy.py
index 8649596790..43b4af8403 100644
--- a/Lib/test/test_exception_hierarchy.py
+++ b/Lib/test/test_exception_hierarchy.py
@@ -150,10 +150,15 @@ class AttributesTest(unittest.TestCase):
e = BlockingIOError(*args[:n])
with self.assertRaises(AttributeError):
e.characters_written
+ with self.assertRaises(AttributeError):
+ del e.characters_written
e = BlockingIOError("a", "b", 3)
self.assertEqual(e.characters_written, 3)
e.characters_written = 5
self.assertEqual(e.characters_written, 5)
+ del e.characters_written
+ with self.assertRaises(AttributeError):
+ e.characters_written
class ExplicitSubclassingTest(unittest.TestCase):
diff --git a/Misc/NEWS.d/next/Core and Builtins/2018-12-15-00-47-41.bpo-35504.9gVuen.rst b/Misc/NEWS.d/next/Core and Builtins/2018-12-15-00-47-41.bpo-35504.9gVuen.rst
new file mode 100644
index 0000000000..622b50ca62
--- /dev/null
+++ b/Misc/NEWS.d/next/Core and Builtins/2018-12-15-00-47-41.bpo-35504.9gVuen.rst
@@ -0,0 +1 @@
+Fixed a SystemError when delete the characters_written attribute of an OSError.
diff --git a/Objects/exceptions.c b/Objects/exceptions.c
index 05578d4a6a..002a602373 100644
--- a/Objects/exceptions.c
+++ b/Objects/exceptions.c
@@ -1196,6 +1196,14 @@ OSError_written_get(PyOSErrorObject *self, void *context)
static int
OSError_written_set(PyOSErrorObject *self, PyObject *arg, void *context)
{
+ if (arg == NULL) {
+ if (self->written == -1) {
+ PyErr_SetString(PyExc_AttributeError, "characters_written");
+ return -1;
+ }
+ self->written = -1;
+ return 0;
+ }
Py_ssize_t n;
n = PyNumber_AsSsize_t(arg, PyExc_ValueError);
if (n == -1 && PyErr_Occurred())