mirror of
https://github.com/vale981/ray
synced 2025-03-10 13:26:39 -04:00
48 lines
1.7 KiB
Python
48 lines
1.7 KiB
Python
![]() |
import datetime
|
||
|
import json
|
||
|
import boto3
|
||
|
from botocore.config import Config
|
||
|
|
||
|
from ray_release.reporter.reporter import Reporter
|
||
|
from ray_release.result import Result
|
||
|
from ray_release.config import Test
|
||
|
from ray_release.logger import logger
|
||
|
|
||
|
|
||
|
class DBReporter(Reporter):
|
||
|
def __init__(self):
|
||
|
self.firehose = boto3.client("firehose", config=Config(region_name="us-west-2"))
|
||
|
|
||
|
def report_result(self, test: Test, result: Result):
|
||
|
logger.info("Persisting result to the databricks delta lake...")
|
||
|
|
||
|
now = datetime.datetime.utcnow()
|
||
|
result_json = {
|
||
|
"_table": "release_test_result",
|
||
|
"report_time": now.strftime("%Y-%m-%d %H:%M:%S"),
|
||
|
"status": result.status or "",
|
||
|
"results": result.results or {},
|
||
|
"name": test.get("name", ""),
|
||
|
"group": test.get("group", ""),
|
||
|
"team": test.get("team", ""),
|
||
|
"frequency": test.get("frequency", ""),
|
||
|
"cluster_url": result.cluster_url or "",
|
||
|
"wheel_url": result.wheels_url or "",
|
||
|
"buildkite_url": result.buildkite_url or "",
|
||
|
"runtime": result.runtime or -1.0,
|
||
|
"stable": result.stable,
|
||
|
"return_code": result.return_code,
|
||
|
}
|
||
|
|
||
|
logger.debug(f"Result json: {json.dumps(result_json)}")
|
||
|
|
||
|
try:
|
||
|
self.firehose.put_record(
|
||
|
DeliveryStreamName="ray-ci-results",
|
||
|
Record={"Data": json.dumps(result_json)},
|
||
|
)
|
||
|
except Exception:
|
||
|
logger.exception("Failed to persist result to the databricks delta lake")
|
||
|
else:
|
||
|
logger.info("Result has been persisted to the databricks delta lake")
|