[Python-Dev] Looking for an "import" expert

Guido van Rossum guido@beopen.com
Mon, 21 Aug 2000 19:00:41 -0500


If the tests are run "the modern way" (python ../Lib/test/regrtest.py)
then the test module is the script directory and it is on the path, so
"import test_support" sees and loads a toplevel module test_support.
Then "import test.test_support" sees a package test with a
test_support submodule which is assumed to be a different one, so it
is loaded again.

But if the tests are run via "import test.autotest" (or "import
test.regrtest; test.regrtest.main()" the "import test_support" knows
that the importing module is in the test package, so it first tries to
import the test_support submodule from that package, so
test.test_support and (plain) test_support are the same.

Conclusion: inside the test package, never refer explicitly to the
test package.  Always use "import test_support".  Never "import
test.test_support" or "from test.test_support import verbose" or "from
test import test_support".

This is one for the README!

I've fixed this by checking in a small patch to test_getopt.py and the
corresponding output file (because of the bug, the output file was
produced under verbose mode).

--Guido van Rossum (home page: http://www.pythonlabs.com/~guido/)