Skip to content

Commit

Permalink
Run tests in parallel. (#98)
Browse files Browse the repository at this point in the history
In #93 @storozhukBM adds test parallization, which is unrelated
to the actual change. I'd rather have this as a separate PR.

The test currently take ~12 seconds on my laptop, so I see why we might
want to run them in parallel. There are other parallelization
opportunities (we could paralelize each of the subtests for each
of the rate-limiters), but this is a good start.

Before:
```
> go test ./... -race -count 1
ok      go.uber.org/ratelimit   12.739s
```

After:
```
> go test ./... -race -count 1
ok      go.uber.org/ratelimit   6.178s
```
  • Loading branch information
rabbbit authored Jul 10, 2022
1 parent 29ac3a2 commit af246a4
Showing 1 changed file with 5 additions and 0 deletions.
5 changes: 5 additions & 0 deletions ratelimit_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,7 @@ func (r *runnerImpl) goWait(fn func()) {
}

func TestUnlimited(t *testing.T) {
t.Parallel()
now := time.Now()
rl := NewUnlimited()
for i := 0; i < 1000; i++ {
Expand All @@ -152,6 +153,7 @@ func TestUnlimited(t *testing.T) {
}

func TestRateLimiter(t *testing.T) {
t.Parallel()
runTest(t, func(r testRunner) {
rl := r.createLimiter(100, WithoutSlack)

Expand All @@ -168,6 +170,7 @@ func TestRateLimiter(t *testing.T) {
}

func TestDelayedRateLimiter(t *testing.T) {
t.Parallel()
runTest(t, func(r testRunner) {
slow := r.createLimiter(10, WithoutSlack)
fast := r.createLimiter(100, WithoutSlack)
Expand All @@ -186,6 +189,7 @@ func TestDelayedRateLimiter(t *testing.T) {
}

func TestPer(t *testing.T) {
t.Parallel()
runTest(t, func(r testRunner) {
rl := r.createLimiter(7, WithoutSlack, Per(time.Minute))

Expand All @@ -199,6 +203,7 @@ func TestPer(t *testing.T) {
}

func TestSlack(t *testing.T) {
t.Parallel()
// To simulate slack, we combine two limiters.
// - First, we start a single goroutine with both of them,
// during this time the slow limiter will dominate,
Expand Down

0 comments on commit af246a4

Please sign in to comment.