bpo-40000: Improve error messages when validating invalid ast.Constant nodes (GH-19055)

Co-authored-by: Pablo Galindo <Pablogsal@gmail.com>
This commit is contained in:
Batuhan Taşkaya 2020-03-19 14:32:28 +03:00 committed by GitHub
parent 50e6e99178
commit 0ac59f93c0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 16 additions and 3 deletions

View File

@ -582,6 +582,15 @@ class AST_Tests(unittest.TestCase):
compile(m, "<test>", "exec") compile(m, "<test>", "exec")
self.assertIn("identifier must be of type str", str(cm.exception)) self.assertIn("identifier must be of type str", str(cm.exception))
def test_invalid_constant(self):
for invalid_constant in int, (1, 2, int), frozenset((1, 2, int)):
e = ast.Expression(body=ast.Constant(invalid_constant))
ast.fix_missing_locations(e)
with self.assertRaisesRegex(
TypeError, "invalid type in Constant: type"
):
compile(e, "<test>", "eval")
def test_empty_yield_from(self): def test_empty_yield_from(self):
# Issue 16546: yield from value is not optional. # Issue 16546: yield from value is not optional.
empty_yield_from = ast.parse("def f():\n yield from g()") empty_yield_from = ast.parse("def f():\n yield from g()")

View File

@ -0,0 +1,2 @@
Improved error messages for validation of ``ast.Constant`` nodes. Patch by
Batuhan Taskaya.

View File

@ -147,6 +147,11 @@ validate_constant(PyObject *value)
return 1; return 1;
} }
if (!PyErr_Occurred()) {
PyErr_Format(PyExc_TypeError,
"got an invalid type in Constant: %s",
_PyType_Name(Py_TYPE(value)));
}
return 0; return 0;
} }
@ -261,9 +266,6 @@ validate_expr(expr_ty exp, expr_context_ty ctx)
validate_keywords(exp->v.Call.keywords); validate_keywords(exp->v.Call.keywords);
case Constant_kind: case Constant_kind:
if (!validate_constant(exp->v.Constant.value)) { if (!validate_constant(exp->v.Constant.value)) {
PyErr_Format(PyExc_TypeError,
"got an invalid type in Constant: %s",
_PyType_Name(Py_TYPE(exp->v.Constant.value)));
return 0; return 0;
} }
return 1; return 1;