2015-02-21 11:56:25 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# vim:fileencoding=utf-8:noet
|
|
|
|
from __future__ import (unicode_literals, division, absolute_import, print_function)
|
|
|
|
|
|
|
|
import argparse
|
|
|
|
import os
|
|
|
|
import re
|
|
|
|
|
|
|
|
from time import sleep
|
|
|
|
from subprocess import check_call
|
2015-02-21 12:03:34 +01:00
|
|
|
from io import BytesIO
|
2015-02-21 11:56:25 +01:00
|
|
|
|
|
|
|
import pexpect
|
|
|
|
|
|
|
|
|
|
|
|
def get_argparser(ArgumentParser=argparse.ArgumentParser):
|
|
|
|
parser = ArgumentParser(description='Run powerline shell test using pexpect')
|
|
|
|
parser.add_argument('--wait-for-echo', action='store_true', help='Wait until the input is echoed back.')
|
|
|
|
parser.add_argument('--type', metavar='TYPE', help='Test type (daemon, nodaemon, …).')
|
|
|
|
parser.add_argument('--client', metavar='CLIENT', help='Type of the client used (C, shell, zpython, …).')
|
|
|
|
parser.add_argument('--shell', metavar='SHELL', help='Shell name.')
|
2015-02-21 12:03:34 +01:00
|
|
|
parser.add_argument('command', nargs=argparse.REMAINDER, metavar='COMMAND',
|
2015-02-21 11:56:25 +01:00
|
|
|
help='Command to run and its argument.')
|
|
|
|
return parser
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
parser = get_argparser()
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
shell = args.shell or args.command[0]
|
2015-02-21 12:03:34 +01:00
|
|
|
test_type = args.type or shell
|
|
|
|
test_client = args.client or test_type
|
2015-02-21 11:56:25 +01:00
|
|
|
|
|
|
|
log_file_base = '{0}.{1}.{2}'.format(shell, test_type, test_client)
|
|
|
|
full_log_file_name = os.path.join('tests', 'shell', '{0}.full.log'.format(log_file_base))
|
|
|
|
# postproc_log_file_name = os.path.join('tests', 'shell', '{0}.log'.format(log_file_base))
|
|
|
|
|
|
|
|
local_paths = [
|
|
|
|
os.path.abspath(os.path.join('tests', 'shell', 'path')),
|
|
|
|
os.path.abspath('scripts'),
|
|
|
|
]
|
|
|
|
|
|
|
|
if test_type == 'fish':
|
|
|
|
local_paths += ['/usr/bin', '/bin']
|
|
|
|
|
|
|
|
python_paths = os.environ.get('PYTHONPATH', '')
|
|
|
|
if python_paths:
|
|
|
|
python_paths = ':' + python_paths
|
|
|
|
python_paths = os.path.abspath('.') + python_paths
|
|
|
|
|
|
|
|
environ = {
|
|
|
|
'LANG': 'en_US.UTF-8',
|
|
|
|
'PATH': os.pathsep.join(local_paths),
|
|
|
|
'TERM': 'screen-256color',
|
|
|
|
'DIR1': os.environ['DIR1'],
|
|
|
|
'DIR2': os.environ['DIR2'],
|
|
|
|
'XDG_CONFIG_HOME': os.path.abspath(os.path.join('tests', 'shell', 'fish_home')),
|
|
|
|
'IPYTHONDIR': os.path.abspath(os.path.join('tests', 'shell', 'ipython_home')),
|
|
|
|
'PYTHONPATH': python_paths,
|
|
|
|
'POWERLINE_CONFIG_OVERRIDES': os.environ.get('POWERLINE_CONFIG_OVERRIDES', ''),
|
|
|
|
'POWERLINE_THEME_OVERRIDES': os.environ.get('POWERLINE_THEME_OVERRIDES', ''),
|
|
|
|
'POWERLINE_CONFIG_PATHS': os.path.abspath(os.path.join('powerline', 'config_files')),
|
|
|
|
'POWERLINE_COMMAND_ARGS': os.environ.get('POWERLINE_COMMAND_ARGS', ''),
|
|
|
|
'POWERLINE_COMMAND': os.environ.get('POWERLINE_COMMAND', ''),
|
|
|
|
'LD_LIBRARY_PATH': os.environ.get('LD_LIBRARY_PATH', ''),
|
|
|
|
}
|
|
|
|
|
2015-02-21 12:03:34 +01:00
|
|
|
os.environ['PATH'] = environ['PATH']
|
|
|
|
|
2015-02-21 11:56:25 +01:00
|
|
|
if test_type == 'daemon':
|
|
|
|
environ['POWERLINE_SHELL_CONTINUATION'] = '1'
|
|
|
|
environ['POWERLINE_SHELL_SELECT'] = '1'
|
|
|
|
|
2015-02-21 12:03:34 +01:00
|
|
|
if test_type != 'zpython' and shell == 'zsh':
|
|
|
|
environ['POWERLINE_NO_ZSH_ZPYTHON'] = '1'
|
|
|
|
|
|
|
|
sio = BytesIO()
|
|
|
|
|
2015-02-21 11:56:25 +01:00
|
|
|
child = pexpect.spawn(
|
|
|
|
args.command[0],
|
|
|
|
args.command[1:],
|
|
|
|
env=environ,
|
2015-02-21 12:03:34 +01:00
|
|
|
logfile=sio,
|
2015-02-21 15:11:11 +01:00
|
|
|
timeout=60 * 3,
|
2015-02-21 11:56:25 +01:00
|
|
|
)
|
2015-02-21 12:03:34 +01:00
|
|
|
child.expect(re.compile(b'.*'))
|
2015-02-21 11:56:25 +01:00
|
|
|
sleep(0.5)
|
|
|
|
child.setwinsize(1, 300)
|
|
|
|
|
|
|
|
with open(os.path.join('tests', 'test_shells', 'input.{0}'.format(shell)), 'rb') as F:
|
|
|
|
if not args.wait_for_echo:
|
|
|
|
child.send(F.read())
|
|
|
|
else:
|
|
|
|
for line in F:
|
|
|
|
child.send(line)
|
|
|
|
sleep(1)
|
|
|
|
# TODO Implement something more smart
|
|
|
|
|
2015-02-21 14:11:04 +01:00
|
|
|
with open(full_log_file_name, 'wb') as LF:
|
2015-02-21 12:03:34 +01:00
|
|
|
LF.write(child.read())
|
|
|
|
|
2015-02-21 11:56:25 +01:00
|
|
|
check_call([
|
|
|
|
os.path.join('tests', 'shell', 'path', 'python'),
|
|
|
|
os.path.join('tests', 'test_shells', 'postproc.py'),
|
|
|
|
test_type, test_client, shell
|
|
|
|
])
|
|
|
|
pidfile = os.path.join('tests', 'shell', '3rd', 'pid')
|
|
|
|
if os.path.exists(pidfile):
|
|
|
|
os.unlink(pidfile)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|