假设您在名为 的文件中有一个 bash 完成脚本asdf-completion
,其中包含:
_asdf() {
COMPREPLY=()
local cur prev
cur=$(_get_cword)
COMPREPLY=( $( compgen -W "one two three four five six" -- "$cur") )
return 0
}
complete -F _asdf asdf
这使用 shell 函数_asdf
来为虚构的asdf
命令提供补全。如果我们设置正确的环境变量(来自 bash 手册页),那么我们可以获得相同的结果,即将潜在扩展放置到COMPREPLY
变量中。这是在单元测试中执行此操作的示例:
import subprocess
import unittest
class BashTestCase(unittest.TestCase):
def test_complete(self):
completion_file="asdf-completion"
partial_word="f"
cmd=["asdf", "other", "arguments", partial_word]
cmdline = ' '.join(cmd)
out = subprocess.Popen(['bash', '-i', '-c',
r'source {compfile}; COMP_LINE="{cmdline}" COMP_WORDS=({cmdline}) COMP_CWORD={cword} COMP_POINT={cmdlen} $(complete -p {cmd} | sed "s/.*-F \\([^ ]*\\) .*/\\1/") && echo ${{COMPREPLY[*]}}'.format(
compfile=completion_file, cmdline=cmdline, cmdlen=len(cmdline), cmd=cmd[0], cword=cmd.index(partial_word)
)],
stdout=subprocess.PIPE)
stdout, stderr = out.communicate()
self.assertEqual(stdout, "four five\n")
if (__name__=='__main__'):
unittest.main()
这应该适用于任何使用 的完成-F
,但也可能适用于其他人。
je4d 使用的评论expect
对于更完整的测试来说是一个很好的评论。