ray/release/ray_release/tests/test_alerts.py
Kai Fricke 331b71ea8d
[ci/release] Refactor release test e2e into package (#22351)
Adds a unit-tested and restructured ray_release package for running release tests.

Relevant changes in behavior:

Per default, Buildkite will wait for the wheels of the current commit to be available. Alternatively, users can a) specify a different commit hash, b) a wheels URL (which we will also wait for to be available) or c) specify a branch (or user/branch combination), in which case the latest available wheels will be used (e.g. if master is passed, behavior matches old default behavior).

The main subpackages are:

    Cluster manager: Creates cluster envs/computes, starts cluster, terminates cluster
    Command runner: Runs commands, e.g. as client command or sdk command
    File manager: Uploads/downloads files to/from session
    Reporter: Reports results (e.g. to database)

Much of the code base is unit tested, but there are probably some pieces missing.

Example build (waited for wheels to be built): https://buildkite.com/ray-project/kf-dev/builds/51#_
Wheel build: https://buildkite.com/ray-project/ray-builders-branch/builds/6023
2022-02-16 17:35:02 +00:00

41 lines
1.2 KiB
Python

import unittest
from ray_release.alerts import (
handle,
default,
# long_running_tests,
# rllib_tests,
# tune_tests,
# xgboost_tests,
)
from ray_release.config import Test
from ray_release.exception import ReleaseTestConfigError, ResultsAlert
from ray_release.result import Result
class AlertsTest(unittest.TestCase):
def setUp(self) -> None:
self.test = Test(name="unit_alert_test", alert="default")
def testHandleAlert(self):
# Unknown test suite
with self.assertRaises(ReleaseTestConfigError):
handle.handle_result(
Test(name="unit_alert_test", alert="invalid"), Result(status="finished")
)
# Alert raised
with self.assertRaises(ResultsAlert):
handle.handle_result(
Test(name="unit_alert_test", alert="default"),
Result(status="unsuccessful"),
)
# Everything fine
handle.handle_result(
Test(name="unit_alert_test", alert="default"), Result(status="finished")
)
def testDefaultAlert(self):
self.assertTrue(default.handle_result(self.test, Result(status="timeout")))
self.assertFalse(default.handle_result(self.test, Result(status="finished")))