ci: Add a server to track flakyness in pytest tests

This commit is contained in:
Christian Decker 2023-08-27 15:52:52 +02:00 committed by Rusty Russell
parent e66d642e3d
commit 4ff513da55
2 changed files with 75 additions and 0 deletions

View File

@ -15,6 +15,7 @@ env:
# of a bit of compile time.
RUST_PROFILE: release
SLOW_MACHINE: 1
CI_SERVER: "http://35.239.136.52:3170"
jobs:
prebuild:

74
conftest.py Normal file
View File

@ -0,0 +1,74 @@
import pytest
import subprocess
from urllib import request
import os
import json
from time import time
server = os.environ.get("CI_SERVER", None)
github_sha = subprocess.check_output([
"git",
"rev-parse",
"HEAD"
]).decode('ASCII').strip()
github_ref_name = subprocess.check_output([
"git",
"rev-parse",
"--abbrev-ref",
"HEAD"
]).decode('ASCII').strip()
run_id = os.environ.get("GITHUB_RUN_ID", None)
run_number = os.environ.get("GITHUB_RUN_NUMBER", None)
result = {
"github_repository": os.environ.get("GITHUB_REPOSITORY", None),
"github_sha": os.environ.get("GITHUB_SHA", github_sha),
"github_ref": os.environ.get("GITHUB_REF", None),
"github_ref_name": github_ref_name,
"github_run_id": int(run_id) if run_id else None,
"github_head_ref": os.environ.get("GITHUB_HEAD_REF", None),
"github_run_number": int(run_number) if run_number else None,
"github_base_ref": os.environ.get("GITHUB_BASE_REF", None),
"github_run_attempt": os.environ.get("GITHUB_RUN_ATTEMPT", None),
}
@pytest.hookimpl(hookwrapper=True)
def pytest_pyfunc_call(pyfuncitem):
global result
result = result.copy()
result['testname'] = pyfuncitem.name
result['start_time'] = int(time())
outcome = yield
result['end_time'] = int(time())
# outcome.excinfo may be None or a (cls, val, tb) tuple
if outcome.excinfo is None:
result['outcome'] = "success"
else:
result['outcome'] = "fail"
print(result)
if not server:
return
try:
req = request.Request(
f"{server}/hook/test",
method="POST"
)
req.add_header("Content-Type", "application/json")
request.urlopen(
req,
data=json.dumps(result).encode('ASCII'),
)
except ConnectionError as e:
print(f"Could not report testrun: {e}")
except Exception as e:
import warnings
warnings.warn(f"Error reporting testrun: {e}: {e.read()}")