diff options
| author | Pablo Galindo <Pablogsal@gmail.com> | 2021-04-16 17:12:03 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-04-16 17:12:03 +0100 | 
| commit | 0ad81d4db2f409d72f469d0b74ab597be772a68e (patch) | |
| tree | 3b8c64cda42f229d3cc3522b380840d6bdd10638 | |
| parent | 3b82cae774638ecf2baaee8fe2cac8fedafb2ca7 (diff) | |
| download | cpython-git-0ad81d4db2f409d72f469d0b74ab597be772a68e.tar.gz | |
bpo-38530: Match exactly AttributeError and NameError when offering suggestions (GH-25443)
| -rw-r--r-- | Lib/test/test_exceptions.py | 15 | ||||
| -rw-r--r-- | Python/suggestions.c | 4 | 
2 files changed, 17 insertions, 2 deletions
| diff --git a/Lib/test/test_exceptions.py b/Lib/test/test_exceptions.py index ebeb67b451..bd20b232e5 100644 --- a/Lib/test/test_exceptions.py +++ b/Lib/test/test_exceptions.py @@ -1537,6 +1537,21 @@ class NameErrorTests(unittest.TestCase):          self.assertNotIn("blech", err.getvalue()) +    def test_unbound_local_error_doesn_not_match(self): +        def foo(): +            something = 3 +            print(somethong) +            somethong = 3 + +        try: +            foo() +        except UnboundLocalError as exc: +            with support.captured_stderr() as err: +                sys.__excepthook__(*sys.exc_info()) + +        self.assertNotIn("something", err.getvalue()) + +  class AttributeErrorTests(unittest.TestCase):      def test_attributes(self):          # Setting 'attr' should not be a problem. diff --git a/Python/suggestions.c b/Python/suggestions.c index 258e3f1833..e422760920 100644 --- a/Python/suggestions.c +++ b/Python/suggestions.c @@ -181,9 +181,9 @@ offer_suggestions_for_name_error(PyNameErrorObject *exc) {  PyObject *_Py_Offer_Suggestions(PyObject *exception) {      PyObject *result = NULL;      assert(!PyErr_Occurred()); -    if (PyErr_GivenExceptionMatches(exception, PyExc_AttributeError)) { +    if (Py_IS_TYPE(exception, (PyTypeObject*)PyExc_AttributeError)) {          result = offer_suggestions_for_attribute_error((PyAttributeErrorObject *) exception); -    } else if (PyErr_GivenExceptionMatches(exception, PyExc_NameError)) { +    } else if (Py_IS_TYPE(exception, (PyTypeObject*)PyExc_NameError)) {          result = offer_suggestions_for_name_error((PyNameErrorObject *) exception);      }      return result; | 
