summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_rlcompleter.py
diff options
context:
space:
mode:
authorMartin Panter <vadmium+py@gmail.com>2015-11-13 23:48:17 (GMT)
committerMartin Panter <vadmium+py@gmail.com>2015-11-13 23:48:17 (GMT)
commitf4ad5f5dea172d91ed21d2a330a72e77013bb279 (patch)
tree2c28246fa5914ba939d7aed732b01a5860a0cb1e /Lib/test/test_rlcompleter.py
parent8adaec56714c0ca902862d8b6279e1e3c969d664 (diff)
parentfa9ea046732eff86408aba477d557c8fc92bc864 (diff)
downloadcpython-f4ad5f5dea172d91ed21d2a330a72e77013bb279.zip
cpython-f4ad5f5dea172d91ed21d2a330a72e77013bb279.tar.gz
cpython-f4ad5f5dea172d91ed21d2a330a72e77013bb279.tar.bz2
Issue #25590: Merge rlcompleter getattr change from 3.5
Diffstat (limited to 'Lib/test/test_rlcompleter.py')
-rw-r--r--Lib/test/test_rlcompleter.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/Lib/test/test_rlcompleter.py b/Lib/test/test_rlcompleter.py
index 2ff0788..fee39bc 100644
--- a/Lib/test/test_rlcompleter.py
+++ b/Lib/test/test_rlcompleter.py
@@ -79,6 +79,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')