Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 1 | # Test packages (dotted-name import) |
| 2 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 3 | import sys |
| 4 | import os |
| 5 | import tempfile |
| 6 | import textwrap |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 7 | import unittest |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 8 | from test import support |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 9 | |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 10 | |
| 11 | # Helpers to create and destroy hierarchies. |
| 12 | |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 13 | def cleanout(root): |
| 14 | names = os.listdir(root) |
| 15 | for name in names: |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 16 | fullname = os.path.join(root, name) |
| 17 | if os.path.isdir(fullname) and not os.path.islink(fullname): |
| 18 | cleanout(fullname) |
| 19 | else: |
| 20 | os.remove(fullname) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 21 | os.rmdir(root) |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 22 | |
Barry Warsaw | 3a9d061 | 2000-09-01 06:53:52 +0000 | [diff] [blame] | 23 | def fixdir(lst): |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 24 | if "__builtins__" in lst: |
| 25 | lst.remove("__builtins__") |
Barry Warsaw | 3a9d061 | 2000-09-01 06:53:52 +0000 | [diff] [blame] | 26 | return lst |
| 27 | |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 28 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 29 | # XXX Things to test |
| 30 | # |
| 31 | # import package without __init__ |
| 32 | # import package with __init__ |
| 33 | # __init__ importing submodule |
| 34 | # __init__ importing global module |
| 35 | # __init__ defining variables |
| 36 | # submodule importing other submodule |
| 37 | # submodule importing global module |
| 38 | # submodule import submodule via global name |
| 39 | # from package import submodule |
| 40 | # from package import subpackage |
| 41 | # from package import variable (defined in __init__) |
| 42 | # from package import * (defined in __init__) |
| 43 | |
| 44 | |
Christian Heimes | db4a2ef | 2007-11-12 19:53:03 +0000 | [diff] [blame] | 45 | class TestPkg(unittest.TestCase): |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 46 | |
| 47 | def setUp(self): |
| 48 | self.root = None |
Christian Heimes | dae2a89 | 2008-04-19 00:55:37 +0000 | [diff] [blame] | 49 | self.pkgname = None |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 50 | self.syspath = list(sys.path) |
Antoine Pitrou | ca15409 | 2009-11-13 16:31:51 +0000 | [diff] [blame] | 51 | self.modules_before = support.modules_setup() |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 52 | |
| 53 | def tearDown(self): |
| 54 | sys.path[:] = self.syspath |
Antoine Pitrou | ca15409 | 2009-11-13 16:31:51 +0000 | [diff] [blame] | 55 | support.modules_cleanup(*self.modules_before) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 56 | cleanout(self.root) |
| 57 | |
Ezio Melotti | 1392500 | 2011-03-16 11:05:33 +0200 | [diff] [blame] | 58 | # delete all modules concerning the tested hierarchy |
Christian Heimes | dae2a89 | 2008-04-19 00:55:37 +0000 | [diff] [blame] | 59 | if self.pkgname: |
| 60 | modules = [name for name in sys.modules |
| 61 | if self.pkgname in name.split('.')] |
| 62 | for name in modules: |
| 63 | del sys.modules[name] |
| 64 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 65 | def run_code(self, code): |
| 66 | exec(textwrap.dedent(code), globals(), {"self": self}) |
| 67 | |
| 68 | def mkhier(self, descr): |
| 69 | root = tempfile.mkdtemp() |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 70 | sys.path.insert(0, root) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 71 | if not os.path.isdir(root): |
| 72 | os.mkdir(root) |
| 73 | for name, contents in descr: |
| 74 | comps = name.split() |
| 75 | fullname = root |
| 76 | for c in comps: |
| 77 | fullname = os.path.join(fullname, c) |
| 78 | if contents is None: |
| 79 | os.mkdir(fullname) |
| 80 | else: |
| 81 | f = open(fullname, "w") |
| 82 | f.write(contents) |
| 83 | if contents and contents[-1] != '\n': |
| 84 | f.write('\n') |
| 85 | f.close() |
| 86 | self.root = root |
Christian Heimes | dae2a89 | 2008-04-19 00:55:37 +0000 | [diff] [blame] | 87 | # package name is the name of the first item |
| 88 | self.pkgname = descr[0][0] |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 89 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 90 | def test_1(self): |
| 91 | hier = [("t1", None), ("t1 __init__.py", "")] |
| 92 | self.mkhier(hier) |
| 93 | import t1 |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 94 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 95 | def test_2(self): |
| 96 | hier = [ |
| 97 | ("t2", None), |
| 98 | ("t2 __init__.py", "'doc for t2'"), |
| 99 | ("t2 sub", None), |
| 100 | ("t2 sub __init__.py", ""), |
| 101 | ("t2 sub subsub", None), |
| 102 | ("t2 sub subsub __init__.py", "spam = 1"), |
| 103 | ] |
| 104 | self.mkhier(hier) |
Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 105 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 106 | import t2 |
| 107 | self.assertEqual(t2.__doc__, "doc for t2") |
Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 108 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 109 | import t2.sub |
| 110 | import t2.sub.subsub |
| 111 | self.assertEqual(t2.__name__, "t2") |
| 112 | self.assertEqual(t2.sub.__name__, "t2.sub") |
| 113 | self.assertEqual(t2.sub.subsub.__name__, "t2.sub.subsub") |
Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 114 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 115 | # This exec crap is needed because Py3k forbids 'import *' outside |
| 116 | # of module-scope and __import__() is insufficient for what we need. |
| 117 | s = """ |
| 118 | import t2 |
| 119 | from t2 import * |
| 120 | self.assertEqual(dir(), ['self', 'sub', 't2']) |
| 121 | """ |
| 122 | self.run_code(s) |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 123 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 124 | from t2 import sub |
| 125 | from t2.sub import subsub |
| 126 | from t2.sub.subsub import spam |
| 127 | self.assertEqual(sub.__name__, "t2.sub") |
| 128 | self.assertEqual(subsub.__name__, "t2.sub.subsub") |
| 129 | self.assertEqual(sub.subsub.__name__, "t2.sub.subsub") |
| 130 | for name in ['spam', 'sub', 'subsub', 't2']: |
Georg Brandl | ab91fde | 2009-08-13 08:51:18 +0000 | [diff] [blame] | 131 | self.assertTrue(locals()["name"], "Failed to import %s" % name) |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 132 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 133 | import t2.sub |
| 134 | import t2.sub.subsub |
| 135 | self.assertEqual(t2.__name__, "t2") |
| 136 | self.assertEqual(t2.sub.__name__, "t2.sub") |
| 137 | self.assertEqual(t2.sub.subsub.__name__, "t2.sub.subsub") |
Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 138 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 139 | s = """ |
| 140 | from t2 import * |
Georg Brandl | ab91fde | 2009-08-13 08:51:18 +0000 | [diff] [blame] | 141 | self.assertTrue(dir(), ['self', 'sub']) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 142 | """ |
| 143 | self.run_code(s) |
Guido van Rossum | c8bf884 | 1997-09-08 16:06:20 +0000 | [diff] [blame] | 144 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 145 | def test_3(self): |
| 146 | hier = [ |
| 147 | ("t3", None), |
| 148 | ("t3 __init__.py", ""), |
| 149 | ("t3 sub", None), |
| 150 | ("t3 sub __init__.py", ""), |
| 151 | ("t3 sub subsub", None), |
| 152 | ("t3 sub subsub __init__.py", "spam = 1"), |
| 153 | ] |
| 154 | self.mkhier(hier) |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 155 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 156 | import t3.sub.subsub |
| 157 | self.assertEqual(t3.__name__, "t3") |
| 158 | self.assertEqual(t3.sub.__name__, "t3.sub") |
| 159 | self.assertEqual(t3.sub.subsub.__name__, "t3.sub.subsub") |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 160 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 161 | def test_4(self): |
| 162 | hier = [ |
| 163 | ("t4.py", "raise RuntimeError('Shouldnt load t4.py')"), |
| 164 | ("t4", None), |
| 165 | ("t4 __init__.py", ""), |
| 166 | ("t4 sub.py", "raise RuntimeError('Shouldnt load sub.py')"), |
| 167 | ("t4 sub", None), |
| 168 | ("t4 sub __init__.py", ""), |
Thomas Wouters | ed03b41 | 2007-08-28 21:37:11 +0000 | [diff] [blame] | 169 | ("t4 sub subsub.py", |
| 170 | "raise RuntimeError('Shouldnt load subsub.py')"), |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 171 | ("t4 sub subsub", None), |
| 172 | ("t4 sub subsub __init__.py", "spam = 1"), |
| 173 | ] |
| 174 | self.mkhier(hier) |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 175 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 176 | s = """ |
| 177 | from t4.sub.subsub import * |
| 178 | self.assertEqual(spam, 1) |
| 179 | """ |
| 180 | self.run_code(s) |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 181 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 182 | def test_5(self): |
| 183 | hier = [ |
| 184 | ("t5", None), |
| 185 | ("t5 __init__.py", "import t5.foo"), |
| 186 | ("t5 string.py", "spam = 1"), |
| 187 | ("t5 foo.py", |
| 188 | "from . import string; assert string.spam == 1"), |
| 189 | ] |
| 190 | self.mkhier(hier) |
Guido van Rossum | 6c61242 | 1997-09-06 18:42:57 +0000 | [diff] [blame] | 191 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 192 | import t5 |
| 193 | s = """ |
| 194 | from t5 import * |
| 195 | self.assertEqual(dir(), ['foo', 'self', 'string', 't5']) |
| 196 | """ |
| 197 | self.run_code(s) |
Guido van Rossum | 10887a3 | 1997-09-07 06:12:11 +0000 | [diff] [blame] | 198 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 199 | import t5 |
| 200 | self.assertEqual(fixdir(dir(t5)), |
| 201 | ['__doc__', '__file__', '__name__', |
Christian Heimes | cbf3b5c | 2007-12-03 21:02:03 +0000 | [diff] [blame] | 202 | '__package__', '__path__', 'foo', 'string', 't5']) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 203 | self.assertEqual(fixdir(dir(t5.foo)), |
Christian Heimes | cbf3b5c | 2007-12-03 21:02:03 +0000 | [diff] [blame] | 204 | ['__doc__', '__file__', '__name__', '__package__', |
| 205 | 'string']) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 206 | self.assertEqual(fixdir(dir(t5.string)), |
Christian Heimes | cbf3b5c | 2007-12-03 21:02:03 +0000 | [diff] [blame] | 207 | ['__doc__', '__file__', '__name__','__package__', |
| 208 | 'spam']) |
Guido van Rossum | 5f4fb91 | 1998-05-19 15:09:42 +0000 | [diff] [blame] | 209 | |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 210 | def test_6(self): |
| 211 | hier = [ |
| 212 | ("t6", None), |
Thomas Wouters | ed03b41 | 2007-08-28 21:37:11 +0000 | [diff] [blame] | 213 | ("t6 __init__.py", |
| 214 | "__all__ = ['spam', 'ham', 'eggs']"), |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 215 | ("t6 spam.py", ""), |
| 216 | ("t6 ham.py", ""), |
| 217 | ("t6 eggs.py", ""), |
| 218 | ] |
| 219 | self.mkhier(hier) |
| 220 | |
| 221 | import t6 |
| 222 | self.assertEqual(fixdir(dir(t6)), |
| 223 | ['__all__', '__doc__', '__file__', |
Christian Heimes | cbf3b5c | 2007-12-03 21:02:03 +0000 | [diff] [blame] | 224 | '__name__', '__package__', '__path__']) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 225 | s = """ |
| 226 | import t6 |
| 227 | from t6 import * |
| 228 | self.assertEqual(fixdir(dir(t6)), |
| 229 | ['__all__', '__doc__', '__file__', |
Christian Heimes | cbf3b5c | 2007-12-03 21:02:03 +0000 | [diff] [blame] | 230 | '__name__', '__package__', '__path__', |
| 231 | 'eggs', 'ham', 'spam']) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 232 | self.assertEqual(dir(), ['eggs', 'ham', 'self', 'spam', 't6']) |
| 233 | """ |
| 234 | self.run_code(s) |
| 235 | |
| 236 | def test_7(self): |
| 237 | hier = [ |
| 238 | ("t7.py", ""), |
| 239 | ("t7", None), |
| 240 | ("t7 __init__.py", ""), |
Thomas Wouters | ed03b41 | 2007-08-28 21:37:11 +0000 | [diff] [blame] | 241 | ("t7 sub.py", |
| 242 | "raise RuntimeError('Shouldnt load sub.py')"), |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 243 | ("t7 sub", None), |
| 244 | ("t7 sub __init__.py", ""), |
Thomas Wouters | ed03b41 | 2007-08-28 21:37:11 +0000 | [diff] [blame] | 245 | ("t7 sub .py", |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 246 | "raise RuntimeError('Shouldnt load subsub.py')"), |
| 247 | ("t7 sub subsub", None), |
| 248 | ("t7 sub subsub __init__.py", |
| 249 | "spam = 1"), |
| 250 | ] |
| 251 | self.mkhier(hier) |
| 252 | |
| 253 | |
| 254 | t7, sub, subsub = None, None, None |
| 255 | import t7 as tas |
| 256 | self.assertEqual(fixdir(dir(tas)), |
Christian Heimes | cbf3b5c | 2007-12-03 21:02:03 +0000 | [diff] [blame] | 257 | ['__doc__', '__file__', '__name__', |
| 258 | '__package__', '__path__']) |
Georg Brandl | ab91fde | 2009-08-13 08:51:18 +0000 | [diff] [blame] | 259 | self.assertFalse(t7) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 260 | from t7 import sub as subpar |
| 261 | self.assertEqual(fixdir(dir(subpar)), |
Christian Heimes | cbf3b5c | 2007-12-03 21:02:03 +0000 | [diff] [blame] | 262 | ['__doc__', '__file__', '__name__', |
| 263 | '__package__', '__path__']) |
Georg Brandl | ab91fde | 2009-08-13 08:51:18 +0000 | [diff] [blame] | 264 | self.assertFalse(t7) |
| 265 | self.assertFalse(sub) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 266 | from t7.sub import subsub as subsubsub |
| 267 | self.assertEqual(fixdir(dir(subsubsub)), |
Christian Heimes | cbf3b5c | 2007-12-03 21:02:03 +0000 | [diff] [blame] | 268 | ['__doc__', '__file__', '__name__', |
| 269 | '__package__', '__path__', 'spam']) |
Georg Brandl | ab91fde | 2009-08-13 08:51:18 +0000 | [diff] [blame] | 270 | self.assertFalse(t7) |
| 271 | self.assertFalse(sub) |
| 272 | self.assertFalse(subsub) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 273 | from t7.sub.subsub import spam as ham |
| 274 | self.assertEqual(ham, 1) |
Georg Brandl | ab91fde | 2009-08-13 08:51:18 +0000 | [diff] [blame] | 275 | self.assertFalse(t7) |
| 276 | self.assertFalse(sub) |
| 277 | self.assertFalse(subsub) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 278 | |
| 279 | |
| 280 | def test_main(): |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 281 | support.run_unittest(__name__) |
Collin Winter | 11e065b | 2007-08-24 19:15:12 +0000 | [diff] [blame] | 282 | |
| 283 | |
| 284 | if __name__ == "__main__": |
| 285 | test_main() |