diff options
author | John Newbery <john@johnnewbery.com> | 2018-08-24 11:14:45 -0400 |
---|---|---|
committer | John Newbery <john@johnnewbery.com> | 2018-08-24 11:55:05 -0400 |
commit | 995dd89d884bda3fb5ca1885c5887d989cd2cad3 (patch) | |
tree | f579b581b7737561f41e39c44fd60b362811c932 | |
parent | 540bf8aacc50aae0ea5beb76511905a7d2a3e15f (diff) |
[Tests] Make combine_logs.py handle multi-line logs
combine_logs.py currently inserts additional newlines into multi-line
log messages, and doesn't color them properly. Fix both of those.
-rwxr-xr-x | test/functional/combine_logs.py | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/test/functional/combine_logs.py b/test/functional/combine_logs.py index 91b6415a7c..f5eb4c4537 100755 --- a/test/functional/combine_logs.py +++ b/test/functional/combine_logs.py @@ -79,7 +79,8 @@ def get_log_events(source, logfile): timestamp = time_match.group() # if it doesn't have a timestamp, it's a continuation line of the previous log. else: - event += "\n" + line + # Add the line. Prefix with space equivalent to the source + timestamp so log lines are aligned + event += " " + line # Flush the final event yield LogEvent(timestamp=timestamp, source=source, event=event.rstrip()) except FileNotFoundError: @@ -98,7 +99,11 @@ def print_logs(log_events, color=False, html=False): colors["reset"] = "\033[0m" # Reset font color for event in log_events: - print("{0} {1: <5} {2} {3}".format(colors[event.source.rstrip()], event.source, event.event, colors["reset"])) + lines = event.event.splitlines() + print("{0} {1: <5} {2} {3}".format(colors[event.source.rstrip()], event.source, lines[0], colors["reset"])) + if len(lines) > 1: + for line in lines[1:]: + print("{0}{1}{2}".format(colors[event.source.rstrip()], line, colors["reset"])) else: try: |