test_ok2/testing/test_argcomplete.py

108 lines
3.4 KiB
Python
Raw Normal View History

# -*- coding: utf-8 -*-
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
2017-12-27 11:47:26 +08:00
import subprocess
import sys
import pytest
# test for _argcomplete but not specific for any application
def equal_with_bash(prefix, ffc, fc, out=None):
res = ffc(prefix)
res_bash = set(fc(prefix))
retval = set(res) == res_bash
if out:
out.write("equal_with_bash({}) {} {}\n".format(prefix, retval, res))
if not retval:
2018-05-23 22:48:46 +08:00
out.write(" python - bash: %s\n" % (set(res) - res_bash))
out.write(" bash - python: %s\n" % (res_bash - set(res)))
return retval
2018-05-23 22:48:46 +08:00
# copied from argcomplete.completers as import from there
# also pulls in argcomplete.__init__ which opens filedescriptor 9
# this gives an IOError at the end of testrun
def _wrapcall(*args, **kargs):
try:
return subprocess.check_output(*args, **kargs).decode().splitlines()
2017-12-27 11:47:26 +08:00
except subprocess.CalledProcessError:
return []
class FilesCompleter(object):
2018-05-23 22:48:46 +08:00
"File completer class, optionally takes a list of allowed extensions"
def __init__(self, allowednames=(), directories=True):
# Fix if someone passes in a string instead of a list
if type(allowednames) is str:
allowednames = [allowednames]
2018-05-23 22:48:46 +08:00
self.allowednames = [x.lstrip("*").lstrip(".") for x in allowednames]
self.directories = directories
def __call__(self, prefix, **kwargs):
completion = []
if self.allowednames:
if self.directories:
2018-05-23 22:48:46 +08:00
files = _wrapcall(
["bash", "-c", "compgen -A directory -- '{p}'".format(p=prefix)]
)
completion += [f + "/" for f in files]
for x in self.allowednames:
2018-05-23 22:48:46 +08:00
completion += _wrapcall(
[
"bash",
"-c",
"compgen -A file -X '!*.{0}' -- '{p}'".format(x, p=prefix),
]
)
else:
2018-05-23 22:48:46 +08:00
completion += _wrapcall(
["bash", "-c", "compgen -A file -- '{p}'".format(p=prefix)]
)
2018-05-23 22:48:46 +08:00
anticomp = _wrapcall(
["bash", "-c", "compgen -A directory -- '{p}'".format(p=prefix)]
)
completion = list(set(completion) - set(anticomp))
if self.directories:
2018-05-23 22:48:46 +08:00
completion += [f + "/" for f in anticomp]
return completion
class TestArgComplete(object):
@pytest.mark.skipif("sys.platform in ('win32', 'darwin')")
def test_compare_with_compgen(self, tmpdir):
from _pytest._argcomplete import FastFilesCompleter
2018-05-23 22:48:46 +08:00
ffc = FastFilesCompleter()
fc = FilesCompleter()
with tmpdir.as_cwd():
assert equal_with_bash("", ffc, fc, out=sys.stdout)
tmpdir.ensure("data")
for x in ["d", "data", "doesnotexist", ""]:
assert equal_with_bash(x, ffc, fc, out=sys.stdout)
@pytest.mark.skipif("sys.platform in ('win32', 'darwin')")
def test_remove_dir_prefix(self):
"""this is not compatible with compgen but it is with bash itself:
ls /usr/<TAB>
"""
from _pytest._argcomplete import FastFilesCompleter
2018-05-23 22:48:46 +08:00
ffc = FastFilesCompleter()
fc = FilesCompleter()
2018-05-23 22:48:46 +08:00
for x in "/usr/".split():
2017-12-27 11:47:26 +08:00
assert not equal_with_bash(x, ffc, fc, out=sys.stdout)