Commit b9da3bd8 authored by Jason R. Coombs's avatar Jason R. Coombs

Added test to capture issue #118

--HG--
branch : distribute
extra : rebase_source : 5c247cafcbecb311469147a46f7f82df47ea5341
parent 2762c22f
...@@ -6,7 +6,20 @@ import shutil ...@@ -6,7 +6,20 @@ import shutil
import unittest import unittest
import tempfile import tempfile
from setuptools.sandbox import DirectorySandbox from setuptools.sandbox import DirectorySandbox, SandboxViolation
def has_win32com():
"""
Run this to determine if the local machine has win32com, and if it
does, include additional tests.
"""
if not sys.platform.startswith('win32'):
return False
try:
mod = __import__('win32com')
except ImportError:
return False
return True
class TestSandbox(unittest.TestCase): class TestSandbox(unittest.TestCase):
...@@ -18,11 +31,33 @@ class TestSandbox(unittest.TestCase): ...@@ -18,11 +31,33 @@ class TestSandbox(unittest.TestCase):
def test_devnull(self): def test_devnull(self):
sandbox = DirectorySandbox(self.dir) sandbox = DirectorySandbox(self.dir)
sandbox.run(self._file_writer(os.devnull))
def _write(): @staticmethod
f = open(os.devnull, 'w') def _file_writer(path):
def do_write():
f = open(path, 'w')
f.write('xxx') f.write('xxx')
f.close() f.close()
return do_write
sandbox.run(_write)
if has_win32com():
def test_win32com(self):
"""
win32com should not be prevented from caching COM interfaces
in gen_py.
"""
import win32com
gen_py = win32com.__gen_path__
target = os.path.join(gen_py, 'test_write')
sandbox = DirectorySandbox(self.dir)
try:
sandbox.run(self._file_writer(target))
except SandboxViolation:
self.fail("Could not create gen_py file due to SandboxViolation")
finally:
if os.path.exists(target): os.remove(target)
if __name__ == '__main__':
unittest.main()
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment