Skip to content

Commit

Permalink
documenting test for #10301
Browse files Browse the repository at this point in the history
enable -race detector for testing api
  • Loading branch information
cgbaker committed Apr 6, 2021
1 parent b206efe commit 4e25e8e
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 1 deletion.
5 changes: 5 additions & 0 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -293,11 +293,15 @@ jobs:
goarch:
type: string
default: "amd64"
enable_race_testing:
type: string
default: ""
environment:
GOTEST_PKGS_EXCLUDE: "<< parameters.exclude_packages >>"
GOTEST_PKGS: "<< parameters.test_packages >>"
GOTEST_MOD: "<< parameters.test_module >>"
GOTESTARCH: "<< parameters.goarch >>"
ENABLE_RACE: "<< parameters.enable_race_testing >>"
steps:
- checkout
- install-golang
Expand Down Expand Up @@ -616,6 +620,7 @@ workflows:
name: "test-api"
test_module: "api"
filters: *backend_test_branches_filter
enable_race_testing: "1"
- test-container:
name: "test-devices"
test_packages: "./devices/..."
Expand Down
28 changes: 27 additions & 1 deletion api/api_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,10 @@ import (
"testing"
"time"

"github.com/hashicorp/nomad/api/internal/testutil"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"

"github.com/hashicorp/nomad/api/internal/testutil"
)

type configCallback func(c *Config)
Expand Down Expand Up @@ -538,3 +539,28 @@ func TestCloneHttpClient(t *testing.T) {
})

}

func TestClient_HeaderRaceCondition(t *testing.T) {
require := require.New(t)

conf := DefaultConfig()
conf.Headers = map[string][]string{
"test-header": {"a"},
}
client, err := NewClient(conf)
require.NoError(err)

c := make(chan int)

go func() {
req, _ := client.newRequest("GET", "/any/path/will/do")
r, _ := req.toHTTP()
c <- len(r.Header)
}()
req, _ := client.newRequest("GET", "/any/path/will/do")
r, _ := req.toHTTP()

require.Len(r.Header, 2, "local request should have two headers")
require.Equal(2, <-c, "goroutine request should have two headers")
require.Len(conf.Headers, 1, "config headers should not mutate")
}

0 comments on commit 4e25e8e

Please sign in to comment.