Skip to content

Commit

Permalink
debug_traceBlockByNumber pattern test (#8655)
Browse files Browse the repository at this point in the history
added debug_traceBlockByNumber API pattern test
  • Loading branch information
Sixtysixter authored Nov 7, 2023
1 parent 509a7af commit d127126
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 1 deletion.
14 changes: 14 additions & 0 deletions cmd/rpctest/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -290,6 +290,19 @@ func main() {
}
with(benchTraceFilterCmd, withGethUrl, withErigonUrl, withNeedCompare, withBlockNum, withRecord, withErrorFile)

var benchDebugTraceBlockByNumberCmd = &cobra.Command{
Use: "benchDebugTraceBlockByNumber",
Short: "",
Long: ``,
Run: func(cmd *cobra.Command, args []string) {
err := rpctest.BenchDebugTraceBlockByNumber(erigonURL, gethURL, needCompare, blockFrom, blockTo, recordFile, errorFile)
if err != nil {
logger.Error(err.Error())
}
},
}
with(benchDebugTraceBlockByNumberCmd, withErigonUrl, withGethUrl, withNeedCompare, withBlockNum, withRecord, withErrorFile, withLatest)

var benchTxReceiptCmd = &cobra.Command{
Use: "benchTxReceipt",
Short: "",
Expand Down Expand Up @@ -384,6 +397,7 @@ func main() {
benchTraceCallManyCmd,
benchTraceBlockCmd,
benchTraceFilterCmd,
benchDebugTraceBlockByNumberCmd,
benchTxReceiptCmd,
compareAccountRange,
benchTraceReplayTransactionCmd,
Expand Down
58 changes: 58 additions & 0 deletions cmd/rpctest/rpctest/bench_debugTraceBlockByNumber.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
package rpctest

import (
"bufio"
"fmt"
"net/http"
"os"
"time"
)

func BenchDebugTraceBlockByNumber(erigonUrl, gethUrl string, needCompare bool, blockFrom uint64, blockTo uint64, recordFileName string, errorFileName string) error {
setRoutes(erigonUrl, gethUrl)
var client = &http.Client{
Timeout: time.Second * 600,
}

var rec *bufio.Writer
if recordFileName != "" {
f, err := os.Create(recordFileName)
if err != nil {
return fmt.Errorf("Cannot create file %s for recording: %v\n", recordFileName, err)
}
defer f.Close()
rec = bufio.NewWriter(f)
defer rec.Flush()
}
var errs *bufio.Writer
if errorFileName != "" {
ferr, err := os.Create(errorFileName)
if err != nil {
return fmt.Errorf("Cannot create file %s for error output: %v\n", errorFileName, err)
}
defer ferr.Close()
errs = bufio.NewWriter(ferr)
defer errs.Flush()
}

var resultsCh chan CallResult = nil
if !needCompare {
resultsCh = make(chan CallResult, 1000)
defer close(resultsCh)
go vegetaWrite(true, []string{"debug_traceBlockByNumber"}, resultsCh)
}

reqGen := &RequestGenerator{
client: client,
}

for bn := blockFrom; bn < blockTo; bn++ {
reqGen.reqID++
request := reqGen.debugTraceBlockByNumber(bn)
errCtx := fmt.Sprintf("block %d", bn)
if err := requestAndCompare(request, "debug_traceBlockByNumber", errCtx, reqGen, needCompare, rec, errs, resultsCh); err != nil {
return err
}
}
return nil
}
8 changes: 7 additions & 1 deletion cmd/rpctest/rpctest/request_generator.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,12 @@ package rpctest
import (
"encoding/base64"
"fmt"
"github.com/ledgerwatch/erigon-lib/common/hexutil"
"net/http"
"strings"
"time"

"github.com/ledgerwatch/erigon-lib/common/hexutil"

"github.com/valyala/fastjson"

libcommon "github.com/ledgerwatch/erigon-lib/common"
Expand Down Expand Up @@ -58,6 +59,11 @@ func (g *RequestGenerator) traceBlockByHash(hash string) string {
return fmt.Sprintf(template, hash, g.reqID)
}

func (g *RequestGenerator) debugTraceBlockByNumber(blockNum uint64) string {
const template = `{"jsonrpc":"2.0","method":"debug_traceBlockByNumber","params":[%d],"id":%d}`
return fmt.Sprintf(template, blockNum, g.reqID)
}

func (g *RequestGenerator) traceTransaction(hash string) string {
const template = `{"jsonrpc":"2.0","method":"debug_traceTransaction","params":["%s"],"id":%d}`
return fmt.Sprintf(template, hash, g.reqID)
Expand Down

0 comments on commit d127126

Please sign in to comment.