diff options
author | Martin Panter <vadmium+py@gmail.com> | 2015-11-13 23:10:39 (GMT) |
---|---|---|
committer | Martin Panter <vadmium+py@gmail.com> | 2015-11-13 23:10:39 (GMT) |
commit | fa9ea046732eff86408aba477d557c8fc92bc864 (patch) | |
tree | e7ab1537f108883827edc860d10b38203eb83773 /Lib/test/test_rlcompleter.py | |
parent | 75559affad77d929ab8a87da226f080ec7b59dbd (diff) | |
parent | 06622ead8072f3602bba8cd1924f0897873ad8b1 (diff) | |
download | cpython-fa9ea046732eff86408aba477d557c8fc92bc864.zip cpython-fa9ea046732eff86408aba477d557c8fc92bc864.tar.gz cpython-fa9ea046732eff86408aba477d557c8fc92bc864.tar.bz2 |
Issue #25590: Merge rlcompleter change from 3.4 into 3.5
Diffstat (limited to 'Lib/test/test_rlcompleter.py')
-rw-r--r-- | Lib/test/test_rlcompleter.py | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/Lib/test/test_rlcompleter.py b/Lib/test/test_rlcompleter.py index d37b620..2022ed6 100644 --- a/Lib/test/test_rlcompleter.py +++ b/Lib/test/test_rlcompleter.py @@ -64,6 +64,19 @@ class TestRlcompleter(unittest.TestCase): ['egg.{}('.format(x) for x in dir(str) if x.startswith('s')]) + def test_excessive_getattr(self): + # Ensure getattr() is invoked no more than once per attribute + class Foo: + calls = 0 + @property + def bar(self): + self.calls += 1 + return None + f = Foo() + completer = rlcompleter.Completer(dict(f=f)) + self.assertEqual(completer.complete('f.b', 0), 'f.bar') + self.assertEqual(f.calls, 1) + def test_complete(self): completer = rlcompleter.Completer() self.assertEqual(completer.complete('', 0), '\t') |