[Libreoffice-commits] core.git: bin/check-missing-unittests.py
Xisco Fauli (via logerrit)
logerrit at kemper.freedesktop.org
Thu Feb 4 20:31:23 UTC 2021
bin/check-missing-unittests.py | 43 ++++++++++++++++++++++++++++++++++++++++-
1 file changed, 42 insertions(+), 1 deletion(-)
New commits:
commit 948207edfbb6a8bcce2573ec758bacf818bbd2c7
Author: Xisco Fauli <xiscofauli at libreoffice.org>
AuthorDate: Thu Feb 4 15:40:01 2021 +0100
Commit: Xisco Fauli <xiscofauli at libreoffice.org>
CommitDate: Thu Feb 4 21:30:32 2021 +0100
check-missing-unittests: use bugzilla rest api
to ignore open bugs or performance issues
Change-Id: Id43ef8bae4936213a65fded3ce138bbf43de397e
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/110420
Tested-by: Jenkins
Reviewed-by: Xisco Fauli <xiscofauli at libreoffice.org>
diff --git a/bin/check-missing-unittests.py b/bin/check-missing-unittests.py
index 3ce385f82f0d..847aa524f1ad 100755
--- a/bin/check-missing-unittests.py
+++ b/bin/check-missing-unittests.py
@@ -11,6 +11,15 @@ import datetime
import subprocess
import sys
import re
+import json
+import requests
+
+def isOpen(status):
+ return status == 'NEW' or status == 'ASSIGNED' or status == 'REOPENED'
+
+def splitList(lst, n):
+ for i in range(0, len(lst), n):
+ yield lst[i:i + n]
def main(ignoredBugs):
results = {
@@ -34,6 +43,7 @@ def main(ignoredBugs):
},
'impress': {
'drawingml': {},
+ 'slidesorter': {},
'others': {},
},
@@ -116,6 +126,9 @@ def main(ignoredBugs):
elif 'drawingml' in changedFiles:
results['impress']['drawingml'][bugId] = infoList
+ elif 'sd/source/ui/slidesorter/' in changedFiles:
+ results['impress']['slidesorter'][bugId] = infoList
+
elif 'sc/source/core/tool/interpr' in changedFiles:
results['calc']['import'][bugId] = infoList
@@ -130,6 +143,22 @@ def main(ignoredBugs):
elif 'sd/source/core/' in changedFiles:
results['impress']['others'][bugId] = infoList
+ listOfBugIdsWithoutTest = []
+ for k,v in results.items():
+ for k1, v1 in v.items():
+ for bugId, info in v1.items():
+ if bugId not in hasTestSet:
+ listOfBugIdsWithoutTest.append(bugId)
+
+ bugzillaJson = []
+ #Split the list into different chunks for the requests, otherwise it fails
+ for chunk in splitList(listOfBugIdsWithoutTest, 50):
+ urlGet = 'https://bugs.documentfoundation.org/rest/bug?id=' + ','.join(chunk)
+ rGet = requests.get(urlGet)
+ rawData = json.loads(rGet.text)
+ rGet.close()
+ bugzillaJson.extend(rawData['bugs'])
+
print()
print('{{TopMenu}}')
print('{{Menu}}')
@@ -142,15 +171,27 @@ def main(ignoredBugs):
print('Branch: ' + branch.decode().strip())
print()
print('Hash: ' + str(last_hash.decode().strip()))
+
for k,v in results.items():
print('\n== ' + k + ' ==')
for k1, v1 in v.items():
print('\n=== ' + k1 + ' ===')
for bugId, info in v1.items():
- if bugId not in hasTestSet:
+
+ status = ''
+ keywords = []
+ for bug in bugzillaJson:
+ if str(bug['id']) == str(bugId):
+ status = bug['status']
+ keywords = bug['keywords']
+ break
+
+ #Ignore open bugs and performance bugs
+ if status and not isOpen(status) and 'perf' not in keywords:
print(
"# {} - {} - [https://bugs.documentfoundation.org/show_bug.cgi?id={} tdf#{}]".format(
info[0], info[1], bugId, bugId))
+
print('\n== ignored bugs ==')
print(' '.join(ignoredBugs))
print()
More information about the Libreoffice-commits
mailing list