Merge pull request #1207 from httprunner/modify-loop-count

change: load testing total running count = worker spawn number * loop count
This commit is contained in:
debugtalk
2022-03-24 23:43:57 +08:00
committed by GitHub
3 changed files with 16 additions and 8 deletions

View File

@@ -78,7 +78,8 @@ func (b *Boomer) GetDisableCompression() bool {
// SetLoopCount set loop count for test.
func (b *Boomer) SetLoopCount(loopCount int64) {
b.localRunner.loop = &Loop{loopCount: loopCount}
// total loop count for testcase, it will be evenly distributed to each worker
b.localRunner.loop = &Loop{loopCount: loopCount * int64(b.localRunner.spawnCount)}
}
// AddOutput accepts outputs which implements the boomer.Output interface.

View File

@@ -65,7 +65,7 @@ type runner struct {
currentClientsNum int32 // current clients count
spawnCount int // target clients to spawn
spawnRate float64
loop *Loop // specify running cycles
loop *Loop // specify loop count for testcase, count = loopCount * spawnCount
spawnDone chan struct{}
outputs []Output
@@ -189,6 +189,12 @@ func (r *localRunner) spawnWorkers(spawnCount int, spawnRate float64, quit chan
sleepTime := time.Duration(1000000/r.spawnRate) * time.Microsecond
time.Sleep(sleepTime)
// loop count per worker
var workerLoop *Loop
if r.loop != nil {
workerLoop = &Loop{loopCount: atomic.LoadInt64(&r.loop.loopCount) / int64(r.spawnCount)}
}
select {
case <-quit:
// quit spawning goroutine
@@ -202,7 +208,7 @@ func (r *localRunner) spawnWorkers(spawnCount int, spawnRate float64, quit chan
case <-quit:
return
default:
if r.loop != nil && !r.loop.acquire() {
if workerLoop != nil && !workerLoop.acquire() {
return
}
if r.rateLimitEnabled {
@@ -215,8 +221,11 @@ func (r *localRunner) spawnWorkers(spawnCount int, spawnRate float64, quit chan
task := r.getTask()
r.safeRun(task.Fn)
}
if r.loop != nil {
if workerLoop != nil {
// finished count of total
r.loop.increaseFinishedCount()
// finished count of single worker
workerLoop.increaseFinishedCount()
if r.loop.isFinished() {
r.stop()
}

View File

@@ -98,7 +98,7 @@ func TestLoopCount(t *testing.T) {
taskA := &Task{
Weight: 10,
Fn: func() {
time.Sleep(time.Second)
time.Sleep(time.Millisecond)
},
Name: "TaskA",
}
@@ -107,9 +107,7 @@ func TestLoopCount(t *testing.T) {
runner.loop = &Loop{loopCount: 4}
runner.setTasks(tasks)
go runner.start()
ticker := time.NewTicker(4 * time.Second)
defer ticker.Stop()
<-ticker.C
<-runner.stopChan
if !assert.Equal(t, runner.loop.loopCount, atomic.LoadInt64(&runner.loop.finishedCount)) {
t.Fail()
}