Skip to content

Commit

Permalink
Switch status fix no 2 (#458)
Browse files Browse the repository at this point in the history
  • Loading branch information
Gerrit91 authored Aug 1, 2023
1 parent 5c657fc commit 6e2a248
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 11 deletions.
2 changes: 1 addition & 1 deletion cmd/metal-api/internal/datastore/switch.go
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
2 changes: 1 addition & 1 deletion cmd/metal-api/internal/service/image-service_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -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"

Expand Down
21 changes: 12 additions & 9 deletions cmd/metal-api/internal/service/switch-service.go
Original file line number Diff line number Diff line change
Expand Up @@ -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) {
Expand Down

0 comments on commit 6e2a248

Please sign in to comment.