Skip to content

Commit

Permalink
adding context.Context to loghook to allow tracing id extraction for …
Browse files Browse the repository at this point in the history
…custom loghooks (#40)

Co-authored-by: mdreikorn <mdreikorn@twilio.com>
  • Loading branch information
dreikorn and dreikorn authored Mar 31, 2020
1 parent 68a33a0 commit e88d85b
Show file tree
Hide file tree
Showing 2 changed files with 74 additions and 16 deletions.
48 changes: 32 additions & 16 deletions pester.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ package pester

import (
"bytes"
"context"
"errors"
"fmt"
"io"
Expand Down Expand Up @@ -36,11 +37,12 @@ type Client struct {
Timeout time.Duration

// pester specific
Concurrency int
MaxRetries int
Backoff BackoffStrategy
KeepLog bool
LogHook LogHook
Concurrency int
MaxRetries int
Backoff BackoffStrategy
KeepLog bool
LogHook LogHook
ContextLogHook ContextLogHook

SuccessReqNum int
SuccessRetryNum int
Expand Down Expand Up @@ -115,6 +117,9 @@ func NewExtendedClient(hc *http.Client) *Client {
// however, if KeepLog is set to true.
type LogHook func(e ErrEntry)

// ContextLogHook does the same as LogHook but with passed Context
type ContextLogHook func(ctx context.Context, e ErrEntry)

// BackoffStrategy is used to determine how long a retry request should wait until attempted
type BackoffStrategy func(retry int) time.Duration

Expand Down Expand Up @@ -286,16 +291,23 @@ func (c *Client) pester(p params) (*http.Response, error) {
return
}

c.log(ErrEntry{
Time: time.Now(),
Method: p.method,
Verb: p.verb,
URL: p.url,
Request: n,
Retry: i + 1, // would remove, but would break backward compatibility
Attempt: i,
Err: err,
})
loggingContext := context.Background()
if p.req != nil {
loggingContext = p.req.Context()
}

c.log(
loggingContext,
ErrEntry{
Time: time.Now(),
Method: p.method,
Verb: p.verb,
URL: p.url,
Request: n,
Retry: i + 1, // would remove, but would break backward compatibility
Attempt: i,
Err: err,
})

// if it is the last iteration, grab the result (which is an error at this point)
if i == AttemptLimit {
Expand Down Expand Up @@ -387,11 +399,15 @@ func (c *Client) EmbedHTTPClient(hc *http.Client) {
c.hc = hc
}

func (c *Client) log(e ErrEntry) {
func (c *Client) log(ctx context.Context, e ErrEntry) {
if c.KeepLog {
c.Lock()
defer c.Unlock()
c.ErrLog = append(c.ErrLog, e)
} else if c.ContextLogHook != nil {
// NOTE: There is a possibility that Log Printing hook slows it down.
// but the consumer can always do the Job in a go-routine.
c.ContextLogHook(ctx, e)
} else if c.LogHook != nil {
// NOTE: There is a possibility that Log Printing hook slows it down.
// but the consumer can always do the Job in a go-routine.
Expand Down
42 changes: 42 additions & 0 deletions pester_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -412,6 +412,48 @@ func TestCustomLogHook(t *testing.T) {
}
}

func TestCustomContextLogHook(t *testing.T) {
t.Parallel()

expectedRetries := 5
errorLines := []ErrEntry{}
testContextKey := "testContextKey"
testContextValue := "testContextValue"
ctx := context.WithValue(context.Background(), testContextKey, testContextValue)

c := New()
c.MaxRetries = expectedRetries
c.Backoff = func(_ int) time.Duration {
return 10 * time.Microsecond
}

c.ContextLogHook = func(ctx context.Context, e ErrEntry) {
if testContextValue != ctx.Value(testContextKey) {
t.Fatalf("Value %s not found under key %s in context", testContextValue, testContextKey)
}
errorLines = append(errorLines, e)
}

nonExistantURL := "http://localhost:9000/foo"
httpRequest, err := http.NewRequest(http.MethodGet, nonExistantURL, nil)
httpRequest = httpRequest.WithContext(ctx)

if err != nil {
t.Fatal("unexpected error on request creation")
}

_, err = c.Do(httpRequest)
if err == nil {
t.Fatal("expected to get an error")
}
c.Wait()

// in the event of an error, let's see what the logs were
if expectedRetries != len(errorLines) {
t.Errorf("Expected %d lines to be emitted. Got %d", expectedRetries, len(errorLines))
}
}

func TestDefaultLogHook(t *testing.T) {
t.Parallel()

Expand Down

0 comments on commit e88d85b

Please sign in to comment.