From 6e2a248ee9371e13b5a47ec699f0271d3e88d1fc Mon Sep 17 00:00:00 2001 From: Gerrit Date: Tue, 1 Aug 2023 14:21:02 +0200 Subject: [PATCH] Switch status fix no 2 (#458) --- cmd/metal-api/internal/datastore/switch.go | 2 +- .../internal/service/image-service_test.go | 2 +- .../internal/service/switch-service.go | 21 +++++++++++-------- 3 files changed, 14 insertions(+), 11 deletions(-) diff --git a/cmd/metal-api/internal/datastore/switch.go b/cmd/metal-api/internal/datastore/switch.go index 24cabac2e..d5982c19c 100644 --- a/cmd/metal-api/internal/datastore/switch.go +++ b/cmd/metal-api/internal/datastore/switch.go @@ -201,7 +201,7 @@ func (rs *RethinkStore) ConnectMachineWithSwitches(m *metal.Machine) error { func (rs *RethinkStore) GetSwitchStatus(id string) (*metal.SwitchStatus, error) { var ss metal.SwitchStatus err := rs.findEntityByID(rs.switchStatusTable(), &ss, id) - if err != nil && !metal.IsNotFound(err) { + if err != nil { return nil, err } return &ss, nil diff --git a/cmd/metal-api/internal/service/image-service_test.go b/cmd/metal-api/internal/service/image-service_test.go index 478fc9a13..48093927a 100644 --- a/cmd/metal-api/internal/service/image-service_test.go +++ b/cmd/metal-api/internal/service/image-service_test.go @@ -183,7 +183,7 @@ func TestCreateImageWithBrokenURL(t *testing.T) { var result httperrors.HTTPErrorResponse err = json.NewDecoder(resp.Body).Decode(&result) require.NoError(t, err) - require.True(t, strings.Contains(result.Message, "no such host")) + require.True(t, strings.Contains(result.Message, "is not accessible under")) createRequest.URL = "http://images.metal-stack.io/this-file-does-not-exist" diff --git a/cmd/metal-api/internal/service/switch-service.go b/cmd/metal-api/internal/service/switch-service.go index 0f1d4cd2c..d0a392bfb 100644 --- a/cmd/metal-api/internal/service/switch-service.go +++ b/cmd/metal-api/internal/service/switch-service.go @@ -223,25 +223,28 @@ func (r *switchResource) notifySwitch(request *restful.Request, response *restfu } } - sync := &metal.SwitchSync{ - Time: time.Now(), - Duration: requestPayload.Duration, - } + newSS := *ss if requestPayload.Error == nil { - ss.LastSync = sync + newSS.LastSync = &metal.SwitchSync{ + Time: time.Now(), + Duration: requestPayload.Duration, + } } else { - ss.LastSyncError = sync - ss.LastSyncError.Error = requestPayload.Error + newSS.LastSyncError = &metal.SwitchSync{ + Time: time.Now(), + Duration: requestPayload.Duration, + Error: requestPayload.Error, + } } - err = r.ds.SetSwitchStatus(ss) + err = r.ds.SetSwitchStatus(&newSS) if err != nil { r.sendError(request, response, defaultError(err)) return } - r.send(request, response, http.StatusOK, v1.NewSwitchNotifyResponse(ss)) + r.send(request, response, http.StatusOK, v1.NewSwitchNotifyResponse(&newSS)) } func (r *switchResource) updateSwitch(request *restful.Request, response *restful.Response) {