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.
		
		
		
		
			
				
					62 lines
				
				1.5 KiB
			
		
		
			
		
	
	
					62 lines
				
				1.5 KiB
			| 
											6 years ago
										 | #!/usr/bin/env python3
 | ||
| 
											6 years ago
										 | 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)
 | ||
|  | 
 | ||
| 
											6 years ago
										 | def remove_ignored_fields(msg, ignore):
 | ||
|  |   msg = msg.as_builder() 
 | ||
|  |   for key, val in ignore:
 | ||
|  |     attr = msg
 | ||
|  |     keys = key.split(".")
 | ||
|  |     if msg.which() not in key and len(keys) > 1:
 | ||
|  |       continue
 | ||
|  |     
 | ||
|  |     for k in keys[:-1]:
 | ||
|  |       try:
 | ||
|  |         attr = getattr(msg, k)
 | ||
|  |       except:
 | ||
|  |         break
 | ||
|  |     else:
 | ||
|  |       setattr(attr, keys[-1], val)
 | ||
|  |   return msg.as_reader()
 | ||
|  | 
 | ||
| 
											6 years ago
										 | def compare_logs(log1, log2, ignore=[]):
 | ||
|  |   assert len(log1) == len(log2), "logs are not same length"
 | ||
|  | 
 | ||
| 
											6 years ago
										 |   ignore_fields = [k for k, v in ignore]
 | ||
| 
											6 years ago
										 |   diff = []
 | ||
|  |   for msg1, msg2 in tqdm(zip(log1, log2)):
 | ||
|  |     assert msg1.which() == msg2.which(), "msgs not aligned between logs"
 | ||
|  | 
 | ||
| 
											6 years ago
										 |     msg1_bytes = remove_ignored_fields(msg1, ignore).as_builder().to_bytes()
 | ||
|  |     msg2_bytes = remove_ignored_fields(msg2, ignore).as_builder().to_bytes()
 | ||
| 
											6 years ago
										 | 
 | ||
|  |     if msg1_bytes != msg2_bytes:
 | ||
|  |       msg1_dict = msg1.to_dict(verbose=True)
 | ||
|  |       msg2_dict = msg2.to_dict(verbose=True)
 | ||
| 
											6 years ago
										 |       dd = dictdiffer.diff(msg1_dict, msg2_dict, ignore=ignore_fields, tolerance=0)
 | ||
| 
											6 years ago
										 |       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:])
 |