Merge branch 'tests' of github.com:kennethreitz/pipenv into tests

This commit is contained in:
Erin O'Connell
2017-09-22 23:02:30 -06:00
2 changed files with 284 additions and 11 deletions
+1 -1
View File
@@ -272,7 +272,7 @@ packages = [
def suggest_package(package):
"""Suggests a package name, given a package name."""
if ('-' in package) or ('[' in package):
if ('-' in package) or ('[' in package) or ('+' in package):
THRESHOLD = 90
else:
THRESHOLD = 86
+283 -10
View File
@@ -10,22 +10,44 @@ class PipenvInstance():
def __init__(self, pipfile=True):
self.original_dir = os.path.abspath(os.curdir)
self.path = tempfile.mkdtemp(suffix='project', prefix='pipenv')
self.pipfile_path = None
if pipfile:
p_path = os.sep.join([self.path, 'Pipfile'])
with open(p_path, 'a'):
os.utime(p_path, None)
self.pipfile_path = p_path
def __enter__(self):
os.chdir(self.path)
if not self.pipfile_path:
os.chdir(self.path)
return self
def __exit__(self, *args):
shutil.rmtree(self.path)
os.chdir(self.original_dir)
if not self.pipfile_path:
os.chdir(self.original_dir)
def pipenv(self, cmd):
return delegator.run('pipenv {0}'.format(cmd))
shutil.rmtree(self.path)
def pipenv(self, cmd, block=True):
if self.pipfile_path:
os.environ['PIPENV_PIPFILE'] = self.pipfile_path
c = delegator.run('pipenv {0}'.format(cmd), block=block)
if 'PIPENV_PIPFILE' in os.environ:
del os.environ['PIPENV_PIPFILE']
# Pretty output for failing tests.
if block:
print('$ pipenv {0}'.format(cmd))
print(c.out)
print(c.err)
# Where the action happens.
return c
@property
def pipfile(self):
@@ -39,6 +61,7 @@ class PipenvInstance():
with open(p_path, 'r') as f:
return json.loads(f.read())
class TestPipenv:
"""The ultimate testing class."""
@@ -51,6 +74,30 @@ class TestPipenv:
p.pipenv('--python python')
assert p.pipenv('--venv').out
def test_pipenv_py(self):
with PipenvInstance() as p:
p.pipenv('--python python')
assert p.pipenv('--py').out
def test_pipenv_rm(self):
with PipenvInstance() as p:
p.pipenv('--python python')
venv_path = p.pipenv('--venv').out
assert p.pipenv('--rm').out
assert not os.path.isdir(venv_path)
def test_pipenv_graph(self):
with PipenvInstance() as p:
p.pipenv('install requests')
assert 'requests' in p.pipenv('graph').out
assert 'requests' in p.pipenv('graph --json').out
# def test_pipenv_check(self):
# with PipenvInstance() as p:
# p.pipenv('install requests==1.0.0')
# assert 'requests' in p.pipenv('check').out
def test_venv_envs(self):
with PipenvInstance() as p:
assert p.pipenv('--envs').out
@@ -63,6 +110,32 @@ class TestPipenv:
with PipenvInstance() as p:
assert p.pipenv('').out
def test_help(self):
with PipenvInstance() as p:
assert p.pipenv('--help').out
def test_basic_setup(self):
with PipenvInstance(pipfile=False) as p:
c = p.pipenv('install requests')
assert c.return_code == 0
assert 'requests' in p.pipfile['packages']
assert 'requests' in p.lockfile['default']
assert 'chardet' in p.lockfile['default']
assert 'idna' in p.lockfile['default']
assert 'urllib3' in p.lockfile['default']
assert 'certifi' in p.lockfile['default']
# def test_spell_checking(self):
# with PipenvInstance() as p:
# c = p.pipenv('install django-rest-framework', block=False)
# c.expect('?')
# c.send('y')
# c.block()
# assert c.return_code == 0
# assert 'requests' in p.pipfile['djangorestframework']
def test_basic_install(self):
with PipenvInstance() as p:
c = p.pipenv('install requests')
@@ -74,13 +147,213 @@ class TestPipenv:
assert 'urllib3' in p.lockfile['default']
assert 'certifi' in p.lockfile['default']
def test_basic_dev_install(self):
with PipenvInstance() as p:
c = p.pipenv('install requests --dev')
assert c.return_code == 0
assert 'requests' in p.pipfile['dev-packages']
assert 'requests' in p.lockfile['develop']
assert 'chardet' in p.lockfile['develop']
assert 'idna' in p.lockfile['develop']
assert 'urllib3' in p.lockfile['develop']
assert 'certifi' in p.lockfile['develop']
c = p.pipenv('run python -m requests.help')
assert c.return_code == 0
def test_uninstall(self):
with PipenvInstance() as p:
c = p.pipenv('install requests')
assert c.return_code == 0
assert 'requests' in p.pipfile['packages']
assert 'requests' in p.lockfile['default']
assert 'chardet' in p.lockfile['default']
assert 'idna' in p.lockfile['default']
assert 'urllib3' in p.lockfile['default']
assert 'certifi' in p.lockfile['default']
c = p.pipenv('uninstall requests')
assert c.return_code == 0
assert 'requests' not in p.pipfile['dev-packages']
assert 'requests' not in p.lockfile['develop']
assert 'chardet' not in p.lockfile['develop']
assert 'idna' not in p.lockfile['develop']
assert 'urllib3' not in p.lockfile['develop']
assert 'certifi' not in p.lockfile['develop']
c = p.pipenv('run python -m requests.help')
assert c.return_code > 0
def test_extras_install(self):
with PipenvInstance() as p:
c = p.pipenv('install requests[socks]')
assert c.return_code == 0
assert 'requests' in p.pipfile['packages']
assert 'extras' in p.pipfile['packages']['requests']
assert 'requests' in p.lockfile['default']
assert 'chardet' in p.lockfile['default']
assert 'idna' in p.lockfile['default']
assert 'urllib3' in p.lockfile['default']
assert 'pysocks' in p.lockfile['default']
def test_basic_vcs_install(self):
with PipenvInstance() as p:
p.pipenv('install git+https://github.com/requests/requests.git')
assert p.return_code == 0
c = p.pipenv('install git+https://github.com/requests/requests.git#egg=requests')
assert c.return_code == 0
assert 'requests' in p.pipfile['packages']
assert 'chardet' in p.lockfile['packages']
assert 'git' in p.pipfile['packages']['requests']
assert p.lockfile['default']['requests'] == {"git": "https://github.com/requests/requests.git"}
def test_editable_vcs_install(self):
with PipenvInstance() as p:
c = p.pipenv('install -e git+https://github.com/requests/requests.git#egg=requests')
assert c.return_code == 0
assert 'requests' in p.pipfile['packages']
assert 'git' in p.pipfile['packages']['requests']
assert 'editable' in p.pipfile['packages']['requests']
assert 'editable' in p.lockfile['default']['requests']
assert 'chardet' in p.lockfile['default']
assert 'idna' in p.lockfile['default']
assert 'urllib3' in p.lockfile['default']
assert 'certifi' in p.lockfile['default']
def test_multiprocess_bug_and_install(self):
os.environ['PIPENV_MAX_SUBPROCESS'] = '2'
with PipenvInstance() as p:
with open(p.pipfile_path, 'w') as f:
contents = """
[packages]
requests = "*"
records = "*"
tpfd = "*"
""".strip()
f.write(contents)
c = p.pipenv('install')
assert c.return_code == 0
assert 'requests' in p.lockfile['default']
assert 'idna' in p.lockfile['default']
assert 'urllib3' in p.lockfile['default']
assert 'certifi' in p.lockfile['default']
assert 'records' in p.lockfile['default']
assert 'tpfd' in p.lockfile['default']
assert 'parse' in p.lockfile['default']
c = p.pipenv('run python -c "import requests; import idna; import certifi; import records; import tpfd; import parse;"')
assert c.return_code == 0
del os.environ['PIPENV_MAX_SUBPROCESS']
def test_sequential_mode(self):
with PipenvInstance() as p:
with open(p.pipfile_path, 'w') as f:
contents = """
[packages]
requests = "*"
records = "*"
tpfd = "*"
""".strip()
f.write(contents)
c = p.pipenv('install --sequential')
assert c.return_code == 0
assert 'requests' in p.lockfile['default']
assert 'idna' in p.lockfile['default']
assert 'urllib3' in p.lockfile['default']
assert 'certifi' in p.lockfile['default']
assert 'records' in p.lockfile['default']
assert 'tpfd' in p.lockfile['default']
assert 'parse' in p.lockfile['default']
c = p.pipenv('run python -c "import requests; import idna; import certifi; import records; import tpfd; import parse;"')
assert c.return_code == 0
def test_package_environment_markers(self):
with PipenvInstance() as p:
with open(p.pipfile_path, 'w') as f:
contents = """
[packages]
requests = {version = "*", markers="os_name=='splashwear'"}
""".strip()
f.write(contents)
c = p.pipenv('install')
assert c.return_code == 0
assert 'Ignoring' in c.out
assert 'markers' in p.lockfile['default']['requests']
c = p.pipenv('run python -c "import requests;"')
assert c.return_code == 1
def test_specific_package_environment_markers(self):
with PipenvInstance() as p:
with open(p.pipfile_path, 'w') as f:
contents = """
[packages]
requests = {version = "*", os_name = "== 'splashwear'"}
""".strip()
f.write(contents)
c = p.pipenv('install')
assert c.return_code == 0
assert 'Ignoring' in c.out
assert 'markers' in p.lockfile['default']['requests']
c = p.pipenv('run python -c "import requests;"')
assert c.return_code == 1
def test_alternative_version_specifier(self):
with PipenvInstance() as p:
with open(p.pipfile_path, 'w') as f:
contents = """
[packages]
requests = {version = "*"}
""".strip()
f.write(contents)
c = p.pipenv('install')
assert c.return_code == 0
assert 'requests' in p.lockfile['default']
assert 'idna' in p.lockfile['default']
assert 'urllib3' in p.lockfile['default']
assert 'certifi' in p.lockfile['default']
assert 'chardet' in p.lockfile['default']
c = p.pipenv('run python -c "import requests; import idna; import certifi;"')
assert c.return_code == 0
def test_bad_packages(self):
with PipenvInstance() as p:
c = p.pipenv('install python')
assert c.return_code > 0
def test_venv_in_project(self):
os.environ['PIPENV_VENV_IN_PROJECT'] = '1'
with PipenvInstance() as p:
c = p.pipenv('install requests')
assert c.return_code == 0
assert p.path in p.pipenv('--venv').out
del os.environ['PIPENV_VENV_IN_PROJECT']
def test_env(self):
with PipenvInstance(pipfile=False) as p:
with open('.env', 'w') as f:
f.write('HELLO=WORLD')
c = p.pipenv('run python -c "import os; print(os.environ[\'HELLO\'])"')
assert c.return_code == 0
assert 'WORLD' in c.out