forked from tahiat/specimin-evaluation
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathcode_line.py
76 lines (62 loc) · 2.76 KB
/
code_line.py
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
import os
from main import read_json_from_file
from main import get_repository_name
import json
import subprocess
'''
This script depends on scc tool: https://github.com/boyter/scc
'''
def main():
json_file_path = os.path.join("resources", "test_data.json")
parsed_data = read_json_from_file(json_file_path)
code_count = {}
if parsed_data:
for issue in parsed_data:
issue_id = issue["issue_id"]
url = issue["url"]
repo_name = get_repository_name(url)
# get hand min program loc
hand_code_line = 0
specimin_code_line = 0
hand_min_program_path = os.path.join("ISSUES", issue_id, "input", repo_name, "specimin", "test")
if os.path.exists(hand_min_program_path):
output = subprocess.check_output(["scc", "-f", "json"], cwd=hand_min_program_path)
data = json.loads(output) # this is array of dictionary
for item in data:
if item.get("Name") == "Java": # checking only java line code
hand_code_line += item.get("Code")
else:
print(f"Test code not available for {issue_id}")
# get specimin min program loc
specimin_min_program_path = os.path.join("ISSUES", issue_id, "output", repo_name, "src")
if os.path.exists(specimin_min_program_path):
output = subprocess.check_output(["scc", "-f", "json"], cwd=specimin_min_program_path)
data = json.loads(output) # this is array of dictionary
for item in data:
if item.get("Name") == "Java": # checking only java line code
specimin_code_line += item.get("Code")
else:
print(f"Minimization was failed/ not executed {issue_id}")
combined_code_info = {"test": hand_code_line, "specimin": specimin_code_line}
code_count[issue_id] = combined_code_info
pretty_json = json.dumps(code_count, indent=4)
print(pretty_json)
total_specimin_line = 0
total_hand_written_line = 0
sp_divisor = 0
hand_divisor = 0
for key in code_count:
sl = code_count.get(key).get("specimin")
total_specimin_line += sl
sp_divisor = sp_divisor + 1 if sl != 0 else sp_divisor
hl = code_count.get(key).get("test")
total_hand_written_line += hl
hand_divisor = hand_divisor + 1 if hl != 0 else hand_divisor
print(f"sp_divisor = {sp_divisor}")
print(f"hand_divisor = {hand_divisor}")
sp_avg = round(total_specimin_line/sp_divisor)
hand_avg = round(total_hand_written_line/hand_divisor)
print(f"sp_avg: {sp_avg}")
print(f"hand_avg: {hand_avg}")
if __name__ == "__main__":
main()