This repository has been archived by the owner on Nov 6, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 865
/
Copy pathbuild_test_config.py
97 lines (76 loc) · 3.24 KB
/
build_test_config.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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
"""Write a YAML file for the Voight-Kampff test setup script.
Voight-Kampff is the name of the integration test suite for mycroft-core and
mycroft-skills. The test setup script installs the skills to include in the
test and copies their feature files over to core for inclusion in the tests.
"""
from argparse import ArgumentParser
from os import environ
import re
import requests
from github import Github
def parse_command_line():
"""Get the values of the command line arguments."""
arg_parser = ArgumentParser()
arg_parser.add_argument(
"--pull-request",
default=None,
help='The Pull Request to be tested.'
)
arg_parser.add_argument(
"--platform",
default='mycroft_mark_1',
help='The Pull Request to be tested.'
)
return arg_parser.parse_args()
def get_pull_request_diff(args):
"""Get the difference between the base branch and the modified branch."""
pr_number = int(args.pull_request.strip('PR-'))
g = Github(environ['GITHUB_API_KEY'])
repo = g.get_repo('MycroftAI/mycroft-skills')
pr = repo.get_pull(pr_number)
pr_diff = requests.get(pr.diff_url)
return pr_diff.text.split('\n')
def get_pull_request_submodule(pull_request_diff):
"""Determine the submodule name of the skill added/modified in the PR"""
diff_file_name = None
skill_submodule_path = None
for line in pull_request_diff:
# The line indicating the file being compared looks like this:
# diff --git a/<file name> b/<file name>
if line.startswith('diff --git a/'):
words = line.split()
diff_file_name = words[2].lstrip('a/').rstrip(' b/')
# If a file contains a subproject commit hash it represents a skill
if line.startswith('+Subproject commit '):
skill_submodule_path = diff_file_name
break
return skill_submodule_path
def get_skill_submodule_name(skill_submodule_path):
"""Find the skill name from a skill submodule path."""
with open('.gitmodules') as f:
for line in f:
name_match = re.match(r"\[submodule \"(?P<entryname>.+)\"\]", line)
if name_match:
name = name_match.groups()[0]
if line.strip() == f'path = {skill_submodule_path}':
return name
print("WARNING: The skill name couldn't be determined. "
"Using skill_submodule_path instead!")
return skill_submodule_path
def write_test_config_file(submodule_path):
"""Write a YAML file for the integration test setup script."""
with open('test_skill.yml', 'w') as config_file:
config_file.write('test_skills:\n')
config_file.write(' '.join(['-', submodule_path, '\n']))
def main():
args = parse_command_line()
pull_request_diff = get_pull_request_diff(args)
skill_submodule_path = get_pull_request_submodule(pull_request_diff)
if skill_submodule_path is None:
# Not every PR into this repository will be a change to a skill.
# If no Skill submodule was found, use the "hello world" Skill.
skill_submodule_path = 'skill-hello-world'
skill_submodule_name = get_skill_submodule_name(skill_submodule_path)
write_test_config_file(skill_submodule_name)
if __name__ == '__main__':
main()