The core protocol of WoopChain
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
woop/p2p/tests/host_test.go

84 lines
2.1 KiB

package p2ptests
import (
"testing"
"github.com/harmony-one/harmony/test/helpers"
"github.com/stretchr/testify/assert"
)
func TestHostSetup(t *testing.T) {
t.Parallel()
hostData := helpers.Hosts[0]
host, pubKey, err := helpers.GenerateHost(hostData.IP, hostData.Port)
assert.NoError(t, err)
peer := host.GetSelfPeer()
assert.Equal(t, hostData.IP, peer.IP)
assert.Equal(t, hostData.Port, peer.Port)
assert.Equal(t, pubKey, peer.ConsensusPubKey)
assert.NotEmpty(t, peer.PeerID)
assert.Equal(t, peer.PeerID, host.GetID())
assert.Empty(t, peer.Addrs)
}
func TestAddPeer(t *testing.T) {
t.Parallel()
hostData := helpers.Hosts[0]
host, _, err := helpers.GenerateHost(hostData.IP, hostData.Port)
assert.NoError(t, err)
assert.NotEmpty(t, host.GetID())
discoveredHostData := helpers.Hosts[1]
discoveredHost, _, err := helpers.GenerateHost(discoveredHostData.IP, discoveredHostData.Port)
assert.NoError(t, err)
assert.NotEmpty(t, discoveredHost.GetID())
discoveredPeer := discoveredHost.GetSelfPeer()
assert.Empty(t, host.GetP2PHost().Peerstore().Addrs(discoveredHost.GetSelfPeer().PeerID))
err = host.AddPeer(&discoveredPeer)
assert.NoError(t, err)
assert.NotEmpty(t, host.GetP2PHost().Peerstore().Addrs(discoveredHost.GetSelfPeer().PeerID))
assert.Equal(t, 2, host.GetPeerCount())
}
/*func TestTopicJoining(t *testing.T) {
t.Parallel()
hostData := hosts[0]
host, _, err := createNode(hostData.IP, hostData.Port)
assert.NoError(t, err)
assert.NotEmpty(t, host.GetID())
for _, topicName := range topics {
topic, err := host.GetOrJoin(topicName)
assert.NoError(t, err)
assert.NotNil(t, topic)
}
}*/
func TestConnectionToInvalidPeer(t *testing.T) {
t.Parallel()
hostData := helpers.Hosts[0]
host, _, err := helpers.GenerateHost(hostData.IP, hostData.Port)
assert.NoError(t, err)
assert.NotEmpty(t, host.GetID())
discoveredHostData := helpers.Hosts[1]
discoveredHost, _, err := helpers.GenerateHost(discoveredHostData.IP, discoveredHostData.Port)
assert.NoError(t, err)
assert.NotEmpty(t, discoveredHost.GetID())
discoveredPeer := discoveredHost.GetSelfPeer()
err = host.ConnectHostPeer(discoveredPeer)
assert.Error(t, err)
}