forked from conda/conda
-
Notifications
You must be signed in to change notification settings - Fork 0
/
conftest.py
59 lines (43 loc) · 1.51 KB
/
conftest.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import os
import sys
import warnings
import pytest
from conda.common.compat import PY3
win_default_shells = ["cmd.exe", "powershell", "git_bash", "cygwin"]
shells = ["bash", "zsh"]
if sys.platform == "win32":
shells = win_default_shells
def pytest_addoption(parser):
parser.addoption("--shell", action="append", default=[],
help="list of shells to run shell tests on")
def pytest_generate_tests(metafunc):
if 'shell' in metafunc.fixturenames:
metafunc.parametrize("shell", metafunc.config.option.shell)
@pytest.fixture()
def suppress_resource_warning():
'''
Suppress `Unclosed Socket Warning`
It seems urllib3 keeps a socket open to avoid costly recreation costs.
xref: https://github.com/kennethreitz/requests/issues/1882
'''
if PY3:
warnings.filterwarnings("ignore", category=ResourceWarning)
tmpdir_in_use = None
def get_tmpdir():
return tmpdir_in_use
@pytest.fixture(autouse=True)
def set_tmpdir(tmpdir):
global tmpdir_in_use
if not tmpdir:
return tmpdir_in_use
td = tmpdir.strpath
# print("Setting testing tmpdir (via CONDA_TEST_TMPDIR) to {}".format(td))
# I do not think setting env. vars so much is sensible, even in tests.
# .. to make sure this never gets misconstrued for just the dirname. It
# is the full path to a tmpdir with additions to it by py.test including
# the test name.
assert os.sep in td
os.environ['CONDA_TEST_TMPDIR'] = td
tmpdir_in_use = td
#@pytest.fixture(autouse=True)
#def tmpdir_name():