mavsdk_tests: import naming, easier coloring

This commit is contained in:
Julian Oes
2020-03-12 08:43:20 +01:00
committed by Nuno Marques
parent 11a28840f3
commit ff64d87ae6
3 changed files with 69 additions and 66 deletions
+39 -37
View File
@@ -3,50 +3,52 @@
import re
import sys
import os
from enum import Enum
from functools import lru_cache
def supports_color():
"""Returns True if the running system's terminal supports color.
From https://stackoverflow.com/a/22254892/8548472
"""
plat = sys.platform
supported_platform = plat != 'Pocket PC' and (plat != 'win32' or
'ANSICON' in os.environ)
# isatty is not always implemented, #6223.
is_a_tty = hasattr(sys.stdout, 'isatty') and sys.stdout.isatty()
return supported_platform and is_a_tty
class color(Enum):
PURPLE = '\033[95m'
CYAN = '\033[96m'
DARKCYAN = '\033[36m'
BLUE = '\033[94m'
GREEN = '\033[92m'
YELLOW = '\033[93m'
RED = '\033[91m'
BOLD = '\033[1m'
UNDERLINE = '\033[4m'
RESET = '\033[0m'
if supports_color():
class color:
PURPLE = '\033[95m'
CYAN = '\033[96m'
DARKCYAN = '\033[36m'
BLUE = '\033[94m'
GREEN = '\033[92m'
YELLOW = '\033[93m'
RED = '\033[91m'
BOLD = '\033[1m'
UNDERLINE = '\033[4m'
END = '\033[0m'
else:
class color:
PURPLE = ''
CYAN = ''
DARKCYAN = ''
BLUE = ''
GREEN = ''
YELLOW = ''
RED = ''
BOLD = ''
UNDERLINE = ''
END = ''
def colorize(text: str, c: color) -> str:
if _supports_color():
return c.value + text + color.RESET.value
else:
return text
def remove_color(text):
def maybe_strip_color(text: str) -> str:
"""Remove ANSI and xterm256 color codes.
From https://stackoverflow.com/a/30500866/8548472
"""
return re.sub(r'\x1b(\[.*?[@-~]|\].*?(\x07|\x1b\\))', '', text)
if not _supports_color():
return re.sub(r'\x1b(\[.*?[@-~]|\].*?(\x07|\x1b\\))', '', text)
else:
return text
@lru_cache
def _supports_color() -> bool:
"""Returns True if the running system's terminal supports color.
From https://stackoverflow.com/a/22254892/8548472
"""
supported_platform = \
(sys.platform != 'Pocket PC') and \
(sys.platform != 'win32' or 'ANSICON' in os.environ)
# isatty is not always implemented.
is_a_tty = hasattr(sys.stdout, 'isatty') and sys.stdout.isatty()
return supported_platform and is_a_tty
+26 -20
View File
@@ -7,12 +7,8 @@ import psutil
import signal
import subprocess
import sys
from logger_helper import color
from process_helper import \
Px4Runner, \
GzserverRunner, \
GzclientRunner, \
TestRunner
from logger_helper import color, colorize
import process_helper as ph
def main():
@@ -160,10 +156,12 @@ class Tester:
break
if overall_success:
print(color.GREEN + "Overall result: success!" + color.END)
print(colorize(colorize(
"Overall result: success!", color.GREEN), color.BOLD))
return 0
else:
print(color.RED + "Overall result: failure!" + color.END)
print(colorize(colorize(
"Overall result: failure!", color.RED), color.BOLD))
return 1
def run_test_group(self):
@@ -184,8 +182,10 @@ class Tester:
models = []
for group in models:
print(color.BOLD + "==> Running tests for '{}' with filter '{}'"
.format(group['model'], group['test_filter']) + color.END)
print(colorize(
"==> Running tests for '{}' with filter '{}'"
.format(group['model'], group['test_filter']),
color.BOLD))
tests = determine_tests(group['test_filter'])
@@ -194,11 +194,15 @@ class Tester:
format(i+1, len(tests), test))
was_success = self.run_test(test, group)
if was_success:
print(color.GREEN + "--- Test {} of {}: '{}' succeeded.".
format(i+1, len(tests), test) + color.END)
print(colorize(
"--- Test {} of {}: '{}' succeeded."
.format(i+1, len(tests), test),
color.GREEN))
else:
print(color.RED + "--- Test {} of {}: '{}' failed.".
format(i+1, len(tests), test) + color.END)
print(colorize(
"--- Test {} of {}: '{}' failed."
.format(i+1, len(tests), test),
color.RED))
if not was_success:
overall_success = False
@@ -217,14 +221,14 @@ class Tester:
speed_factor = min(int(speed_factor), group["max_speed_factor"])
if self.config['mode'] == 'sitl':
px4_runner = Px4Runner(
px4_runner = ph.Px4Runner(
group['model'], os.getcwd(), self.log_dir, speed_factor,
self.debugger, self.verbose)
px4_runner.start(group)
self.active_runners.append(px4_runner)
if self.config['simulator'] == 'gazebo':
gzserver_runner = GzserverRunner(
gzserver_runner = ph.GzserverRunner(
group['model'],
os.getcwd(),
self.log_dir,
@@ -234,12 +238,12 @@ class Tester:
self.active_runners.append(gzserver_runner)
if self.gui:
gzclient_runner = GzclientRunner(
gzclient_runner = ph.GzclientRunner(
os.getcwd(), self.log_dir, self.verbose)
gzclient_runner.start(group)
self.active_runners.append(gzclient_runner)
test_runner = TestRunner(
test_runner = ph.TestRunner(
os.getcwd(),
self.log_dir,
group,
@@ -261,8 +265,10 @@ class Tester:
runner.print_output()
else:
print(color.BOLD + "Test timeout of {} mins triggered!".
format(group['timeout_min']) + color.END)
print(colorize(
"Test timeout of {} mins triggered!".
format(group['timeout_min']),
color.BOLD))
is_success = False
for runner in self.active_runners:
+4 -9
View File
@@ -8,7 +8,7 @@ import atexit
import subprocess
import threading
import errno
from logger_helper import color
from logger_helper import color, maybe_strip_color, colorize
class Runner:
@@ -81,10 +81,7 @@ class Runner:
def get_output(self):
try:
output = self.output_queue.get(block=True, timeout=0.1)
if supports_color():
return output
else:
return remove_color(output)
return maybe_strip_color(output)
except queue.Empty:
return None
@@ -92,10 +89,8 @@ class Runner:
output = self.get_output()
if not output:
return
print(color.END +
"[" + self.name.ljust(11) + "] " +
output +
color.END, end="")
print(colorize("[" + self.name.ljust(11) + "] " + output, color.RESET),
end="")
def stop(self):
atexit.unregister(self.stop)