Add script to rerun process on route and generate new logs (#22100)
* add script to rerun process on route and generate new logs
* cleanup
* move to root
* newline
old-commit-hash: 3b13eb8c7d
commatwo_master
parent
3150250f00
commit
503fe7421a
3 changed files with 41 additions and 1 deletions
@ -0,0 +1,31 @@ |
||||
#!/usr/bin/env python3 |
||||
|
||||
import argparse |
||||
|
||||
from selfdrive.test.process_replay.compare_logs import save_log |
||||
from selfdrive.test.process_replay.process_replay import CONFIGS, replay_process |
||||
from tools.lib.logreader import MultiLogIterator |
||||
from tools.lib.route import Route |
||||
|
||||
if __name__ == "__main__": |
||||
parser = argparse.ArgumentParser(description="Run process on route and create new logs", |
||||
formatter_class=argparse.ArgumentDefaultsHelpFormatter) |
||||
parser.add_argument("route", help="The route name to use") |
||||
parser.add_argument("process", help="The process to run") |
||||
args = parser.parse_args() |
||||
|
||||
cfg = [c for c in CONFIGS if c.proc_name == args.process][0] |
||||
|
||||
route = Route(args.route) |
||||
lr = MultiLogIterator(route.log_paths(), wraparound=False) |
||||
inputs = list(lr) |
||||
|
||||
outputs = replay_process(cfg, inputs) |
||||
|
||||
# Remove message generated by the process under test and merge in the new messages |
||||
produces = set(o.which() for o in outputs) |
||||
inputs = [i for i in inputs if i.which() not in produces] |
||||
outputs = sorted(inputs + outputs, key=lambda x: x.logMonoTime) |
||||
|
||||
fn = f"{args.route}_{args.process}.bz2" |
||||
save_log(fn, outputs) |
Loading…
Reference in new issue