From 62d963e3cce34d4249544c83310278ad9b8c5b6d Mon Sep 17 00:00:00 2001 From: muXxer Date: Thu, 25 Apr 2024 11:46:18 +0200 Subject: [PATCH] Remove target slot from `CreateSnapshot` endpoint --- api/management.go | 6 ------ api/management_test.go | 16 ---------------- nodeclient/http_api_client_test.go | 12 +++++++----- nodeclient/management_client.go | 10 +++------- nodeclient/management_client_test.go | 8 ++------ 5 files changed, 12 insertions(+), 40 deletions(-) diff --git a/api/management.go b/api/management.go index 6a0258d5..29e8037d 100644 --- a/api/management.go +++ b/api/management.go @@ -57,12 +57,6 @@ type ( Epoch iotago.EpochIndex `serix:""` } - // CreateSnapshotRequest defines the request of a create snapshot REST API call. - CreateSnapshotRequest struct { - // The slot of the snapshot. - Slot iotago.SlotIndex `serix:""` - } - // CreateSnapshotResponse defines the response of a create snapshot REST API call. CreateSnapshotResponse struct { // The slot of the snapshot. diff --git a/api/management_test.go b/api/management_test.go index c2927290..29083a1a 100644 --- a/api/management_test.go +++ b/api/management_test.go @@ -68,13 +68,6 @@ func Test_ManagementAPIDeSerialize(t *testing.T) { }, Target: &api.PruneDatabaseResponse{}, }, - { - Name: "ok - CreateSnapshotRequest", - Source: &api.CreateSnapshotRequest{ - Slot: 1, - }, - Target: &api.CreateSnapshotRequest{}, - }, { Name: "ok - CreateSnapshotResponse", Source: &api.CreateSnapshotResponse{ @@ -185,15 +178,6 @@ func Test_ManagementAPIJSONSerialization(t *testing.T) { }, Target: `{ "epoch": 1 -}`, - }, - { - Name: "ok - CreateSnapshotRequest", - Source: &api.CreateSnapshotRequest{ - Slot: 1, - }, - Target: `{ - "slot": 1 }`, }, { diff --git a/nodeclient/http_api_client_test.go b/nodeclient/http_api_client_test.go index ad5cc658..58a76862 100644 --- a/nodeclient/http_api_client_test.go +++ b/nodeclient/http_api_client_test.go @@ -76,11 +76,13 @@ func mockGetJSONWithParams(route string, status int, body interface{}, params ma //nolint:unparam // false positive func mockPostJSON(route string, status int, req interface{}, resp interface{}) { - gock.New(nodeAPIUrl). - Post(route). - MatchHeader("Content-Type", api.MIMEApplicationJSON). - BodyString(string(lo.PanicOnErr(mockAPI.JSONEncode(req)))). - Reply(status). + mock := gock.New(nodeAPIUrl).Post(route) + if req != nil { + mock.MatchHeader("Content-Type", api.MIMEApplicationJSON). + BodyString(string(lo.PanicOnErr(mockAPI.JSONEncode(req)))) + } + + mock.Reply(status). SetHeader("Content-Type", api.MIMEApplicationJSON). BodyString(string(lo.PanicOnErr(mockAPI.JSONEncode(resp)))) } diff --git a/nodeclient/management_client.go b/nodeclient/management_client.go index f640eef4..e473bb5e 100644 --- a/nodeclient/management_client.go +++ b/nodeclient/management_client.go @@ -26,7 +26,7 @@ type ( // PruneDatabaseByDepth prunes the database by depth. PruneDatabaseByDepth(ctx context.Context, depth iotago.EpochIndex) (*api.PruneDatabaseResponse, error) // CreateSnapshot creates a snapshot. - CreateSnapshot(ctx context.Context, slot iotago.SlotIndex) (*api.CreateSnapshotResponse, error) + CreateSnapshot(ctx context.Context) (*api.CreateSnapshotResponse, error) } managementClient struct { @@ -147,14 +147,10 @@ func (client *managementClient) PruneDatabaseByDepth(ctx context.Context, depth } // CreateSnapshot creates a snapshot. -func (client *managementClient) CreateSnapshot(ctx context.Context, slot iotago.SlotIndex) (*api.CreateSnapshotResponse, error) { - req := &api.CreateSnapshotRequest{ - Slot: slot, - } - +func (client *managementClient) CreateSnapshot(ctx context.Context) (*api.CreateSnapshotResponse, error) { res := new(api.CreateSnapshotResponse) //nolint:bodyclose - if _, err := client.DoWithRequestHeaderHook(ctx, http.MethodPost, api.ManagementRouteSnapshotsCreate, RequestHeaderHookAcceptJSON, req, res); err != nil { + if _, err := client.DoWithRequestHeaderHook(ctx, http.MethodPost, api.ManagementRouteSnapshotsCreate, RequestHeaderHookAcceptJSON, nil, res); err != nil { return nil, err } diff --git a/nodeclient/management_client_test.go b/nodeclient/management_client_test.go index 37c0d450..abb27b7b 100644 --- a/nodeclient/management_client_test.go +++ b/nodeclient/management_client_test.go @@ -267,28 +267,24 @@ func TestManagementClient_PruneDatabaseByDepth(t *testing.T) { func TestManagementClient_CreateSnapshot(t *testing.T) { defer gock.Off() - slot := iotago.SlotIndex(1) - originRes := &api.CreateSnapshotResponse{ Slot: 1, FilePath: "filePath", } - req := &api.CreateSnapshotRequest{Slot: slot} - originRoutes := &api.RoutesResponse{ Routes: []iotago.PrefixedStringUint8{api.ManagementPluginName}, } mockGetJSON(api.RouteRoutes, 200, originRoutes) - mockPostJSON(api.ManagementRouteSnapshotsCreate, 200, req, originRes) + mockPostJSON(api.ManagementRouteSnapshotsCreate, 200, nil, originRes) client := nodeClient(t) management, err := client.Management(context.TODO()) require.NoError(t, err) - resp, err := management.CreateSnapshot(context.Background(), slot) + resp, err := management.CreateSnapshot(context.Background()) require.NoError(t, err) require.EqualValues(t, originRes, resp) }