Skip to content

Commit

Permalink
Merge pull request #27 from yaronius/master
Browse files Browse the repository at this point in the history
Fix error logging on canceled context
  • Loading branch information
K-Phoen authored Apr 29, 2021
2 parents 0cfc4ac + e987bc3 commit bc3e45a
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 2 deletions.
9 changes: 7 additions & 2 deletions svc.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
package svc

import (
"context"
"errors"
"fmt"
"log"
"net/http"
Expand Down Expand Up @@ -137,7 +139,7 @@ func (s *SVC) Run() {
go func(name string, w Worker) {
defer s.recoverWait(name, &wg, errs)
if err := w.Run(); err != nil {
s.logger.Error("Run exited with error", zap.Error(err), zap.String("worker", name))
err = fmt.Errorf("worker %s exited: %w", name, err)
errs <- err
}
}(name, w)
Expand All @@ -147,7 +149,10 @@ func (s *SVC) Run() {

select {
case err := <-errs:
s.logger.Fatal("Worker Init/Run failure", zap.Error(err))
if !errors.Is(err, context.Canceled) {
s.logger.Fatal("Worker Init/Run failure", zap.Error(err))
}
s.logger.Warn("Worker context canceled", zap.Error(err))
case sig := <-s.signals:
s.logger.Warn("Caught signal", zap.String("signal", sig.String()))
case <-waitGroupToChan(&wg):
Expand Down
19 changes: 19 additions & 0 deletions svc_test.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
package svc

import (
"context"
"fmt"
"testing"
"time"

Expand Down Expand Up @@ -87,6 +89,23 @@ func TestShutdown(t *testing.T) {
}
}

func TestContextCanceled(t *testing.T) {
dummyWorker := &WorkerMock{
InitFunc: func(*zap.Logger) error { return nil },
RunFunc: func() error {
return fmt.Errorf("stopped: %w", context.Canceled)
},
TerminateFunc: func() error { return nil },
}

s, err := New("dummy-service", "v0.0.1")
require.NoError(t, err)
s.AddWorker("dummy-worker", dummyWorker)

// Run should not log fatal
s.Run()
}

var _ Worker = (*WorkerMock)(nil)

type WorkerMock struct {
Expand Down

0 comments on commit bc3e45a

Please sign in to comment.