From 3d1b8c4fac9bf2252213a20eceb8c95104f22dd2 Mon Sep 17 00:00:00 2001 From: shuiyisong <113876041+shuiyisong@users.noreply.github.com> Date: Wed, 11 Dec 2024 10:56:48 +0800 Subject: [PATCH] chore: add `/ready` api for health checking (#5124) * chore: add ready endpoint for health checking * chore: add test --- src/servers/src/http.rs | 13 +++++++++---- tests-integration/tests/http.rs | 33 +++++++++++++++++++-------------- 2 files changed, 28 insertions(+), 18 deletions(-) diff --git a/src/servers/src/http.rs b/src/servers/src/http.rs index c719e02cac35..d8d07ed31fa0 100644 --- a/src/servers/src/http.rs +++ b/src/servers/src/http.rs @@ -638,10 +638,15 @@ impl HttpServer { router.clone() }; - router = router.route( - "/health", - routing::get(handler::health).post(handler::health), - ); + router = router + .route( + "/health", + routing::get(handler::health).post(handler::health), + ) + .route( + "/ready", + routing::get(handler::health).post(handler::health), + ); router = router.route("/status", routing::get(handler::status)); diff --git a/tests-integration/tests/http.rs b/tests-integration/tests/http.rs index 083a9daa1a26..9d7b81f3919b 100644 --- a/tests-integration/tests/http.rs +++ b/tests-integration/tests/http.rs @@ -757,21 +757,26 @@ pub async fn test_health_api(store_type: StorageType) { let (app, _guard) = setup_test_http_app_with_frontend(store_type, "health_api").await; let client = TestClient::new(app); - // we can call health api with both `GET` and `POST` method. - let res_post = client.post("/health").send().await; - assert_eq!(res_post.status(), StatusCode::OK); - let res_get = client.get("/health").send().await; - assert_eq!(res_get.status(), StatusCode::OK); - - // both `GET` and `POST` method return same result - let body_text = res_post.text().await; - assert_eq!(body_text, res_get.text().await); - - // currently health api simply returns an empty json `{}`, which can be deserialized to an empty `HealthResponse` - assert_eq!(body_text, "{}"); + async fn health_api(client: &TestClient, endpoint: &str) { + // we can call health api with both `GET` and `POST` method. + let res_post = client.post(endpoint).send().await; + assert_eq!(res_post.status(), StatusCode::OK); + let res_get = client.get(endpoint).send().await; + assert_eq!(res_get.status(), StatusCode::OK); + + // both `GET` and `POST` method return same result + let body_text = res_post.text().await; + assert_eq!(body_text, res_get.text().await); + + // currently health api simply returns an empty json `{}`, which can be deserialized to an empty `HealthResponse` + assert_eq!(body_text, "{}"); + + let body = serde_json::from_str::(&body_text).unwrap(); + assert_eq!(body, HealthResponse {}); + } - let body = serde_json::from_str::(&body_text).unwrap(); - assert_eq!(body, HealthResponse {}); + health_api(&client, "/health").await; + health_api(&client, "/ready").await; } pub async fn test_status_api(store_type: StorageType) {