mirror of
https://github.com/vale981/ray
synced 2025-03-06 02:21:39 -05:00
47 lines
1.7 KiB
Python
47 lines
1.7 KiB
Python
import time
|
|
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...")
|
|
|
|
result_json = {
|
|
"_table": "release_test_result",
|
|
"report_timestamp_ms": int(time.time() * 1000),
|
|
"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,
|
|
"smoke_test": result.smoke_test,
|
|
}
|
|
|
|
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")
|