mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-07 03:22:18 +00:00
64 lines
1.7 KiB
Go
64 lines
1.7 KiB
Go
//go:build integration
|
|
|
|
package discover
|
|
|
|
import (
|
|
"context"
|
|
"github.com/ledgerwatch/erigon/p2p/discover/v5wire"
|
|
"net"
|
|
"runtime"
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
// This test checks that calls with n replies may take up to n * respTimeout.
|
|
func TestUDPv5_callTimeoutReset(t *testing.T) {
|
|
if runtime.GOOS == "windows" {
|
|
t.Skip("fix me on win please")
|
|
}
|
|
t.Parallel()
|
|
|
|
replyTimeout := respTimeoutV5
|
|
// This must be significantly lower than replyTimeout to not get "RPC timeout" error.
|
|
singleReplyDelay := replyTimeout / (totalNodesResponseLimit - 1)
|
|
if singleReplyDelay*totalNodesResponseLimit < replyTimeout {
|
|
t.Fatalf("The total delay of all replies must exceed an individual reply timeout.")
|
|
}
|
|
if replyTimeout-singleReplyDelay < 50*time.Millisecond {
|
|
t.Errorf("50ms is sometimes not enough on a slow CI to process a reply.")
|
|
}
|
|
|
|
ctx := context.Background()
|
|
ctx = contextWithReplyTimeout(ctx, replyTimeout)
|
|
|
|
test := newUDPV5TestContext(ctx, t)
|
|
t.Cleanup(test.close)
|
|
|
|
// Launch the request:
|
|
var (
|
|
distance = uint(230)
|
|
remote = test.getNode(test.remotekey, test.remoteaddr).Node()
|
|
nodes = nodesAtDistance(remote.ID(), int(distance), totalNodesResponseLimit)
|
|
done = make(chan error, 1)
|
|
)
|
|
go func() {
|
|
_, err := test.udp.findnode(remote, []uint{distance})
|
|
done <- err
|
|
}()
|
|
|
|
// Serve two responses, slowly.
|
|
test.waitPacketOut(func(p *v5wire.Findnode, addr *net.UDPAddr, _ v5wire.Nonce) {
|
|
for i := 0; i < totalNodesResponseLimit; i++ {
|
|
time.Sleep(singleReplyDelay)
|
|
test.packetIn(&v5wire.Nodes{
|
|
ReqID: p.ReqID,
|
|
Total: totalNodesResponseLimit,
|
|
Nodes: nodesToRecords(nodes[i : i+1]),
|
|
})
|
|
}
|
|
})
|
|
if err := <-done; err != nil {
|
|
t.Fatalf("unexpected error: %q", err)
|
|
}
|
|
}
|