2013-05-01 00:30:15 +02:00
|
|
|
import sys
|
2013-03-27 06:26:52 +01:00
|
|
|
import os
|
|
|
|
import tempfile
|
|
|
|
import shutil
|
|
|
|
|
|
|
|
from pip.exceptions import PreviousBuildDirError
|
|
|
|
from pip.index import PackageFinder
|
2013-05-01 00:30:15 +02:00
|
|
|
from pip.log import logger
|
2013-03-27 06:26:52 +01:00
|
|
|
from pip.req import InstallRequirement, RequirementSet
|
|
|
|
from tests.test_pip import here, path_to_url, assert_raises_regexp
|
|
|
|
|
|
|
|
find_links = path_to_url(os.path.join(here, 'packages'))
|
|
|
|
|
|
|
|
class TestRequirementSet(object):
|
|
|
|
"""RequirementSet tests"""
|
|
|
|
|
|
|
|
def setup(self):
|
2013-05-01 00:30:15 +02:00
|
|
|
logger.consumers = [(logger.NOTIFY, sys.stdout)]
|
2013-03-27 06:26:52 +01:00
|
|
|
self.tempdir = tempfile.mkdtemp()
|
|
|
|
|
|
|
|
def teardown(self):
|
2013-05-01 00:30:15 +02:00
|
|
|
logger.consumers = []
|
2013-03-27 06:26:52 +01:00
|
|
|
shutil.rmtree(self.tempdir, ignore_errors=True)
|
|
|
|
|
|
|
|
def basic_reqset(self):
|
|
|
|
return RequirementSet(
|
|
|
|
build_dir=os.path.join(self.tempdir, 'build'),
|
|
|
|
src_dir=os.path.join(self.tempdir, 'src'),
|
|
|
|
download_dir=None,
|
|
|
|
download_cache=os.path.join(self.tempdir, 'download_cache'),
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_no_reuse_existing_build_dir(self):
|
|
|
|
"""Test prepare_files raise exception with previous build dir"""
|
|
|
|
|
|
|
|
build_dir = os.path.join(self.tempdir, 'build', 'simple')
|
|
|
|
os.makedirs(build_dir)
|
|
|
|
open(os.path.join(build_dir, "setup.py"), 'w')
|
|
|
|
reqset = self.basic_reqset()
|
|
|
|
req = InstallRequirement.from_line('simple')
|
|
|
|
reqset.add_requirement(req)
|
|
|
|
finder = PackageFinder([find_links], [])
|
|
|
|
assert_raises_regexp(
|
|
|
|
PreviousBuildDirError,
|
2013-05-01 00:30:15 +02:00
|
|
|
"pip can't proceed with [\s\S]*%s[\s\S]*%s" % (req, build_dir),
|
2013-03-27 06:26:52 +01:00
|
|
|
reqset.prepare_files,
|
|
|
|
finder
|
|
|
|
)
|
|
|
|
|