forked from Cookies_Public/AquaDX
		
	[O] Better diffing
This commit is contained in:
		
							parent
							
								
									77a791e5da
								
							
						
					
					
						commit
						0cb3fd3134
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -82,3 +82,4 @@ src/main/resources/meta/*/*.json | ||||
| *.log.*.gz | ||||
| *.salive | ||||
| test-diff | ||||
| htmlReport | ||||
|  | ||||
| @ -1,6 +1,8 @@ | ||||
| import json | ||||
| import re | ||||
| from pathlib import Path | ||||
| 
 | ||||
| import genson | ||||
| import requests | ||||
| 
 | ||||
| token = "fill this in" | ||||
| @ -9,27 +11,6 @@ urls = { | ||||
|     "staging": f"http://staging.aquadx.net/gs/{token}/chu3/2.27" | ||||
| } | ||||
| 
 | ||||
| def decode_to_dict(s: str) -> dict: | ||||
|     # Remove the surrounding braces | ||||
|     s = s.strip('{}') | ||||
|     # Use regex to match key-value pairs | ||||
|     pairs = re.findall(r'(\w+)=([^,]+)', s) | ||||
|     # Convert the list of tuples into a dictionary | ||||
|     decoded_dict = {} | ||||
|     for key, value in pairs: | ||||
|         if key == 'version': | ||||
|             continue | ||||
|         decoded_dict[key] = value | ||||
|         # # Try to convert numeric values to int or float | ||||
|         # if value.isdigit(): | ||||
|         #     decoded_dict[key] = int(value) | ||||
|         # else: | ||||
|         #     try: | ||||
|         #         decoded_dict[key] = float(value) | ||||
|         #     except ValueError: | ||||
|         #         decoded_dict[key] = value  # Keep it as a string if not a number | ||||
|     return decoded_dict | ||||
| 
 | ||||
| 
 | ||||
| def save_resp(i, idx, api, data): | ||||
|     url = urls[idx] | ||||
| @ -41,20 +22,60 @@ Request: {api} | ||||
| Response: {resp.status_code} | ||||
| {resp.text} | ||||
| """ | ||||
|     print(txt) | ||||
|     Path(f"test-diff/{idx}").mkdir(exist_ok=True, parents=True) | ||||
|     Path(f"test-diff/{idx}/{i}-{api}.json").write_text(txt) | ||||
|     Path(f"test-diff/{idx}-struct").mkdir(exist_ok=True, parents=True) | ||||
|     Path(f"test-diff/{idx}-struct/{i}-{api}.json").write_text(json.dumps(to_structure(resp.json()), indent=2)) | ||||
| 
 | ||||
| 
 | ||||
| # def to_structure(d: dict): | ||||
| #     # Convert the dictionary into type structure | ||||
| #     # e.g. {a: "1", b: 2, c: [1, 2, 3], d: {e: true, f: [1, "b", "c"]}} -> {a: "str", b: "int", c: ["int"], d: {e: "bool", f: ["int", "str"]}} | ||||
| #     # Make sure that the returned dict is sorted by key | ||||
| #     def get_type(value): | ||||
| #         # Handle dictionary | ||||
| #         if isinstance(value, dict): | ||||
| #             return {key: get_type(val) for key, val in value.items()} | ||||
| #         # Handle list | ||||
| #         elif isinstance(value, list): | ||||
| #             # Get unique types from the list | ||||
| #             unique_types = {get_type(item) for item in value} | ||||
| #             if len(unique_types) == 1: | ||||
| #                 return [unique_types.pop()]  # Homogeneous list | ||||
| #             return list(unique_types)  # Heterogeneous list | ||||
| #         else: | ||||
| #             return type(value).__name__ | ||||
| # | ||||
| #     return get_type(d) | ||||
| 
 | ||||
| 
 | ||||
| def to_structure(d: dict): | ||||
|     b = genson.SchemaBuilder() | ||||
|     b.add_object(d) | ||||
|     return sort_dict_keys(b.to_schema()) | ||||
| 
 | ||||
| 
 | ||||
| def sort_dict_keys(data): | ||||
|     if isinstance(data, dict): | ||||
|         # Sort the dictionary keys and recursively sort its values | ||||
|         return {key: sort_dict_keys(data[key]) for key in sorted(data)} | ||||
|     elif isinstance(data, list): | ||||
|         # If the value is a list, sort each item in the list recursively | ||||
|         return [sort_dict_keys(item) for item in data] | ||||
|     else: | ||||
|         # Return the value as is if it's not a dict or list | ||||
|         return data | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|     # Read chusan.log | ||||
|     d = Path("chusan.log").read_text('utf-8').splitlines() | ||||
|     d = Path("test.log").read_text('utf-8').splitlines() | ||||
|     d = [l.split("|", 1)[1] for l in d if '|' in l] | ||||
|     d = [l.split(": ", 1)[1] for l in d if ': ' in l] | ||||
|     d = [l for l in d if l.startswith("Chu3 <")] | ||||
|     d = [l for l in d if l.startswith("Chu3 <") and 'Upsert' not in l] | ||||
|     d = [l.split("< ", 1)[1] for l in d] | ||||
|     d = [l.split(" : ") for l in d if l.count("{") == 1]  # (api, data) | ||||
|     d = [(api, decode_to_dict(data)) for api, data in d] | ||||
|     d = [l.split(" : ") for l in d]  # (api, data) | ||||
|     d = [(api, json.loads(data)) for api, data in d] | ||||
| 
 | ||||
|     print(d) | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Azalea
						Azalea