Skip to content

Commit

Permalink
Reset unit failed status before restarting
Browse files Browse the repository at this point in the history
Signed-off-by: Daniel Weiße <[email protected]>
  • Loading branch information
daniel-weisse committed Jun 20, 2024
1 parent 0368047 commit 9385e63
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 0 deletions.
5 changes: 5 additions & 0 deletions debugd/internal/debugd/deploy/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,8 @@ type dbusConn interface {
// StopUnitContext is similar to StartUnitContext, but stops the specified unit
// rather than starting it.
StopUnitContext(ctx context.Context, name string, mode string, ch chan<- string) (int, error)
// ResetFailedUnitContext resets the "failed" state of a unit.
ResetFailedUnitContext(ctx context.Context, name string) error
// RestartUnitContext restarts a service. If a service is restarted that isn't
// running it will be started.
RestartUnitContext(ctx context.Context, name string, mode string, ch chan<- string) (int, error)
Expand Down Expand Up @@ -122,6 +124,9 @@ func (s *ServiceManager) SystemdAction(ctx context.Context, request ServiceManag
case Stop:
_, err = conn.StopUnitContext(ctx, request.Unit, "replace", resultChan)
case Restart:
if err = conn.ResetFailedUnitContext(ctx, request.Unit); err != nil {
s.log.Error("Failed to reset unit failed state", "error", err.Error(), "unit", request.Unit)
}
_, err = conn.RestartUnitContext(ctx, request.Unit, "replace", resultChan)
case Reload:
err = conn.ReloadContext(ctx)
Expand Down
4 changes: 4 additions & 0 deletions debugd/internal/debugd/deploy/service_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -356,6 +356,10 @@ func (c *fakeDbusConn) StopUnitContext(_ context.Context, name string, mode stri
return c.jobID, c.actionErr
}

func (c *fakeDbusConn) ResetFailedUnitContext(_ context.Context, _ string) error {
return nil
}

func (c *fakeDbusConn) RestartUnitContext(_ context.Context, name string, mode string, ch chan<- string) (int, error) {
c.inputs = append(c.inputs, dbusConnActionInput{name: name, mode: mode})
ch <- c.result
Expand Down
4 changes: 4 additions & 0 deletions debugd/internal/debugd/deploy/wrappers.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,10 @@ func (c *dbusConnWrapper) StopUnitContext(ctx context.Context, name string, mode
return c.conn.StopUnitContext(ctx, name, mode, ch)
}

func (c *dbusConnWrapper) ResetFailedUnitContext(ctx context.Context, name string) error {
return c.conn.ResetFailedUnitContext(ctx, name)
}

func (c *dbusConnWrapper) RestartUnitContext(ctx context.Context, name string, mode string, ch chan<- string) (int, error) {
return c.conn.RestartUnitContext(ctx, name, mode, ch)
}
Expand Down

0 comments on commit 9385e63

Please sign in to comment.