diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2010-08-04 15:43:16 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-08-04 15:43:16 (GMT) |
commit | 482e66a58a8c38b8f4c2cc4f588a656d0c8fb2df (patch) | |
tree | f80d4f7c2602b8a3a8ce253cb5b24c10f3a938da | |
parent | e99f507c98fd56f48ad0c9d5f61b3e816adeb51e (diff) | |
download | cpython-482e66a58a8c38b8f4c2cc4f588a656d0c8fb2df.zip cpython-482e66a58a8c38b8f4c2cc4f588a656d0c8fb2df.tar.gz cpython-482e66a58a8c38b8f4c2cc4f588a656d0c8fb2df.tar.bz2 |
Issue #9496: Provide a test suite for the rlcompleter module. Patch by
Michele Orrù.
-rw-r--r-- | Lib/test/test_rlcompleter.py | 73 | ||||
-rw-r--r-- | Lib/test/test_sundry.py | 1 | ||||
-rw-r--r-- | Misc/ACKS | 1 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
4 files changed, 77 insertions, 1 deletions
diff --git a/Lib/test/test_rlcompleter.py b/Lib/test/test_rlcompleter.py new file mode 100644 index 0000000..29e6a1b --- /dev/null +++ b/Lib/test/test_rlcompleter.py @@ -0,0 +1,73 @@ +from test import support +import unittest +import builtins +import rlcompleter + +class CompleteMe: + """ Trivial class used in testing rlcompleter.Completer. """ + spam = 1 + + +class TestRlcompleter(unittest.TestCase): + def setUp(self): + self.stdcompleter = rlcompleter.Completer() + self.completer = rlcompleter.Completer(dict(spam=int, + egg=str, + CompleteMe=CompleteMe)) + + # forces stdcompleter to bind builtins namespace + self.stdcompleter.complete('', 0) + + def test_namespace(self): + class A(dict): + pass + class B(list): + pass + + self.assertTrue(self.stdcompleter.use_main_ns) + self.assertFalse(self.completer.use_main_ns) + self.assertFalse(rlcompleter.Completer(A()).use_main_ns) + self.assertRaises(TypeError, rlcompleter.Completer, B((1,))) + + def test_global_matches(self): + # test with builtins namespace + self.assertEqual(self.stdcompleter.global_matches('di'), + [x+'(' for x in dir(builtins) if x.startswith('di')]) + self.assertEqual(self.stdcompleter.global_matches('st'), + [x+'(' for x in dir(builtins) if x.startswith('st')]) + self.assertEqual(self.stdcompleter.global_matches('akaksajadhak'), []) + + # test with a customized namespace + self.assertEqual(self.completer.global_matches('CompleteM'), + ['CompleteMe(']) + self.assertEqual(self.completer.global_matches('eg'), + ['egg(']) + # XXX: see issue5256 + self.assertEqual(self.completer.global_matches('CompleteM'), + ['CompleteMe(']) + + def test_attr_matches(self): + # test with builtins namespace + self.assertEqual(self.stdcompleter.attr_matches('str.s'), + ['str.{}('.format(x) for x in dir(str) + if x.startswith('s')]) + self.assertEqual(self.stdcompleter.attr_matches('tuple.foospamegg'), []) + + # test with a customized namespace + self.assertEqual(self.completer.attr_matches('CompleteMe.sp'), + ['CompleteMe.spam']) + self.assertEqual(self.completer.attr_matches('Completeme.egg'), []) + + CompleteMe.me = CompleteMe + self.assertEqual(self.completer.attr_matches('CompleteMe.me.me.sp'), + ['CompleteMe.me.me.spam']) + self.assertEqual(self.completer.attr_matches('egg.s'), + ['egg.{}('.format(x) for x in dir(str) + if x.startswith('s')]) + +def test_main(): + support.run_unittest(TestRlcompleter) + + +if __name__ == '__main__': + test_main() diff --git a/Lib/test/test_sundry.py b/Lib/test/test_sundry.py index 065c685..a57ed44 100644 --- a/Lib/test/test_sundry.py +++ b/Lib/test/test_sundry.py @@ -56,7 +56,6 @@ class TestUntestedModules(unittest.TestCase): import os2emxpath import pstats import py_compile - import rlcompleter import sndhdr import symbol import tabnanny @@ -591,6 +591,7 @@ Grant Olson Piet van Oostrum Jason Orendorff Douglas Orr +Michele Orrù Denis S. Otkidach Michael Otteneder R. M. Oudkerk @@ -108,6 +108,9 @@ Tools/Demos Tests ----- +- Issue #9496: Provide a test suite for the rlcompleter module. Patch by + Michele Orrù. + - Issue #8687: provide a test suite for sched.py module. |