Skip to content

Commit e53e026

Browse files
authored
Add broken tags to FW's that haven't started/stopped correctly in last 3 full runs + script for detecting failing frameworks (#8255)
* Web scraper for detecting failing frameworks * Mark tests that have issues starting as broken * Add broken tag to frameworks that fail all tests * remove prologue broken tag * Cherrypy fix attempt
1 parent 922ad8e commit e53e026

File tree

11 files changed

+108
-14
lines changed

11 files changed

+108
-14
lines changed

frameworks/Java/spring-webflux/benchmark_config.json

+8-4
Original file line numberDiff line numberDiff line change
@@ -41,7 +41,8 @@
4141
"database_os": "Linux",
4242
"display_name": "spring-webflux-mongo",
4343
"notes": "",
44-
"versus": "spring"
44+
"versus": "spring",
45+
"tags": ["broken"]
4546
},
4647
"pgclient": {
4748
"db_url": "/db",
@@ -62,7 +63,8 @@
6263
"database_os": "Linux",
6364
"display_name": "spring-webflux-pgclient",
6465
"notes": "",
65-
"versus": "spring"
66+
"versus": "spring",
67+
"tags": ["broken"]
6668
},
6769
"rxjdbc": {
6870
"db_url": "/db",
@@ -83,7 +85,8 @@
8385
"database_os": "Linux",
8486
"display_name": "spring-webflux-rxjdbc",
8587
"notes": "",
86-
"versus": "spring"
88+
"versus": "spring",
89+
"tags": ["broken"]
8790
},
8891
"jdbc": {
8992
"db_url": "/db",
@@ -104,7 +107,8 @@
104107
"database_os": "Linux",
105108
"display_name": "spring-webflux-jdbc",
106109
"notes": "",
107-
"versus": "spring"
110+
"versus": "spring",
111+
"tags": ["broken"]
108112
}
109113
}]
110114
}

frameworks/JavaScript/sailsjs/benchmark_config.json

+2-1
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,8 @@
2222
"database_os": "Linux",
2323
"display_name": "Sails.js",
2424
"notes": "",
25-
"versus": "nodejs"
25+
"versus": "nodejs",
26+
"tags": ["broken"]
2627
},
2728
"postgres": {
2829
"db_url": "/postgres/db",

frameworks/Kotlin/vertx-web-kotlin-coroutines/benchmark_config.json

+2-1
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,8 @@
1818
"database_os": "Linux",
1919
"display_name": "vertx-web-kotlin-coroutines",
2020
"notes": "",
21-
"versus": "vertx-web"
21+
"versus": "vertx-web",
22+
"tags": ["broken"]
2223
},
2324
"postgres": {
2425
"db_url": "/db",

frameworks/PHP/php/benchmark_config.json

+2-1
Original file line numberDiff line numberDiff line change
@@ -112,7 +112,8 @@
112112
"database_os": "Linux",
113113
"display_name": "PHP Unit Nginx",
114114
"notes": "",
115-
"versus": "php"
115+
"versus": "php",
116+
"tags": ["broken"]
116117
},
117118
"pools": {
118119
"json_url": "/json.php",

frameworks/Python/cherrypy/app.py

+2
Original file line numberDiff line numberDiff line change
@@ -154,6 +154,8 @@ def fortunes(self):
154154
cherrypy.server.socket_host = '0.0.0.0'
155155
cherrypy.server.socket_port = 8080
156156
cherrypy.server.thread_pool = workers
157+
cherrypy.server.socket_queue_size = 25
158+
157159
cherrypy.quickstart(CherryPyBenchmark(), '', {
158160
'/': {
159161
'tools.db.on': True,

frameworks/Python/cherrypy/benchmark_config.json

+2-1
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,8 @@
2121
"os": "Linux",
2222
"database_os": "Linux",
2323
"display_name": "CherryPy [py2]",
24-
"notes": "CPython 2.7"
24+
"notes": "CPython 2.7",
25+
"tags": ["broken"]
2526
},
2627
"py3": {
2728
"json_url": "/json",

frameworks/Python/fastapi/benchmark_config.json

+4-2
Original file line numberDiff line numberDiff line change
@@ -169,7 +169,8 @@
169169
"database_os": "Linux",
170170
"display_name": "FastAPI-nginx-unit",
171171
"notes": "",
172-
"versus": "None"
172+
"versus": "None",
173+
"tags": ["broken"]
173174
},
174175
"nginx-unit-orjson": {
175176
"json_url": "/json",
@@ -190,7 +191,8 @@
190191
"database_os": "Linux",
191192
"display_name": "FastAPI-nginx-unit-orjson",
192193
"notes": "",
193-
"versus": "None"
194+
"versus": "None",
195+
"tags": ["broken"]
194196
},
195197
"uvicorn": {
196198
"json_url": "/json",

frameworks/Python/sanic/benchmark_config.json

+2-1
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,8 @@
2323
"database_os": "Linux",
2424
"display_name": "Sanic",
2525
"notes": "",
26-
"versus": "None"
26+
"versus": "None",
27+
"tags": ["broken"]
2728
}
2829
}
2930
]

frameworks/Rust/rocket/benchmark_config.json

+4-2
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,8 @@
2222
"database_os": "Linux",
2323
"display_name": "Rocket",
2424
"notes": "",
25-
"versus": "None"
25+
"versus": "None",
26+
"tags": ["broken"]
2627
},
2728
"diesel": {
2829
"json_url": "/json",
@@ -45,7 +46,8 @@
4546
"database_os": "Linux",
4647
"display_name": "Rocket (Diesel)",
4748
"notes": "",
48-
"versus": "None"
49+
"versus": "None",
50+
"tags": ["broken"]
4951
}
5052
}]
5153
}

frameworks/Scala/snunit/benchmark_config.json

+2-1
Original file line numberDiff line numberDiff line change
@@ -19,7 +19,8 @@
1919
"database_os": "Linux",
2020
"display_name": "SNUnit",
2121
"notes": "",
22-
"versus": ""
22+
"versus": "",
23+
"tags": ["broken"]
2324
}
2425
}
2526
]

scripts/tfb-fail-detector.py

+78
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,78 @@
1+
"""
2+
TFB Fail Detector Web Scraper
3+
Scrapes data from the last 3 complete runs and outputs the frameworks that have failed all of them with the same errors.
4+
5+
Developed using selenium==4.10.0 and the selenium/standalone-chrome:4.10.0 docker image.
6+
7+
USAGE: python tfb-fail-detector.py
8+
"""
9+
10+
from collections import defaultdict
11+
import re
12+
13+
from selenium import webdriver
14+
from selenium.webdriver.chrome.options import Options
15+
from selenium.webdriver.common.by import By
16+
17+
NUM_RUNS = 3
18+
19+
def get_driver():
20+
"""Gets the selenium webdriver for interacting with the website"""
21+
chrome_options = Options()
22+
chrome_options.add_argument("--headless")
23+
chrome_options.add_argument("--no-sandbox")
24+
chrome_options.add_argument("--disable-dev-shm-usage")
25+
chrome_prefs = {}
26+
chrome_options.experimental_options["prefs"] = chrome_prefs
27+
chrome_prefs["profile.default_content_settings"] = {"images": 2}
28+
driver = webdriver.Chrome(options=chrome_options)
29+
return driver
30+
31+
def get_last_n_complete_runs(driver, n=3):
32+
"""Scrape the last n complete runs"""
33+
rows = driver.find_elements(By.CSS_SELECTOR, "table.resultsTable > tbody > tr")
34+
complete_runs = []
35+
for row in rows:
36+
row_uuid = row.get_dom_attribute("data-uuid")
37+
run_stats = row.find_element(By.CSS_SELECTOR, "td:nth-of-type(2)")
38+
frameworks_tested_stats = re.search(r"([0-9]+)/([0-9]+) frameworks tested", run_stats.text)
39+
if not frameworks_tested_stats:
40+
# print("Unable to get info from run %s" % row_uuid)
41+
continue
42+
tested, total = frameworks_tested_stats.groups()
43+
if tested != total:
44+
# print("Found incomplete run %s. Tested: %s/%s" % (row_uuid, tested, total))
45+
continue
46+
# print("Found complete run %s. Tested: %s/%s" % (row_uuid, tested, total))
47+
complete_runs.append(row_uuid)
48+
if len(complete_runs) >= n:
49+
return complete_runs
50+
51+
def find_failing_frameworks(driver, run_uuids):
52+
"""Find frameworks that have failed all the given runs with the same error message"""
53+
failing_frameworks = defaultdict(lambda: 0)
54+
def process_failed_framework(framework_element):
55+
framework = re.search(r"\[\S+] [a-zA-Z][a-zA-Z:\_ ]*$", framework_element.text)
56+
framework_failure = framework.group(0)
57+
failing_frameworks[framework_failure] += 1
58+
59+
for run_uuid in run_uuids:
60+
driver.get("https://tfb-status.techempower.com/results/%s" % run_uuid)
61+
assert "TFB Status" in driver.title
62+
failure_list = driver.find_element(By.CLASS_NAME, "failures")
63+
failures = failure_list.find_elements(By.TAG_NAME, "li")
64+
for failure in failures:
65+
process_failed_framework(failure)
66+
return failing_frameworks
67+
68+
if __name__ == '__main__':
69+
driver = get_driver()
70+
driver.get("https://tfb-status.techempower.com/")
71+
assert "TFB Status" in driver.title
72+
complete_runs = get_last_n_complete_runs(driver, NUM_RUNS)
73+
failed_frameworks = find_failing_frameworks(driver, complete_runs)
74+
75+
for failure_info, fail_count in failed_frameworks.items():
76+
if fail_count != NUM_RUNS:
77+
continue
78+
print(failure_info)

0 commit comments

Comments
 (0)