2014-01-13 19:37:33 +01:00
|
|
|
#!/usr/bin/env python
|
2014-08-31 20:55:26 +02:00
|
|
|
# vim:fileencoding=utf-8:noet
|
|
|
|
from __future__ import (unicode_literals, division, absolute_import, print_function)
|
2014-01-13 19:37:33 +01:00
|
|
|
|
|
|
|
import os
|
|
|
|
import socket
|
|
|
|
import sys
|
|
|
|
import codecs
|
2014-11-29 22:30:35 +01:00
|
|
|
import platform
|
|
|
|
import re
|
2014-01-13 19:37:33 +01:00
|
|
|
|
|
|
|
|
2017-04-30 23:00:45 +02:00
|
|
|
test_root = os.environ['TEST_ROOT']
|
2014-08-02 19:02:26 +02:00
|
|
|
test_type = sys.argv[1]
|
2014-08-23 01:28:51 +02:00
|
|
|
test_client = sys.argv[2]
|
|
|
|
shell = sys.argv[3]
|
2017-04-30 23:00:45 +02:00
|
|
|
fname = os.path.join(test_root, '.'.join((shell, test_type, test_client, 'full.log')))
|
|
|
|
new_fname = os.path.join(test_root, '.'.join((shell, test_type, test_client, 'log')))
|
|
|
|
pid_fname = os.path.join(test_root, '3rd', 'pid')
|
2014-01-13 19:37:33 +01:00
|
|
|
|
2014-11-29 22:30:35 +01:00
|
|
|
is_pypy = platform.python_implementation() == 'PyPy'
|
|
|
|
|
2014-01-23 04:36:54 +01:00
|
|
|
|
2014-08-06 15:18:42 +02:00
|
|
|
try:
|
|
|
|
with open(pid_fname, 'r') as P:
|
|
|
|
pid = P.read().strip()
|
|
|
|
except IOError:
|
|
|
|
pid = None
|
2014-01-13 19:37:33 +01:00
|
|
|
hostname = socket.gethostname()
|
|
|
|
user = os.environ['USER']
|
|
|
|
|
2014-12-05 21:09:21 +01:00
|
|
|
REFS_RE = re.compile(r'^\[\d+ refs\]\n')
|
2014-11-29 22:30:35 +01:00
|
|
|
IPYPY_DEANSI_RE = re.compile(r'\033(?:\[(?:\?\d+[lh]|[^a-zA-Z]+[a-ln-zA-Z])|[=>])')
|
2015-08-22 16:44:57 +02:00
|
|
|
ZSH_HL_RE = re.compile(r'\033\[\?\d+[hl]')
|
2014-11-29 22:30:35 +01:00
|
|
|
|
2017-04-30 23:00:45 +02:00
|
|
|
start_str = 'cd "$TEST_ROOT"/3rd'
|
2015-02-21 15:56:13 +01:00
|
|
|
if shell == 'pdb':
|
|
|
|
start_str = 'class Foo(object):'
|
|
|
|
|
2014-01-13 19:37:33 +01:00
|
|
|
with codecs.open(fname, 'r', encoding='utf-8') as R:
|
|
|
|
with codecs.open(new_fname, 'w', encoding='utf-8') as W:
|
|
|
|
found_cd = False
|
2015-01-31 15:58:14 +01:00
|
|
|
i = -1
|
2014-01-23 04:45:35 +01:00
|
|
|
for line in (R if shell != 'fish' else R.read().split('\n')):
|
2015-01-31 15:58:14 +01:00
|
|
|
i += 1
|
2014-01-13 19:37:33 +01:00
|
|
|
if not found_cd:
|
2015-02-21 15:56:13 +01:00
|
|
|
found_cd = (start_str in line)
|
2014-01-13 19:37:33 +01:00
|
|
|
continue
|
2014-01-17 22:59:19 +01:00
|
|
|
if 'true is the last line' in line:
|
|
|
|
break
|
2014-01-17 18:34:18 +01:00
|
|
|
line = line.translate({
|
|
|
|
ord('\r'): None
|
|
|
|
})
|
2014-12-05 21:09:21 +01:00
|
|
|
if REFS_RE.match(line):
|
|
|
|
continue
|
2014-01-13 19:37:33 +01:00
|
|
|
line = line.replace(hostname, 'HOSTNAME')
|
|
|
|
line = line.replace(user, 'USER')
|
2014-08-06 15:18:42 +02:00
|
|
|
if pid is not None:
|
|
|
|
line = line.replace(pid, 'PID')
|
2015-08-22 16:44:57 +02:00
|
|
|
if shell == 'zsh':
|
|
|
|
line = line.replace('\033[0m\033[23m\033[24m\033[J', '')
|
|
|
|
line = ZSH_HL_RE.subn('', line)[0]
|
|
|
|
elif shell == 'fish':
|
2014-08-24 15:09:40 +02:00
|
|
|
res = ''
|
2014-01-23 04:36:54 +01:00
|
|
|
try:
|
2014-08-24 15:09:40 +02:00
|
|
|
while line.index('\033[0;'):
|
|
|
|
start = line.index('\033[0;')
|
|
|
|
end = line.index('\033[0m', start)
|
|
|
|
res += line[start:end + 4] + '\n'
|
|
|
|
line = line[end + 4:]
|
2014-01-23 04:36:54 +01:00
|
|
|
except ValueError:
|
2014-08-24 15:09:40 +02:00
|
|
|
pass
|
|
|
|
line = res
|
2014-01-26 21:22:38 +01:00
|
|
|
elif shell == 'tcsh':
|
|
|
|
try:
|
|
|
|
start = line.index('\033[0;')
|
|
|
|
end = line.index(' ', start)
|
2015-03-01 15:23:07 +01:00
|
|
|
line = line[start:end] + '\n'
|
2014-01-26 21:22:38 +01:00
|
|
|
except ValueError:
|
|
|
|
line = ''
|
2014-07-20 00:00:56 +02:00
|
|
|
elif shell == 'mksh':
|
|
|
|
# Output is different in travis: on my machine I see full
|
|
|
|
# command, in travis it is truncated just after `true`.
|
|
|
|
if line.startswith('[1] + Terminated'):
|
|
|
|
line = '[1] + Terminated bash -c ...\n'
|
2014-08-12 05:54:34 +02:00
|
|
|
elif shell == 'dash':
|
|
|
|
# Position of this line is not stable: it may go both before and
|
|
|
|
# after the next line
|
|
|
|
if line.startswith('[1] + Terminated'):
|
|
|
|
continue
|
2014-11-29 22:30:35 +01:00
|
|
|
elif shell == 'ipython' and is_pypy:
|
|
|
|
try:
|
|
|
|
end_idx = line.rindex('\033[0m')
|
|
|
|
try:
|
|
|
|
idx = line[:end_idx].rindex('\033[1;1H')
|
|
|
|
except ValueError:
|
|
|
|
idx = line[:end_idx].rindex('\033[?25h')
|
|
|
|
line = line[idx + len('\033[1;1H'):]
|
|
|
|
except ValueError:
|
|
|
|
pass
|
|
|
|
try:
|
|
|
|
data_end_idx = line.rindex('\033[1;1H')
|
|
|
|
line = line[:data_end_idx] + '\n'
|
|
|
|
except ValueError:
|
|
|
|
pass
|
|
|
|
if line == '\033[1;1H\n':
|
|
|
|
continue
|
|
|
|
was_empty = line == '\n'
|
|
|
|
line = IPYPY_DEANSI_RE.subn('', line)[0]
|
|
|
|
if line == '\n' and not was_empty:
|
|
|
|
line = ''
|
2015-01-09 15:40:05 +01:00
|
|
|
elif shell == 'rc':
|
|
|
|
if line == 'read() failed: Connection reset by peer\n':
|
|
|
|
line = ''
|
2015-01-31 15:58:14 +01:00
|
|
|
elif shell == 'pdb':
|
|
|
|
if is_pypy:
|
|
|
|
if line == '\033[?1h\033=\033[?25l\033[1A\n':
|
|
|
|
line = ''
|
|
|
|
line = IPYPY_DEANSI_RE.subn('', line)[0]
|
2015-02-01 10:08:09 +01:00
|
|
|
if line == '\n':
|
|
|
|
line = ''
|
2015-01-31 15:58:14 +01:00
|
|
|
if line.startswith(('>',)):
|
|
|
|
line = ''
|
|
|
|
elif line == '-> self.quitting = 1\n':
|
|
|
|
line = '-> self.quitting = True\n'
|
2015-02-21 16:44:01 +01:00
|
|
|
elif line == '\n':
|
|
|
|
line = ''
|
2015-02-21 17:02:37 +01:00
|
|
|
if line == '-> self.quitting = True\n':
|
|
|
|
break
|
2014-01-13 19:37:33 +01:00
|
|
|
W.write(line)
|