2015-01-11 01:09:14 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# vim:fileencoding=utf-8:noet
|
|
|
|
from __future__ import (unicode_literals, division, absolute_import, print_function)
|
|
|
|
|
|
|
|
import os
|
2015-02-19 09:35:29 +01:00
|
|
|
import sys
|
2017-04-30 01:13:41 +02:00
|
|
|
import json
|
2015-01-11 01:09:14 +01:00
|
|
|
|
|
|
|
from time import sleep
|
|
|
|
from subprocess import check_call
|
2015-02-19 09:35:29 +01:00
|
|
|
from glob import glob1
|
2017-04-30 02:43:46 +02:00
|
|
|
from traceback import print_exc
|
2015-01-11 01:09:14 +01:00
|
|
|
|
2017-04-30 01:34:20 +02:00
|
|
|
from powerline.lib.dict import updated
|
2015-01-16 20:44:34 +01:00
|
|
|
from powerline.bindings.tmux import get_tmux_version
|
|
|
|
from powerline import get_fallback_logger
|
2015-01-11 01:09:14 +01:00
|
|
|
|
2017-04-30 14:05:18 +02:00
|
|
|
from tests.modules.lib.terminal import (ExpectProcess, MutableDimensions,
|
|
|
|
do_terminal_tests, get_env)
|
2015-01-11 01:09:14 +01:00
|
|
|
|
|
|
|
|
2015-08-21 17:39:52 +02:00
|
|
|
VTERM_TEST_DIR = os.path.abspath('tests/vterm_tmux')
|
2015-02-19 09:35:29 +01:00
|
|
|
|
|
|
|
|
2017-04-30 05:40:05 +02:00
|
|
|
def tmux_logs_iter(test_dir):
|
|
|
|
for tail in glob1(test_dir, '*.log'):
|
|
|
|
yield os.path.join(test_dir, tail)
|
|
|
|
|
|
|
|
|
2017-04-30 04:34:19 +02:00
|
|
|
def print_tmux_logs():
|
2017-04-30 05:40:05 +02:00
|
|
|
for f in tmux_logs_iter(VTERM_TEST_DIR):
|
2017-04-30 04:34:19 +02:00
|
|
|
print('_' * 80)
|
2017-04-30 05:40:05 +02:00
|
|
|
print(os.path.basename(f) + ':')
|
2017-04-30 04:34:19 +02:00
|
|
|
print('=' * 80)
|
2017-04-30 05:40:05 +02:00
|
|
|
with open(f, 'r') as fp:
|
2017-04-30 04:34:19 +02:00
|
|
|
for line in fp:
|
|
|
|
sys.stdout.write(line)
|
2017-04-30 05:40:05 +02:00
|
|
|
os.unlink(f)
|
2017-04-30 04:34:19 +02:00
|
|
|
|
|
|
|
|
2017-04-30 01:13:41 +02:00
|
|
|
def get_expected_result(tmux_version,
|
|
|
|
expected_result_old,
|
|
|
|
expected_result_1_7=None,
|
2017-04-30 02:49:52 +02:00
|
|
|
expected_result_1_8=None,
|
2017-04-30 01:13:41 +02:00
|
|
|
expected_result_2_0=None):
|
2015-05-23 15:10:46 +02:00
|
|
|
if tmux_version >= (2, 0) and expected_result_2_0:
|
|
|
|
return expected_result_2_0
|
2017-04-30 02:49:52 +02:00
|
|
|
elif tmux_version >= (1, 8) and expected_result_1_8:
|
|
|
|
return expected_result_1_8
|
2015-05-23 15:10:46 +02:00
|
|
|
elif tmux_version >= (1, 7) and expected_result_1_7:
|
|
|
|
return expected_result_1_7
|
|
|
|
else:
|
|
|
|
return expected_result_old
|
|
|
|
|
|
|
|
|
2017-04-30 12:18:50 +02:00
|
|
|
def tmux_fin_cb(p, cmd, env):
|
|
|
|
try:
|
|
|
|
check_call([
|
|
|
|
cmd, '-S', env['POWERLINE_TMUX_SOCKET_PATH'], 'kill-server'
|
|
|
|
], env=env, cwd=VTERM_TEST_DIR)
|
|
|
|
except Exception:
|
|
|
|
print_exc()
|
|
|
|
for f in tmux_logs_iter(VTERM_TEST_DIR):
|
|
|
|
os.unlink(f)
|
|
|
|
|
|
|
|
|
2015-02-19 09:19:38 +01:00
|
|
|
def main(attempts=3):
|
2015-01-11 01:09:14 +01:00
|
|
|
vterm_path = os.path.join(VTERM_TEST_DIR, 'path')
|
|
|
|
|
2015-01-16 19:45:48 +01:00
|
|
|
tmux_exe = os.path.join(vterm_path, 'tmux')
|
|
|
|
|
2017-04-30 12:18:50 +02:00
|
|
|
socket_path = os.path.abspath('tmux-socket-{0}'.format(attempts))
|
|
|
|
if os.path.exists(socket_path):
|
|
|
|
os.unlink(socket_path)
|
|
|
|
|
|
|
|
env = get_env(vterm_path, VTERM_TEST_DIR, {
|
2017-04-30 01:13:41 +02:00
|
|
|
'POWERLINE_THEME_OVERRIDES': ';'.join((
|
|
|
|
key + '=' + json.dumps(val)
|
|
|
|
for key, val in (
|
|
|
|
('default.segments.right', [{
|
|
|
|
'type': 'string',
|
|
|
|
'name': 's1',
|
|
|
|
'highlight_groups': ['cwd'],
|
|
|
|
'priority':50,
|
|
|
|
}]),
|
|
|
|
('default.segments.left', [{
|
|
|
|
'type': 'string',
|
|
|
|
'name': 's2',
|
|
|
|
'highlight_groups': ['background'],
|
|
|
|
'priority':20,
|
|
|
|
}]),
|
|
|
|
('default.segment_data.s1.contents', 'S1 string here'),
|
|
|
|
('default.segment_data.s2.contents', 'S2 string here'),
|
|
|
|
)
|
|
|
|
)),
|
2017-04-30 12:18:50 +02:00
|
|
|
'POWERLINE_TMUX_SOCKET_PATH': socket_path,
|
|
|
|
})
|
2017-04-30 01:13:41 +02:00
|
|
|
|
2017-04-30 01:19:47 +02:00
|
|
|
conf_path = os.path.abspath('powerline/bindings/tmux/powerline.conf')
|
|
|
|
conf_line = 'source "' + (
|
|
|
|
conf_path.replace('\\', '\\\\').replace('"', '\\"')) + '"\n'
|
|
|
|
conf_file = os.path.realpath(os.path.join(VTERM_TEST_DIR, 'tmux.conf'))
|
|
|
|
with open(conf_file, 'w') as cf_fd:
|
|
|
|
cf_fd.write(conf_line)
|
|
|
|
|
2017-04-30 04:00:49 +02:00
|
|
|
tmux_version = get_tmux_version(get_fallback_logger())
|
|
|
|
|
2017-04-30 04:35:53 +02:00
|
|
|
dim = MutableDimensions(rows=50, cols=200)
|
|
|
|
|
2017-04-30 12:18:50 +02:00
|
|
|
def prepare_test_1(p):
|
2017-04-30 04:31:14 +02:00
|
|
|
sleep(5)
|
|
|
|
|
2017-04-30 12:18:50 +02:00
|
|
|
def prepare_test_2(p):
|
2017-04-30 04:31:14 +02:00
|
|
|
dim.cols = 40
|
|
|
|
p.resize(dim)
|
|
|
|
sleep(5)
|
|
|
|
|
2017-04-30 13:36:50 +02:00
|
|
|
base_attrs = {
|
|
|
|
((0, 0, 0), (243, 243, 243), 1, 0, 0): 'lead',
|
|
|
|
((243, 243, 243), (11, 11, 11), 0, 0, 0): 'leadsep',
|
|
|
|
((255, 255, 255), (11, 11, 11), 0, 0, 0): 'bg',
|
|
|
|
((199, 199, 199), (88, 88, 88), 0, 0, 0): 'cwd',
|
|
|
|
((88, 88, 88), (11, 11, 11), 0, 0, 0): 'cwdhsep',
|
|
|
|
((0, 0, 0), (0, 224, 0), 0, 0, 0): 'defstl',
|
|
|
|
}
|
|
|
|
tests = (
|
|
|
|
{
|
|
|
|
'expected_result': get_expected_result(
|
|
|
|
tmux_version,
|
|
|
|
expected_result_old=(
|
|
|
|
'{lead: 0 }{leadsep: }{bg: S2 string here }'
|
|
|
|
'{4: 0 }{cwdhsep:| }{6:bash }'
|
|
|
|
'{bg: }{4: 1- }{cwdhsep:| }{6:bash }'
|
|
|
|
'{bg: }{7: }{8:2* | }{9:bash }{10: }'
|
|
|
|
'{bg:' + (' ' * 124) + '}'
|
|
|
|
'{cwdhsep: }{cwd: S1 string here }', updated(base_attrs, {
|
|
|
|
((133, 133, 133), (11, 11, 11), 0, 0, 0): 4,
|
|
|
|
((188, 188, 188), (11, 11, 11), 0, 0, 0): 6,
|
|
|
|
((11, 11, 11), (0, 102, 153), 0, 0, 0): 7,
|
|
|
|
((102, 204, 255), (0, 102, 153), 0, 0, 0): 8,
|
|
|
|
((255, 255, 255), (0, 102, 153), 1, 0, 0): 9,
|
|
|
|
((0, 102, 153), (11, 11, 11), 0, 0, 0): 10,
|
|
|
|
})),
|
|
|
|
expected_result_1_8=(
|
|
|
|
'{lead: 0 }{leadsep: }{bg: S2 string here }'
|
|
|
|
'{4: 0 }{cwdhsep:| }{6:bash }'
|
|
|
|
'{bg: }{4: 1- }{cwdhsep:| }{7:bash }'
|
|
|
|
'{bg: }{8: }{9:2* | }{10:bash }{7: }'
|
|
|
|
'{bg:' + (' ' * 124) + '}'
|
|
|
|
'{cwdhsep: }{cwd: S1 string here }', updated(base_attrs, {
|
|
|
|
((133, 133, 133), (11, 11, 11), 0, 0, 0): 4,
|
|
|
|
((188, 188, 188), (11, 11, 11), 0, 0, 0): 6,
|
|
|
|
((0, 102, 153), (11, 11, 11), 0, 0, 0): 7,
|
|
|
|
((11, 11, 11), (0, 102, 153), 0, 0, 0): 8,
|
|
|
|
((102, 204, 255), (0, 102, 153), 0, 0, 0): 9,
|
|
|
|
((255, 255, 255), (0, 102, 153), 1, 0, 0): 10,
|
|
|
|
})),
|
|
|
|
expected_result_2_0=(
|
|
|
|
'{lead: 0 }{leadsep: }{bg: S2 string here }'
|
|
|
|
'{4: 0 }{cwdhsep:| }{6:bash }'
|
|
|
|
'{bg: }{4: 1- }{cwdhsep:| }{7:bash }'
|
|
|
|
'{bg: }{8: }{9:2* | }{10:bash }{7: }'
|
|
|
|
'{bg:' + (' ' * 125) + '}'
|
|
|
|
'{cwdhsep: }{cwd: S1 string here }', updated(base_attrs, {
|
|
|
|
((133, 133, 133), (11, 11, 11), 0, 0, 0): 4,
|
|
|
|
((188, 188, 188), (11, 11, 11), 0, 0, 0): 6,
|
|
|
|
((0, 102, 153), (11, 11, 11), 0, 0, 0): 7,
|
|
|
|
((11, 11, 11), (0, 102, 153), 0, 0, 0): 8,
|
|
|
|
((102, 204, 255), (0, 102, 153), 0, 0, 0): 9,
|
|
|
|
((255, 255, 255), (0, 102, 153), 1, 0, 0): 10,
|
|
|
|
})),
|
|
|
|
),
|
|
|
|
'prep_cb': prepare_test_1,
|
|
|
|
'row': dim.rows - 1,
|
|
|
|
}, {
|
|
|
|
'expected_result': get_expected_result(
|
|
|
|
tmux_version,
|
|
|
|
expected_result_old=('{bg:' + (' ' * 40) + '}', base_attrs),
|
|
|
|
expected_result_1_7=(
|
|
|
|
'{lead: 0 }'
|
|
|
|
'{leadsep: }{bg: <}{4:h }{bg: }{5: }'
|
|
|
|
'{6:2* | }{7:bash }{8: }{bg: }{cwdhsep: }'
|
|
|
|
'{cwd: S1 string here }', updated(base_attrs, {
|
|
|
|
((188, 188, 188), (11, 11, 11), 0, 0, 0): 4,
|
|
|
|
((11, 11, 11), (0, 102, 153), 0, 0, 0): 5,
|
|
|
|
((102, 204, 255), (0, 102, 153), 0, 0, 0): 6,
|
|
|
|
((255, 255, 255), (0, 102, 153), 1, 0, 0): 7,
|
|
|
|
((0, 102, 153), (11, 11, 11), 0, 0, 0): 8,
|
|
|
|
})),
|
|
|
|
expected_result_1_8=(
|
|
|
|
'{lead: 0 }'
|
|
|
|
'{leadsep: }{bg: <}{4:h }{bg: }{5: }'
|
|
|
|
'{6:2* | }{7:bash }{4: }{bg: }{cwdhsep: }'
|
|
|
|
'{cwd: S1 string here }', updated(base_attrs, {
|
|
|
|
((0, 102, 153), (11, 11, 11), 0, 0, 0): 4,
|
|
|
|
((11, 11, 11), (0, 102, 153), 0, 0, 0): 5,
|
|
|
|
((102, 204, 255), (0, 102, 153), 0, 0, 0): 6,
|
|
|
|
((255, 255, 255), (0, 102, 153), 1, 0, 0): 7,
|
|
|
|
})),
|
|
|
|
expected_result_2_0=(
|
|
|
|
'{lead: 0 }'
|
|
|
|
'{leadsep: }{bg:<}{4:ash }{bg: }{5: }'
|
|
|
|
'{6:2* | }{7:bash }{4: }{cwdhsep: }'
|
|
|
|
'{cwd: S1 string here }', updated(base_attrs, {
|
|
|
|
((0, 102, 153), (11, 11, 11), 0, 0, 0): 4,
|
|
|
|
((11, 11, 11), (0, 102, 153), 0, 0, 0): 5,
|
|
|
|
((102, 204, 255), (0, 102, 153), 0, 0, 0): 6,
|
|
|
|
((255, 255, 255), (0, 102, 153), 1, 0, 0): 7,
|
|
|
|
})),
|
|
|
|
),
|
|
|
|
'prep_cb': prepare_test_2,
|
|
|
|
'row': dim.rows - 1,
|
|
|
|
}
|
2017-04-30 04:31:14 +02:00
|
|
|
)
|
2017-04-30 04:35:53 +02:00
|
|
|
|
2017-04-30 04:07:25 +02:00
|
|
|
args = [
|
|
|
|
# Specify full path to tmux socket (testing tmux instance must not
|
|
|
|
# interfere with user one)
|
|
|
|
'-S', socket_path,
|
|
|
|
# Force 256-color mode
|
|
|
|
'-2',
|
|
|
|
# Request verbose logging just in case
|
|
|
|
'-v',
|
|
|
|
# Specify configuration file
|
|
|
|
'-f', conf_file,
|
|
|
|
# Run bash three times
|
|
|
|
'new-session', 'bash --norc --noprofile -i', ';',
|
|
|
|
'new-window', 'bash --norc --noprofile -i', ';',
|
|
|
|
'new-window', 'bash --norc --noprofile -i', ';',
|
|
|
|
]
|
2017-04-30 04:00:49 +02:00
|
|
|
|
2017-04-30 12:18:50 +02:00
|
|
|
return do_terminal_tests(
|
2017-04-30 13:36:50 +02:00
|
|
|
tests=tests,
|
2017-04-30 12:18:50 +02:00
|
|
|
cmd=tmux_exe,
|
|
|
|
dim=dim,
|
|
|
|
args=args,
|
|
|
|
env=env,
|
|
|
|
cwd=VTERM_TEST_DIR,
|
|
|
|
fin_cb=tmux_fin_cb,
|
|
|
|
last_attempt_cb=print_tmux_logs,
|
|
|
|
)
|
2015-01-11 01:09:14 +01:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
if main():
|
|
|
|
raise SystemExit(0)
|
|
|
|
else:
|
|
|
|
raise SystemExit(1)
|