mirror of
https://github.com/fedora-python/tox-current-env.git
synced 2025-01-25 22:36:14 +01:00
Tests: Manipulate INI config with ConfigParser
This commit is contained in:
parent
10da929f4b
commit
f663c1b4d5
1
tests/fixtures/tox.ini
vendored
1
tests/fixtures/tox.ini
vendored
@ -10,4 +10,3 @@ extras =
|
|||||||
full
|
full
|
||||||
commands =
|
commands =
|
||||||
python -c 'import os, sys; print(os.path.realpath(sys.exec_prefix), "is the exec_prefix")'
|
python -c 'import os, sys; print(os.path.realpath(sys.exec_prefix), "is the exec_prefix")'
|
||||||
# note: some tests assume [testenv] is the last section
|
|
||||||
|
@ -7,6 +7,8 @@ import subprocess
|
|||||||
import sys
|
import sys
|
||||||
import textwrap
|
import textwrap
|
||||||
import warnings
|
import warnings
|
||||||
|
import configparser
|
||||||
|
import contextlib
|
||||||
|
|
||||||
from packaging import version
|
from packaging import version
|
||||||
|
|
||||||
@ -51,6 +53,24 @@ def print_extras_stdout_arg(request):
|
|||||||
return request.param
|
return request.param
|
||||||
|
|
||||||
|
|
||||||
|
@contextlib.contextmanager
|
||||||
|
def modify_config(tox_ini_path):
|
||||||
|
"""Context manager that allows modifying the given Tox config file
|
||||||
|
|
||||||
|
A statement like::
|
||||||
|
|
||||||
|
with prepare_config(projdir) as config:
|
||||||
|
|
||||||
|
will make `config` a ConfigParser instance that is saved at the end
|
||||||
|
of the `with` block.
|
||||||
|
"""
|
||||||
|
config = configparser.ConfigParser()
|
||||||
|
config.read(tox_ini_path)
|
||||||
|
yield config
|
||||||
|
with open(tox_ini_path, 'w') as tox_ini_file:
|
||||||
|
config.write(tox_ini_file)
|
||||||
|
|
||||||
|
|
||||||
def tox(*args, quiet=True, **kwargs):
|
def tox(*args, quiet=True, **kwargs):
|
||||||
kwargs.setdefault("encoding", "utf-8")
|
kwargs.setdefault("encoding", "utf-8")
|
||||||
kwargs.setdefault("stdout", subprocess.PIPE)
|
kwargs.setdefault("stdout", subprocess.PIPE)
|
||||||
@ -552,9 +572,8 @@ def test_noquiet_installed_packages(flag):
|
|||||||
@pytest.mark.parametrize("flag", ["--print-deps-to=-", "--print-extras-to=-", "--current-env"])
|
@pytest.mark.parametrize("flag", ["--print-deps-to=-", "--print-extras-to=-", "--current-env"])
|
||||||
@pytest.mark.parametrize("usedevelop", [True, False])
|
@pytest.mark.parametrize("usedevelop", [True, False])
|
||||||
def test_self_is_not_installed(projdir, flag, usedevelop):
|
def test_self_is_not_installed(projdir, flag, usedevelop):
|
||||||
tox_ini = projdir / "tox.ini"
|
with modify_config(projdir / 'tox.ini') as config:
|
||||||
with open(tox_ini, 'a') as tox_ini_file:
|
config['testenv']['usedevelop'] = str(usedevelop)
|
||||||
print(f"usedevelop={usedevelop}", file=tox_ini_file)
|
|
||||||
result = tox("-e", NATIVE_TOXENV, flag, quiet=False)
|
result = tox("-e", NATIVE_TOXENV, flag, quiet=False)
|
||||||
assert 'test==0.0.0' not in result.stdout
|
assert 'test==0.0.0' not in result.stdout
|
||||||
assert 'test @ file://' not in result.stdout
|
assert 'test @ file://' not in result.stdout
|
||||||
@ -562,9 +581,8 @@ def test_self_is_not_installed(projdir, flag, usedevelop):
|
|||||||
|
|
||||||
@pytest.mark.parametrize("usedevelop", [True, False])
|
@pytest.mark.parametrize("usedevelop", [True, False])
|
||||||
def test_self_is_installed_with_regular_tox(projdir, usedevelop):
|
def test_self_is_installed_with_regular_tox(projdir, usedevelop):
|
||||||
tox_ini = projdir / "tox.ini"
|
with modify_config(projdir / 'tox.ini') as config:
|
||||||
with open(tox_ini, 'a') as tox_ini_file:
|
config['testenv']['usedevelop'] = str(usedevelop)
|
||||||
print(f"usedevelop={usedevelop}", file=tox_ini_file)
|
|
||||||
result = tox("-e", NATIVE_TOXENV, quiet=False)
|
result = tox("-e", NATIVE_TOXENV, quiet=False)
|
||||||
assert ('test==0.0.0' in result.stdout or
|
assert ('test==0.0.0' in result.stdout or
|
||||||
'test @ file://' in result.stdout)
|
'test @ file://' in result.stdout)
|
||||||
|
Loading…
Reference in New Issue
Block a user