From 4710c53dcad1ebf3755f3efb9e80ac24bd72a9b2 Mon Sep 17 00:00:00 2001 From: darylm503 Date: Mon, 16 Apr 2012 22:12:42 +0000 Subject: 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 --- .../Python/Python-2.7.2/Lib/test/test___all__.py | 123 +++++++++++++++++++++ 1 file changed, 123 insertions(+) create mode 100644 AppPkg/Applications/Python/Python-2.7.2/Lib/test/test___all__.py (limited to 'AppPkg/Applications/Python/Python-2.7.2/Lib/test/test___all__.py') diff --git a/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test___all__.py b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test___all__.py new file mode 100644 index 0000000000..27ce69f106 --- /dev/null +++ b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test___all__.py @@ -0,0 +1,123 @@ +from __future__ import print_function + +import unittest +from test import test_support as support +import os +import sys + +# Setup bsddb warnings +try: + bsddb = support.import_module('bsddb', deprecated=True) +except unittest.SkipTest: + pass + + +class NoAll(RuntimeError): + pass + +class FailedImport(RuntimeError): + pass + + +class AllTest(unittest.TestCase): + + def check_all(self, modname): + names = {} + with support.check_warnings((".* (module|package)", + DeprecationWarning), quiet=True): + try: + exec "import %s" % modname in names + except: + # Silent fail here seems the best route since some modules + # may not be available or not initialize properly in all + # environments. + raise FailedImport(modname) + if not hasattr(sys.modules[modname], "__all__"): + raise NoAll(modname) + names = {} + try: + exec "from %s import *" % modname in names + except Exception as e: + # Include the module name in the exception string + self.fail("__all__ failure in {}: {}: {}".format( + modname, e.__class__.__name__, e)) + if "__builtins__" in names: + del names["__builtins__"] + keys = set(names) + all = set(sys.modules[modname].__all__) + self.assertEqual(keys, all) + + def walk_modules(self, basedir, modpath): + for fn in sorted(os.listdir(basedir)): + path = os.path.join(basedir, fn) + if os.path.isdir(path): + pkg_init = os.path.join(path, '__init__.py') + if os.path.exists(pkg_init): + yield pkg_init, modpath + fn + for p, m in self.walk_modules(path, modpath + fn + "."): + yield p, m + continue + if not fn.endswith('.py') or fn == '__init__.py': + continue + yield path, modpath + fn[:-3] + + def test_all(self): + # Blacklisted modules and packages + blacklist = set([ + # Will raise a SyntaxError when compiling the exec statement + '__future__', + ]) + + if not sys.platform.startswith('java'): + # In case _socket fails to build, make this test fail more gracefully + # than an AttributeError somewhere deep in CGIHTTPServer. + import _socket + + # rlcompleter needs special consideration; it import readline which + # initializes GNU readline which calls setlocale(LC_CTYPE, "")... :-( + try: + import rlcompleter + import locale + except ImportError: + pass + else: + locale.setlocale(locale.LC_CTYPE, 'C') + + ignored = [] + failed_imports = [] + lib_dir = os.path.dirname(os.path.dirname(__file__)) + for path, modname in self.walk_modules(lib_dir, ""): + m = modname + blacklisted = False + while m: + if m in blacklist: + blacklisted = True + break + m = m.rpartition('.')[0] + if blacklisted: + continue + if support.verbose: + print(modname) + try: + # This heuristic speeds up the process by removing, de facto, + # most test modules (and avoiding the auto-executing ones). + with open(path, "rb") as f: + if "__all__" not in f.read(): + raise NoAll(modname) + self.check_all(modname) + except NoAll: + ignored.append(modname) + except FailedImport: + failed_imports.append(modname) + + if support.verbose: + print('Following modules have no __all__ and have been ignored:', + ignored) + print('Following modules failed to be imported:', failed_imports) + + +def test_main(): + support.run_unittest(AllTest) + +if __name__ == "__main__": + test_main() -- cgit v1.2.3