-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrunner.py
110 lines (102 loc) · 4.71 KB
/
runner.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
98
99
100
101
102
103
104
105
106
107
108
109
110
import requests
import json
from os import environ
import tests.cobra
import tests.yaml
import tests.memote
API_ENDPOINT = 'https://api.github.com/graphql'
API_TOKEN = environ['GH_TOKEN']
MODEL_FILENAME = 'model'
MODEL_FORMATS = ['.yml', '.xml', '.mat', '.json']
RELEASES = 5
header_auth = {'Authorization': 'token %s' % API_TOKEN}
# additional_branch_tags = []
additional_branch_tags = ['main']
def gem_repositories():
json_request = {"query" : """
{ search(
type: REPOSITORY,
query: \"\"\"fork:true topic:standard-GEM\"\"\",
first: 100
)
{ repos:
edges {
repo: node {
... on Repository { nameWithOwner }
}
}
}
}""" }
r = requests.post(url=API_ENDPOINT, json=json_request, headers=header_auth)
json_data = json.loads(r.text)['data']['search']['repos']
gem_repositories = map(lambda x: x['repo']['nameWithOwner'], json_data)
filtered_repositories = filter(lambda x: 'standard-GEM' not in x, gem_repositories)
return filtered_repositories
def releases(nameWithOwner):
owner, repo = nameWithOwner.split('/')
json_request = { "query": """
{ repository(
owner: \"%s\",
name: \"%s\"
)
{ releases(first: %s){
edges {
node { tagName }
}
}
}
}""" % (owner, repo, RELEASES) }
r = requests.post(url=API_ENDPOINT, json=json_request, headers=header_auth)
json_data = json.loads(r.text)['data']['repository']['releases']['edges']
release_tags = list(map(lambda x: x['node']['tagName'], json_data))
if not release_tags:
return []
return additional_branch_tags + release_tags
def matrix():
m = json.dumps(list(gem_repositories()))
with open("index.json", "w") as file:
file.write(m)
def gem_follows_standard(nameWithOwner, release, version):
repo_standard = requests.get('https://raw.githubusercontent.com/{}/{}/.standard-GEM.md'.format(nameWithOwner, release))
if repo_standard.status_code == 404:
return False
repo_standard = repo_standard.text
raw_standard = requests.get('https://raw.githubusercontent.com/MetabolicAtlas/standard-GEM/{}/.standard-GEM.md'.format(version)).text
import difflib
the_diff = difflib.ndiff(repo_standard, raw_standard)
return True
def validate(nameWithOwner):
owner, model = nameWithOwner.split('/')
data = {}
data[nameWithOwner] = []
for model_release in releases(nameWithOwner):
release_data = {}
standard_gem_releases = releases('MetabolicAtlas/standard-GEM')
last_standard = standard_gem_releases[len(standard_gem_releases)-1:]
for standard_version in last_standard:
print("{}: {} | standard-GEM version: {}".format(nameWithOwner, model_release, standard_version))
gem_is_standard = gem_follows_standard(nameWithOwner, model_release, standard_version)
test_results = {}
if gem_is_standard:
for model_format in MODEL_FORMATS:
my_model = model + model_format
response = requests.get('https://raw.githubusercontent.com/{}/{}/model/{}'.format(nameWithOwner, model_release, my_model), timeout=10)
if response.ok:
with open(my_model, 'w') as file:
file.write(response.text)
test_results.update(resultJSONString(tests.cobra.loadYaml, model))
test_results.update(resultJSONString(tests.cobra.loadSbml, model))
test_results.update(resultJSONString(tests.cobra.loadMatlab, model))
test_results.update(resultJSONString(tests.cobra.loadJson, model))
test_results.update(resultJSONString(tests.cobra.validateSbml, model))
test_results.update(resultJSONString(tests.yaml.validate, model))
test_results.update(resultJSONString(tests.memote.scoreAnnotationAndConsistency, model))
else:
print('is not following standard')
release_data = { 'standard-GEM' : [ { standard_version : gem_is_standard }, { 'test_results' : test_results} ] }
data[nameWithOwner].append({ model_release: release_data })
with open('results/{}_{}.json'.format(owner, model), 'w') as output:
output.write(json.dumps(data, indent=2, sort_keys=True))
def resultJSONString(testToRun, model):
testModule, description, moduleVersion, status, errors = testToRun(model)
return {testModule: { 'description': description, 'version': moduleVersion, 'status': status, 'errors': errors[:300] } }