Merged in anthon_van_der_neut/pytest/argcomplete (pull request #51)
fix for tests running subprocesses of py.test after test_argcomplete
This commit is contained in:
commit
44d5524be2
|
@ -174,9 +174,9 @@ def test_addoption_parser_epilog(testdir):
|
||||||
result.stdout.fnmatch_lines(["hint: hello world", "hint: from me too"])
|
result.stdout.fnmatch_lines(["hint: hello world", "hint: from me too"])
|
||||||
|
|
||||||
@pytest.mark.skipif("sys.version_info < (2,5)")
|
@pytest.mark.skipif("sys.version_info < (2,5)")
|
||||||
def test_argcomplete(testdir):
|
def test_argcomplete(testdir, monkeypatch):
|
||||||
if not py.path.local.sysfind('bash'):
|
if not py.path.local.sysfind('bash'):
|
||||||
pytest.skip("bash not available")
|
pytest.skip("bash not available")
|
||||||
import os
|
import os
|
||||||
script = os.path.join(os.getcwd(), 'test_argcomplete')
|
script = os.path.join(os.getcwd(), 'test_argcomplete')
|
||||||
with open(str(script), 'w') as fp:
|
with open(str(script), 'w') as fp:
|
||||||
|
@ -185,13 +185,16 @@ def test_argcomplete(testdir):
|
||||||
# so we use bash
|
# so we use bash
|
||||||
fp.write('COMP_WORDBREAKS="$COMP_WORDBREAKS" $(which py.test) '
|
fp.write('COMP_WORDBREAKS="$COMP_WORDBREAKS" $(which py.test) '
|
||||||
'8>&1 9>&2')
|
'8>&1 9>&2')
|
||||||
os.environ['_ARGCOMPLETE'] = "1"
|
# alternative would be exteneded Testdir.{run(),_run(),popen()} to be able
|
||||||
os.environ['_ARGCOMPLETE_IFS'] = "\x0b"
|
# to handle a keyword argument env that replaces os.environ in popen or
|
||||||
os.environ['COMP_WORDBREAKS'] = ' \\t\\n"\\\'><=;|&(:'
|
# extends the copy, advantage: could not forget to restore
|
||||||
|
monkeypatch.setenv('_ARGCOMPLETE', "1")
|
||||||
|
monkeypatch.setenv('_ARGCOMPLETE_IFS',"\x0b")
|
||||||
|
monkeypatch.setenv('COMP_WORDBREAKS', ' \\t\\n"\\\'><=;|&(:')
|
||||||
|
|
||||||
arg = '--fu'
|
arg = '--fu'
|
||||||
os.environ['COMP_LINE'] = "py.test " + arg
|
monkeypatch.setenv('COMP_LINE', "py.test " + arg)
|
||||||
os.environ['COMP_POINT'] = str(len(os.environ['COMP_LINE']))
|
monkeypatch.setenv('COMP_POINT', str(len("py.test " + arg)))
|
||||||
result = testdir.run('bash', str(script), arg)
|
result = testdir.run('bash', str(script), arg)
|
||||||
print dir(result), result.ret
|
print dir(result), result.ret
|
||||||
if result.ret == 255:
|
if result.ret == 255:
|
||||||
|
@ -202,7 +205,8 @@ def test_argcomplete(testdir):
|
||||||
|
|
||||||
os.mkdir('test_argcomplete.d')
|
os.mkdir('test_argcomplete.d')
|
||||||
arg = 'test_argc'
|
arg = 'test_argc'
|
||||||
os.environ['COMP_LINE'] = "py.test " + arg
|
monkeypatch.setenv('COMP_LINE', "py.test " + arg)
|
||||||
os.environ['COMP_POINT'] = str(len(os.environ['COMP_LINE']))
|
monkeypatch.setenv('COMP_POINT', str(len('py.test ' + arg)))
|
||||||
result = testdir.run('bash', str(script), arg)
|
result = testdir.run('bash', str(script), arg)
|
||||||
result.stdout.fnmatch_lines(["test_argcomplete", "test_argcomplete.d/"])
|
result.stdout.fnmatch_lines(["test_argcomplete", "test_argcomplete.d/"])
|
||||||
|
# restore environment
|
||||||
|
|
Loading…
Reference in New Issue