Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
c24136c5
Commit
c24136c5
authored
Jul 20, 2012
by
Brett Cannon
Browse files
Options
Browse Files
Download
Plain Diff
Merge
parents
9c9d9075
fc1c2928
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
25 additions
and
41 deletions
+25
-41
Lib/test/test_import.py
Lib/test/test_import.py
+21
-40
Misc/NEWS
Misc/NEWS
+4
-1
No files found.
Lib/test/test_import.py
View file @
c24136c5
...
...
@@ -2,7 +2,6 @@
import
importlib
import
builtins
import
imp
from
importlib.test.import_
import
test_suite
as
importlib_import_test_suite
from
importlib.test.import_
import
util
as
importlib_util
import
marshal
import
os
...
...
@@ -705,36 +704,34 @@ class PycacheTests(unittest.TestCase):
class
TestSymbolicallyLinkedPackage
(
unittest
.
TestCase
):
package_name
=
'sample'
tagged
=
package_name
+
'-tagged'
def
setUp
(
self
):
if
os
.
path
.
exists
(
self
.
tagged
):
shutil
.
rmtree
(
self
.
tagged
)
if
os
.
path
.
exists
(
self
.
package_name
):
os
.
remove
(
self
.
package_name
)
test
.
support
.
rmtree
(
self
.
tagged
)
test
.
support
.
rmtree
(
self
.
package_name
)
self
.
orig_sys_path
=
sys
.
path
[:]
# create a sample package; imagine you have a package with a tag and
# you want to symbolically link it from its untagged name.
os
.
mkdir
(
self
.
tagged
)
self
.
addCleanup
(
test
.
support
.
rmtree
,
self
.
tagged
)
init_file
=
os
.
path
.
join
(
self
.
tagged
,
'__init__.py'
)
open
(
init_file
,
'w'
).
close
(
)
self
.
assertEqual
(
os
.
path
.
exists
(
init_file
),
Tru
e
)
test
.
support
.
create_empty_file
(
init_file
)
assert
os
.
path
.
exists
(
init_fil
e
)
# now create a symlink to the tagged package
# sample -> sample-tagged
os
.
symlink
(
self
.
tagged
,
self
.
package_name
)
self
.
addCleanup
(
test
.
support
.
unlink
,
self
.
package_name
)
importlib
.
invalidate_caches
()
# disabled because os.isdir currently fails (see issue 15093)
# self.assertEqual(os.path.isdir(self.package_name), True)
self
.
assertEqual
(
os
.
path
.
isfile
(
os
.
path
.
join
(
self
.
package_name
,
'__init__.py'
)),
True
,
)
assert
os
.
path
.
isfile
(
os
.
path
.
join
(
self
.
package_name
,
'__init__.py'
))
@
property
def
tagged
(
self
):
return
self
.
package_name
+
'-tagged'
def
tearDown
(
self
):
sys
.
path
[:]
=
self
.
orig_sys_path
# regression test for issue6727
@
unittest
.
skipUnless
(
...
...
@@ -742,24 +739,14 @@ class TestSymbolicallyLinkedPackage(unittest.TestCase):
or
sys
.
getwindowsversion
()
>=
(
6
,
0
),
"Windows Vista or later required"
)
@
test
.
support
.
skip_unless_symlink
@
unittest
.
skipUnless
(
sys
.
platform
==
'win32'
,
"Test failing on Unix (see issue15091)"
)
def
test_symlinked_dir_importable
(
self
):
# make sure sample can only be imported from the current directory.
sys
.
path
[:]
=
[
'.'
]
assert
os
.
path
.
exists
(
self
.
package_name
)
assert
os
.
path
.
exists
(
os
.
path
.
join
(
self
.
package_name
,
'__init__.py'
))
# and try to import the package
__import__
(
self
.
package_name
)
def
tearDown
(
self
):
# now cleanup
if
os
.
path
.
exists
(
self
.
package_name
):
os
.
remove
(
self
.
package_name
)
if
os
.
path
.
exists
(
self
.
tagged
):
shutil
.
rmtree
(
self
.
tagged
)
sys
.
path
[:]
=
self
.
orig_sys_path
# Try to import the package
importlib
.
import_module
(
self
.
package_name
)
@
cpython_only
...
...
@@ -881,18 +868,12 @@ class ImportTracebackTests(unittest.TestCase):
def
test_main
(
verbose
=
None
):
flag
=
importlib_util
.
using___import__
try
:
importlib_util
.
using___import__
=
True
run_unittest
(
ImportTests
,
PycacheTests
,
PycRewritingTests
,
PathsTests
,
RelativeImportTests
,
OverridingImportBuiltinTests
,
ImportlibBootstrapTests
,
TestSymbolicallyLinkedPackage
,
ImportTracebackTests
,
importlib_import_test_suite
())
finally
:
importlib_util
.
using___import__
=
flag
run_unittest
(
ImportTests
,
PycacheTests
,
PycRewritingTests
,
PathsTests
,
RelativeImportTests
,
OverridingImportBuiltinTests
,
ImportlibBootstrapTests
,
TestSymbolicallyLinkedPackage
,
ImportTracebackTests
)
if
__name__
==
'__main__'
:
...
...
Misc/NEWS
View file @
c24136c5
...
...
@@ -181,7 +181,10 @@ Documentation
Tests
-----
-
Issue
#
15230
:
Adopted
a
more
systematic
approach
in
the
runpy
tests
-
Issue
#
15091
:
Reactivate
a
test
on
UNIX
which
was
failing
thanks
to
a
forgotten
importlib
.
invalidate_caches
()
call
.
-
Issue
#
15230
:
Adopted
a
more
systematic
approach
in
the
runpy
tests
.
-
Issue
#
15300
:
Ensure
the
temporary
test
working
directories
are
in
the
same
parent
folder
when
running
tests
in
multiprocess
mode
from
a
Python
build
.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment