Merged in embray/pytest (pull request #37)
Adds a test for and fixes #112
This commit is contained in:
commit
2951c3ace9
|
@ -177,6 +177,10 @@ def _write_pyc(co, source_path, pyc):
|
||||||
# This happens when we get a EEXIST in find_module creating the
|
# This happens when we get a EEXIST in find_module creating the
|
||||||
# __pycache__ directory and __pycache__ is by some non-dir node.
|
# __pycache__ directory and __pycache__ is by some non-dir node.
|
||||||
return False
|
return False
|
||||||
|
elif err == errno.EACCES:
|
||||||
|
# The directory is read-only; this can happen for example when
|
||||||
|
# running the tests in a package installed as root
|
||||||
|
return False
|
||||||
raise
|
raise
|
||||||
try:
|
try:
|
||||||
fp.write(imp.get_magic())
|
fp.write(imp.get_magic())
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import os
|
import os
|
||||||
|
import stat
|
||||||
import sys
|
import sys
|
||||||
import zipfile
|
import zipfile
|
||||||
import py
|
import py
|
||||||
|
@ -319,10 +320,22 @@ class TestRewriteOnImport:
|
||||||
def test_pycache_is_a_file(self, testdir):
|
def test_pycache_is_a_file(self, testdir):
|
||||||
testdir.tmpdir.join("__pycache__").write("Hello")
|
testdir.tmpdir.join("__pycache__").write("Hello")
|
||||||
testdir.makepyfile("""
|
testdir.makepyfile("""
|
||||||
def test_rewritten():
|
def test_rewritten():
|
||||||
assert "@py_builtins" in globals()""")
|
assert "@py_builtins" in globals()""")
|
||||||
assert testdir.runpytest().ret == 0
|
assert testdir.runpytest().ret == 0
|
||||||
|
|
||||||
|
def test_pycache_is_readonly(self, testdir):
|
||||||
|
cache = testdir.tmpdir.mkdir("__pycache__")
|
||||||
|
old_mode = cache.stat().mode
|
||||||
|
cache.chmod(old_mode ^ stat.S_IWRITE)
|
||||||
|
testdir.makepyfile("""
|
||||||
|
def test_rewritten():
|
||||||
|
assert "@py_builtins" in globals()""")
|
||||||
|
try:
|
||||||
|
assert testdir.runpytest().ret == 0
|
||||||
|
finally:
|
||||||
|
cache.chmod(old_mode)
|
||||||
|
|
||||||
def test_zipfile(self, testdir):
|
def test_zipfile(self, testdir):
|
||||||
z = testdir.tmpdir.join("myzip.zip")
|
z = testdir.tmpdir.join("myzip.zip")
|
||||||
z_fn = str(z)
|
z_fn = str(z)
|
||||||
|
@ -334,9 +347,9 @@ def test_rewritten():
|
||||||
f.close()
|
f.close()
|
||||||
z.chmod(256)
|
z.chmod(256)
|
||||||
testdir.makepyfile("""
|
testdir.makepyfile("""
|
||||||
import sys
|
import sys
|
||||||
sys.path.append(%r)
|
sys.path.append(%r)
|
||||||
import test_gum.test_lizard""" % (z_fn,))
|
import test_gum.test_lizard""" % (z_fn,))
|
||||||
assert testdir.runpytest().ret == 0
|
assert testdir.runpytest().ret == 0
|
||||||
|
|
||||||
def test_readonly(self, testdir):
|
def test_readonly(self, testdir):
|
||||||
|
@ -345,17 +358,21 @@ import test_gum.test_lizard""" % (z_fn,))
|
||||||
py.builtin._totext("""
|
py.builtin._totext("""
|
||||||
def test_rewritten():
|
def test_rewritten():
|
||||||
assert "@py_builtins" in globals()
|
assert "@py_builtins" in globals()
|
||||||
""").encode("utf-8"), "wb")
|
""").encode("utf-8"), "wb")
|
||||||
|
old_mode = sub.stat().mode
|
||||||
sub.chmod(320)
|
sub.chmod(320)
|
||||||
assert testdir.runpytest().ret == 0
|
try:
|
||||||
|
assert testdir.runpytest().ret == 0
|
||||||
|
finally:
|
||||||
|
sub.chmod(old_mode)
|
||||||
|
|
||||||
def test_dont_write_bytecode(self, testdir, monkeypatch):
|
def test_dont_write_bytecode(self, testdir, monkeypatch):
|
||||||
testdir.makepyfile("""
|
testdir.makepyfile("""
|
||||||
import os
|
import os
|
||||||
def test_no_bytecode():
|
def test_no_bytecode():
|
||||||
assert "__pycache__" in __cached__
|
assert "__pycache__" in __cached__
|
||||||
assert not os.path.exists(__cached__)
|
assert not os.path.exists(__cached__)
|
||||||
assert not os.path.exists(os.path.dirname(__cached__))""")
|
assert not os.path.exists(os.path.dirname(__cached__))""")
|
||||||
monkeypatch.setenv("PYTHONDONTWRITEBYTECODE", "1")
|
monkeypatch.setenv("PYTHONDONTWRITEBYTECODE", "1")
|
||||||
assert testdir.runpytest().ret == 0
|
assert testdir.runpytest().ret == 0
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue