-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcover_cal.py
More file actions
107 lines (98 loc) · 4.46 KB
/
cover_cal.py
File metadata and controls
107 lines (98 loc) · 4.46 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
import csv
import json
import os
import glob
# 存储方法覆盖率和覆盖测试的字典
input_dir = "/Users/linzheyuan/loghound/tgt_sys/coverage_out"
if not os.path.exists(input_dir+"/json"):
os.makedirs(input_dir+"/json")
print(f"Folder created: {input_dir+"/json"}")
else:
print(f"Folder already exists: {input_dir+"/json"}")
for csv_file in glob.glob(os.path.join(input_dir, "*.csv")):
method_coverage_and_tests = {}
print(f"Processing {csv_file}...")
# 假设数据存储在一个名为 input_data.csv 的文件中,你可以根据实际情况修改
# with open(csv_file, "r", encoding="utf-8") as file:
# reader = csv.reader(file)
# next(reader)
# for row in reader:
# method_sig = row[1]
# internal_covered = int(row[2])
# internal_total = int(row[3])
# covering_test_full = row[4]
# # 去除测试名称中 @ 符号后的调用点位信息
# covering_test = covering_test_full.split('@')[0]
#
# coverage = 0 if internal_total == 0 else internal_covered / internal_total
#
# if method_sig not in method_coverage_and_tests:
# method_coverage_and_tests[method_sig] = {
# 'coverage': coverage,
# 'tests': [covering_test]
# }
# else:
# # 保留最大覆盖率(避免被后一个覆盖掉更高的值)
# method_coverage_and_tests[method_sig]["coverage"] = max(
# method_coverage_and_tests[method_sig]["coverage"], coverage
# )
# method_coverage_and_tests[method_sig]["tests"].append(covering_test)
#
# # 准备要输出到 JSON 文件的数据
# output_data = []
# for method_sig, info in method_coverage_and_tests.items():
# output_data.append({
# "method_sig": method_sig,
# "coverage": info["coverage"],
# "covering_tests": list(set(info["tests"])) # 去重
# })
# # 利用 file.name 获取当前输入 CSV 的完整路径
# csv_path = file.name
# csv_dir = "/Users/linzheyuan/loghound/tgt_sys/coverage_out/json"
# csv_base = os.path.splitext(os.path.basename(csv_path))[0]
#
# # 1) 先生成“单文件 JSON”
# single_json_path = os.path.join(csv_dir, f"{csv_base}_method_coverage.json")
#
# # 将数据输出到 JSON 文件
# with open(single_json_path, 'w', encoding='utf-8') as json_file:
# json.dump(output_data, json_file, ensure_ascii=False, indent=4)
with open(csv_file, "r", encoding="utf-8") as file:
reader = csv.reader(file)
next(reader) # 跳过表头
# 遍历一次,边累积边更新
for row in reader:
method_sig = row[1]
internal_covered = int(row[2])
internal_total = int(row[3])
covering_test_full = row[4]
covering_test = covering_test_full.split('@')[0]
coverage = 0 if internal_total == 0 else internal_covered / internal_total
if method_sig not in method_coverage_and_tests:
method_coverage_and_tests[method_sig] = {
'coverage': coverage,
'tests': {covering_test} # 用 set 避免重复
}
else:
method_coverage_and_tests[method_sig]['coverage'] = max(
method_coverage_and_tests[method_sig]['coverage'], coverage
)
method_coverage_and_tests[method_sig]['tests'].add(covering_test)
# 遍历完成后统一准备输出
output_data = [
{
"method_sig": method_sig,
"coverage": info["coverage"],
"covering_tests": list(info["tests"])
}
for method_sig, info in method_coverage_and_tests.items()
]
# 利用 file.name 获取路径
csv_path = file.name
csv_dir = "/Users/linzheyuan/loghound/tgt_sys/coverage_out/json_new"
os.makedirs(csv_dir, exist_ok=True) # 确保输出目录存在
csv_base = os.path.splitext(os.path.basename(csv_path))[0]
# 单文件 JSON
single_json_path = os.path.join(csv_dir, f"{csv_base}_method_coverage.json")
with open(single_json_path, 'w', encoding='utf-8') as json_file:
json.dump(output_data, json_file, ensure_ascii=False, indent=4)