You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
46 lines
1.0 KiB
46 lines
1.0 KiB
6 years ago
|
#!/usr/bin/env python2
|
||
|
import bz2
|
||
|
import os
|
||
|
import sys
|
||
|
|
||
|
import dictdiffer
|
||
|
if "CI" in os.environ:
|
||
|
tqdm = lambda x: x
|
||
|
else:
|
||
|
from tqdm import tqdm
|
||
|
|
||
|
from tools.lib.logreader import LogReader
|
||
|
|
||
|
|
||
|
def save_log(dest, log_msgs):
|
||
|
dat = ""
|
||
|
for msg in log_msgs:
|
||
|
dat += msg.as_builder().to_bytes()
|
||
|
dat = bz2.compress(dat)
|
||
|
|
||
|
with open(dest, "w") as f:
|
||
|
f.write(dat)
|
||
|
|
||
|
def compare_logs(log1, log2, ignore=[]):
|
||
|
assert len(log1) == len(log2), "logs are not same length"
|
||
|
|
||
|
diff = []
|
||
|
for msg1, msg2 in tqdm(zip(log1, log2)):
|
||
|
assert msg1.which() == msg2.which(), "msgs not aligned between logs"
|
||
|
|
||
|
msg1_bytes = msg1.as_builder().to_bytes()
|
||
|
msg2_bytes = msg2.as_builder().to_bytes()
|
||
|
|
||
|
if msg1_bytes != msg2_bytes:
|
||
|
msg1_dict = msg1.to_dict(verbose=True)
|
||
|
msg2_dict = msg2.to_dict(verbose=True)
|
||
|
dd = dictdiffer.diff(msg1_dict, msg2_dict, ignore=ignore, tolerance=0)
|
||
|
diff.extend(dd)
|
||
|
return diff
|
||
|
|
||
|
if __name__ == "__main__":
|
||
|
log1 = list(LogReader(sys.argv[1]))
|
||
|
log2 = list(LogReader(sys.argv[2]))
|
||
|
|
||
|
compare_logs(log1, log2, sys.argv[3:])
|