summaryrefslogtreecommitdiff
path: root/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_rlcompleter.py
diff options
context:
space:
mode:
authordarylm503 <darylm503@6f19259b-4bc3-4df7-8a09-765794883524>2012-04-16 22:12:42 +0000
committerdarylm503 <darylm503@6f19259b-4bc3-4df7-8a09-765794883524>2012-04-16 22:12:42 +0000
commit4710c53dcad1ebf3755f3efb9e80ac24bd72a9b2 (patch)
tree2d17d2388a78082e32f6a97120d707328143543b /AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_rlcompleter.py
parentcbc6b5e54599c7391ece99ad3c5313f4dd4ddda6 (diff)
downloadedk2-platforms-4710c53dcad1ebf3755f3efb9e80ac24bd72a9b2.tar.xz
AppPkg/Applications/Python: Add Python 2.7.2 sources since the release of Python 2.7.3 made them unavailable from the python.org web site.
These files are a subset of the python-2.7.2.tgz distribution from python.org. Changed files from PyMod-2.7.2 have been copied into the corresponding directories of this tree, replacing the original files in the distribution. Signed-off-by: daryl.mcdaniel@intel.com git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@13197 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_rlcompleter.py')
-rw-r--r--AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_rlcompleter.py73
1 files changed, 73 insertions, 0 deletions
diff --git a/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_rlcompleter.py b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_rlcompleter.py
new file mode 100644
index 0000000000..53ca167a73
--- /dev/null
+++ b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_rlcompleter.py
@@ -0,0 +1,73 @@
+from test import test_support as support
+import unittest
+import __builtin__ as builtins
+import rlcompleter
+
+class CompleteMe(object):
+ """ 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(sorted(self.stdcompleter.global_matches('di')),
+ [x+'(' for x in dir(builtins) if x.startswith('di')])
+ self.assertEqual(sorted(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()