diff options
author | Damien George <damien.p.george@gmail.com> | 2020-05-29 10:28:38 +1000 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2020-06-02 15:42:20 +1000 |
commit | 203b10703e5df20939b88a2ce29bb961cce7e4b6 (patch) | |
tree | c7d9b303ed56097b1b0cd3ddd09f0218a4ec331b /tests/basics | |
parent | da71f55e23a97102d241481e410fdb22d7c55758 (diff) | |
download | micropython-203b10703e5df20939b88a2ce29bb961cce7e4b6.tar.gz micropython-203b10703e5df20939b88a2ce29bb961cce7e4b6.zip |
py/modbuiltins: Fix getattr to work with class raising AttributeError.
Fixes issue #6089.
Diffstat (limited to 'tests/basics')
-rw-r--r-- | tests/basics/builtin_getattr.py | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/tests/basics/builtin_getattr.py b/tests/basics/builtin_getattr.py index 59cb7e7f7a..afa4ab3293 100644 --- a/tests/basics/builtin_getattr.py +++ b/tests/basics/builtin_getattr.py @@ -16,3 +16,15 @@ print(getattr(a, "meth")(5)) print(getattr(a, "_none_such", 123)) print(getattr(list, "foo", 456)) print(getattr(a, "va" + "r2")) + +# test a class that defines __getattr__ and may raise AttributeError +class B: + def __getattr__(self, attr): + if attr == "a": + return attr + else: + raise AttributeError +b = B() +print(getattr(b, "a")) +print(getattr(b, "a", "default")) +print(getattr(b, "b", "default")) |