Commit f4a5588d authored by Nicolas Dumazet's avatar Nicolas Dumazet

add a test to check behavior when __compile__ directory already exists

parent 870f92ea
from zope.testing import doctest from zope.testing import doctest
from zope.testing import renormalizing from zope.testing import renormalizing
import errno
import os import os
import re import re
import shutil import shutil
...@@ -37,10 +38,15 @@ class NonInformativeTests(unittest.TestCase): ...@@ -37,10 +38,15 @@ class NonInformativeTests(unittest.TestCase):
def make_recipe(self, buildout, name, options): def make_recipe(self, buildout, name, options):
from hexagonit.recipe.cmmi import Recipe from hexagonit.recipe.cmmi import Recipe
parts_directory_path = os.path.join(self.dir, 'test_parts') parts_directory_path = os.path.join(self.dir, 'test_parts')
try:
os.mkdir(parts_directory_path) os.mkdir(parts_directory_path)
except OSError, e:
if e.errno != errno.EEXIST:
raise
bo = { bo = {
'buildout' : { 'buildout' : {
'parts-directory' : parts_directory_path, 'parts-directory' : parts_directory_path,
'directory' : self.dir,
} }
} }
bo.update(buildout) bo.update(buildout)
...@@ -82,6 +88,20 @@ class NonInformativeTests(unittest.TestCase): ...@@ -82,6 +88,20 @@ class NonInformativeTests(unittest.TestCase):
os.chdir(self.dir) os.chdir(self.dir)
self.assertEquals(self.dir, os.getcwd()) self.assertEquals(self.dir, os.getcwd())
def test_compile_directory_exists(self):
"""
Do not fail if the compile-directory already exists
"""
compile_directory = os.path.join(self.dir, 'test_parts/test__compile__')
os.makedirs(compile_directory)
recipe = self.make_recipe({}, 'test', dict(url="some invalid url"))
os.chdir(self.dir)
# if compile directory exists, recipe should raise an IOError because
# of the bad URL, and _not_ some OSError because test__compile__
# already exists
self.assertRaises(IOError, recipe.install)
def test_suite(): def test_suite():
suite = unittest.TestSuite(( suite = unittest.TestSuite((
......
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