erigon-pulse/cmd/devnet/requests/tx.go
ledgerwatch f5bd806b84
[devnet] Remove dependency on rpctest (#7608)
Co-authored-by: Alex Sharp <alexsharp@Alexs-MacBook-Pro-2.local>
2023-05-31 19:47:32 +01:00

51 lines
1.2 KiB
Go

package requests
import (
"fmt"
"github.com/ledgerwatch/erigon/cmd/devnet/models"
"github.com/ledgerwatch/log/v3"
)
func TxpoolContent(reqGen *RequestGenerator, logger log.Logger) (int, int, int, error) {
var (
b models.EthTxPool
pending map[string]interface{}
queued map[string]interface{}
baseFee map[string]interface{}
)
if res := reqGen.Erigon("txpool_content", reqGen.TxpoolContent(), &b); res.Err != nil {
return len(pending), len(queued), len(baseFee), fmt.Errorf("failed to fetch txpool content: %v", res.Err)
}
resp := b.Result.(map[string]interface{})
pendingLen := 0
queuedLen := 0
baseFeeLen := 0
if resp["pending"] != nil {
pending = resp["pending"].(map[string]interface{})
for _, txs := range pending { // iterate over senders
pendingLen += len(txs.(map[string]interface{}))
}
}
if resp["queue"] != nil {
queued = resp["queue"].(map[string]interface{})
for _, txs := range queued {
queuedLen += len(txs.(map[string]interface{}))
}
}
if resp["baseFee"] != nil {
baseFee = resp["baseFee"].(map[string]interface{})
for _, txs := range baseFee {
baseFeeLen += len(txs.(map[string]interface{}))
}
}
return pendingLen, queuedLen, baseFeeLen, nil
}