From d61818989ecefd4cb58b95f8f6d71697075efc04 Mon Sep 17 00:00:00 2001 From: muXxer Date: Thu, 21 Mar 2024 17:40:59 +0100 Subject: [PATCH] Add json responses for health endpoints --- api/core.go | 6 ++++++ api/core_test.go | 18 ++++++++++++++++++ api/{routes.go => root.go} | 6 ++++++ api/{routes_test.go => root_test.go} | 20 ++++++++++++++++++-- nodeclient/http_api_client_test.go | 24 ++++++++++++------------ 5 files changed, 60 insertions(+), 14 deletions(-) rename api/{routes.go => root.go} (63%) rename api/{routes_test.go => root_test.go} (67%) diff --git a/api/core.go b/api/core.go index 088e9c7f7..364111c08 100644 --- a/api/core.go +++ b/api/core.go @@ -519,6 +519,12 @@ type ( Decimals uint32 `serix:""` } + // NetworkHealthResponse defines the network health response. + NetworkHealthResponse struct { + // Whether the network is healthy (finalization is not delayed). + IsNetworkHealthy bool `serix:""` + } + // NetworkMetricsResponse defines the network metrics response. NetworkMetricsResponse struct { // The current rate of new blocks per second, it's updated when a commitment is committed. diff --git a/api/core_test.go b/api/core_test.go index f0c92ba7f..d87e3cfdf 100644 --- a/api/core_test.go +++ b/api/core_test.go @@ -52,6 +52,15 @@ func Test_CoreAPIDeSerialize(t *testing.T) { SeriErr: nil, DeSeriErr: nil, }, + { + Name: "ok - NetworkHealthResponse", + Source: &api.NetworkHealthResponse{ + IsNetworkHealthy: true, + }, + Target: &api.NetworkHealthResponse{}, + SeriErr: nil, + DeSeriErr: nil, + }, { Name: "ok - NetworkMetricsResponse", Source: &api.NetworkMetricsResponse{ @@ -434,6 +443,15 @@ func Test_CoreAPIJSONSerialization(t *testing.T) { "subunit": "glow", "decimals": 6 } +}`, + }, + { + Name: "ok - NetworkHealthResponse", + Source: &api.NetworkHealthResponse{ + IsNetworkHealthy: true, + }, + Target: `{ + "isNetworkHealthy": true }`, }, { diff --git a/api/routes.go b/api/root.go similarity index 63% rename from api/routes.go rename to api/root.go index 363d5c046..dddaaf2ac 100644 --- a/api/routes.go +++ b/api/root.go @@ -5,6 +5,12 @@ import ( ) type ( + // HealthResponse defines the health response. + HealthResponse struct { + // Whether the node is healthy. + IsHealthy bool `serix:""` + } + // RoutesResponse defines the response of a GET routes REST API call. RoutesResponse struct { Routes []iotago.PrefixedStringUint8 `serix:",lenPrefix=uint8"` diff --git a/api/routes_test.go b/api/root_test.go similarity index 67% rename from api/routes_test.go rename to api/root_test.go index 2fae7e4f0..665d7c205 100644 --- a/api/routes_test.go +++ b/api/root_test.go @@ -8,8 +8,15 @@ import ( "github.com/iotaledger/iota.go/v4/tpkg/frameworks" ) -func Test_RoutesAPIDeSerialize(t *testing.T) { +func Test_RootAPIDeSerialize(t *testing.T) { tests := []*frameworks.DeSerializeTest{ + { + Name: "ok - HealthResponse", + Source: &api.HealthResponse{ + IsHealthy: true, + }, + Target: &api.HealthResponse{}, + }, { Name: "ok - RoutesResponse", Source: &api.RoutesResponse{ @@ -24,8 +31,17 @@ func Test_RoutesAPIDeSerialize(t *testing.T) { } } -func Test_RoutesAPIJSONSerialization(t *testing.T) { +func Test_RootAPIJSONSerialization(t *testing.T) { tests := []*frameworks.JSONEncodeTest{ + { + Name: "ok - HealthResponse", + Source: &api.HealthResponse{ + IsHealthy: true, + }, + Target: `{ + "isHealthy": true +}`, + }, { Name: "ok - RoutesResponse", Source: &api.RoutesResponse{ diff --git a/nodeclient/http_api_client_test.go b/nodeclient/http_api_client_test.go index 117381f90..927b249a7 100644 --- a/nodeclient/http_api_client_test.go +++ b/nodeclient/http_api_client_test.go @@ -146,18 +146,18 @@ func nodeClient(t *testing.T) *nodeclient.Client { func TestClient_Health(t *testing.T) { defer gock.Off() - gock.New(nodeAPIUrl). - Get(api.RouteHealth). - Reply(200) + mockGetJSON(api.RouteHealth, 200, &api.HealthResponse{ + IsHealthy: true, + }) nodeAPI := nodeClient(t) healthy, err := nodeAPI.Health(context.Background()) require.NoError(t, err) require.True(t, healthy) - gock.New(nodeAPIUrl). - Get(api.RouteHealth). - Reply(503) + mockGetJSON(api.RouteHealth, 503, &api.HealthResponse{ + IsHealthy: false, + }) healthy, err = nodeAPI.Health(context.Background()) require.NoError(t, err) @@ -167,18 +167,18 @@ func TestClient_Health(t *testing.T) { func TestClient_NetworkHealth(t *testing.T) { defer gock.Off() - gock.New(nodeAPIUrl). - Get(api.CoreRouteNetworkHealth). - Reply(200) + mockGetJSON(api.CoreRouteNetworkHealth, 200, &api.NetworkHealthResponse{ + IsNetworkHealthy: true, + }) nodeAPI := nodeClient(t) healthy, err := nodeAPI.NetworkHealth(context.Background()) require.NoError(t, err) require.True(t, healthy) - gock.New(nodeAPIUrl). - Get(api.CoreRouteNetworkHealth). - Reply(503) + mockGetJSON(api.CoreRouteNetworkHealth, 503, &api.NetworkHealthResponse{ + IsNetworkHealthy: false, + }) healthy, err = nodeAPI.NetworkHealth(context.Background()) require.NoError(t, err)