Skip to content

Commit

Permalink
feat: fix discovery test
Browse files Browse the repository at this point in the history
Signed-off-by: Chen Kai <281165273grape@gmail.com>
  • Loading branch information
GrapeBaBa committed Feb 24, 2024
1 parent c8d7aa5 commit 00fcda6
Showing 1 changed file with 34 additions and 28 deletions.
62 changes: 34 additions & 28 deletions p2p/discover/portal_protocol_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import (
"time"

"github.com/prysmaticlabs/go-bitfield"
"golang.org/x/exp/slices"

"github.com/ethereum/go-ethereum/internal/testlog"
"github.com/ethereum/go-ethereum/log"
Expand Down Expand Up @@ -200,50 +201,55 @@ func TestPortalWireProtocolUdp(t *testing.T) {
func TestPortalWireProtocol(t *testing.T) {
node1, err := setupLocalPortalNode(":7777", nil)
assert.NoError(t, err)
node1.log = testlog.Logger(t, log.LvlTrace)
node1.log = testlog.Logger(t, log.LevelDebug)
err = node1.Start()
assert.NoError(t, err)
fmt.Println(node1.localNode.Node().String())

time.Sleep(15 * time.Second)

node2, err := setupLocalPortalNode(":7778", []*enode.Node{node1.localNode.Node()})
assert.NoError(t, err)
node2.log = testlog.Logger(t, log.LvlTrace)
node2.log = testlog.Logger(t, log.LevelDebug)
err = node2.Start()
assert.NoError(t, err)
fmt.Println(node2.localNode.Node().String())

time.Sleep(15 * time.Second)

node3, err := setupLocalPortalNode(":7779", []*enode.Node{node1.localNode.Node()})
assert.NoError(t, err)
node3.log = testlog.Logger(t, log.LvlTrace)
node3.log = testlog.Logger(t, log.LevelDebug)
err = node3.Start()
assert.NoError(t, err)
fmt.Println(node3.localNode.Node().String())
time.Sleep(10 * time.Second)

//assert.Equal(t, 2, len(node1.table.Nodes()))
//assert.Equal(t, 2, len(node2.table.Nodes()))
//assert.Equal(t, 2, len(node3.table.Nodes()))

//slices.ContainsFunc(node1.table.Nodes(), func(n *enode.Node) bool {
// return n.ID() == node2.localNode.Node().ID()
//})
//slices.ContainsFunc(node1.table.Nodes(), func(n *enode.Node) bool {
// return n.ID() == node3.localNode.Node().ID()
//})
//
//slices.ContainsFunc(node2.table.Nodes(), func(n *enode.Node) bool {
// return n.ID() == node1.localNode.Node().ID()
//})
//slices.ContainsFunc(node2.table.Nodes(), func(n *enode.Node) bool {
// return n.ID() == node3.localNode.Node().ID()
//})
//
//slices.ContainsFunc(node3.table.Nodes(), func(n *enode.Node) bool {
// return n.ID() == node1.localNode.Node().ID()
//})
//slices.ContainsFunc(node3.table.Nodes(), func(n *enode.Node) bool {
// return n.ID() == node2.localNode.Node().ID()
//})
time.Sleep(15 * time.Second)

assert.Equal(t, 2, len(node1.table.Nodes()))
assert.Equal(t, 2, len(node2.table.Nodes()))
assert.Equal(t, 2, len(node3.table.Nodes()))

slices.ContainsFunc(node1.table.Nodes(), func(n *enode.Node) bool {
return n.ID() == node2.localNode.Node().ID()
})
slices.ContainsFunc(node1.table.Nodes(), func(n *enode.Node) bool {
return n.ID() == node3.localNode.Node().ID()
})

slices.ContainsFunc(node2.table.Nodes(), func(n *enode.Node) bool {
return n.ID() == node1.localNode.Node().ID()
})
slices.ContainsFunc(node2.table.Nodes(), func(n *enode.Node) bool {
return n.ID() == node3.localNode.Node().ID()
})

slices.ContainsFunc(node3.table.Nodes(), func(n *enode.Node) bool {
return n.ID() == node1.localNode.Node().ID()
})
slices.ContainsFunc(node3.table.Nodes(), func(n *enode.Node) bool {
return n.ID() == node2.localNode.Node().ID()
})

err = node1.storage.Put(node1.toContentId([]byte("test_key")), []byte("test_value"))
assert.NoError(t, err)
Expand Down

0 comments on commit 00fcda6

Please sign in to comment.