feat: report testcase as a whole Action transaction, inspired by LoadRunner

This commit is contained in:
debugtalk
2021-12-20 18:38:36 +08:00
parent 310b89b84b
commit 1958883a24
2 changed files with 12 additions and 7 deletions

View File

@@ -62,6 +62,7 @@ func (b *hrpBoomer) convertBoomerTask(testcase *TestCase) *boomer.Task {
Weight: config.Weight,
Fn: func() {
runner := NewRunner(nil).SetDebug(b.debug).Reset()
startTime := time.Now()
for _, step := range testcase.TestSteps {
stepData, err := runner.runStep(step, testcase.Config)
@@ -72,9 +73,8 @@ func (b *hrpBoomer) convertBoomerTask(testcase *TestCase) *boomer.Task {
// record transaction
if stepData.stepType == stepTypeTransaction {
// TODO: implement recording transaction in boomer
if stepData.elapsed != 0 {
b.RecordSuccess(string(stepTypeTransaction), stepData.name, stepData.elapsed, 0)
if stepData.elapsed != 0 { // only record when transaction ends
b.RecordTransaction(stepData.name, stepData.elapsed, 0)
}
continue
}
@@ -96,9 +96,12 @@ func (b *hrpBoomer) convertBoomerTask(testcase *TestCase) *boomer.Task {
if len(transaction) == 1 {
// if transaction end time not exists, use testcase end time instead
duration := endTime.Sub(transaction[TransactionStart])
b.RecordSuccess(string(stepTypeTransaction), name, duration.Milliseconds(), 0)
b.RecordTransaction(name, duration.Milliseconds(), 0)
}
}
// report testcase as a whole Action transaction, inspired by LoadRunner
b.RecordTransaction("Action", endTime.Sub(startTime).Milliseconds(), 0)
},
}
}

View File

@@ -206,9 +206,11 @@ func (r *hrpRunner) runStepTransaction(transaction *Transaction) (stepResult *st
Msg("transaction")
stepResult = &stepData{
name: transaction.Name,
stepType: stepTypeTransaction,
success: true,
name: transaction.Name,
stepType: stepTypeTransaction,
success: true,
elapsed: 0,
responseLength: 0, // TODO: record transaction total response length
}
// create transaction if not exists