mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-26 19:17:24 +00:00
aa4bc1b6e8
* block partial persist * replaced refactored files with old one. * removed gokit/log from deps * Tweaks to not overburden remote nodes with getheaders/getblocks * Changed Transporter interface to not take the server as argument due to a cause of race warning from the compiler * started server test suite * more test + return errors from message handlers * removed --race from build * Little improvements.
114 lines
2.7 KiB
Go
114 lines
2.7 KiB
Go
package network
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/CityOfZion/neo-go/pkg/network/payload"
|
|
"github.com/CityOfZion/neo-go/pkg/util"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestSendVersion(t *testing.T) {
|
|
var (
|
|
s = newTestServer()
|
|
p = newLocalPeer(t)
|
|
)
|
|
s.ListenTCP = 3000
|
|
s.UserAgent = "/test/"
|
|
|
|
p.messageHandler = func(t *testing.T, msg *Message) {
|
|
assert.Equal(t, CMDVersion, msg.CommandType())
|
|
assert.IsType(t, msg.Payload, &payload.Version{})
|
|
version := msg.Payload.(*payload.Version)
|
|
assert.NotZero(t, version.Nonce)
|
|
assert.Equal(t, uint16(3000), version.Port)
|
|
assert.Equal(t, uint64(1), version.Services)
|
|
assert.Equal(t, uint32(0), version.Version)
|
|
assert.Equal(t, []byte("/test/"), version.UserAgent)
|
|
assert.Equal(t, uint32(0), version.StartHeight)
|
|
}
|
|
|
|
s.sendVersion(p)
|
|
}
|
|
|
|
func TestRequestPeerInfo(t *testing.T) {
|
|
var (
|
|
s = newTestServer()
|
|
p = newLocalPeer(t)
|
|
)
|
|
|
|
p.messageHandler = func(t *testing.T, msg *Message) {
|
|
assert.Equal(t, CMDGetAddr, msg.CommandType())
|
|
assert.Nil(t, msg.Payload)
|
|
}
|
|
s.requestPeerInfo(p)
|
|
}
|
|
|
|
// Server should reply with a verack after receiving a valid version.
|
|
func TestVerackAfterHandleVersionCmd(t *testing.T) {
|
|
var (
|
|
s = newTestServer()
|
|
p = newLocalPeer(t)
|
|
)
|
|
p.endpoint = util.NewEndpoint("0.0.0.0:3000")
|
|
|
|
// Should have a verack
|
|
p.messageHandler = func(t *testing.T, msg *Message) {
|
|
assert.Equal(t, CMDVerack, msg.CommandType())
|
|
}
|
|
version := payload.NewVersion(1337, 3000, "/NEO-GO/", 0, true)
|
|
|
|
if err := s.handleVersionCmd(p, version); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
// Server should not reply with a verack after receiving a
|
|
// invalid version and disconnects the peer.
|
|
func TestServerNotSendsVerack(t *testing.T) {
|
|
var (
|
|
s = newTestServer()
|
|
p = newLocalPeer(t)
|
|
)
|
|
s.id = 1
|
|
go s.run()
|
|
|
|
p.endpoint = util.NewEndpoint("0.0.0.0:3000")
|
|
s.register <- p
|
|
|
|
// Port should mismatch
|
|
version := payload.NewVersion(1337, 2000, "/NEO-GO/", 0, true)
|
|
err := s.handleVersionCmd(p, version)
|
|
assert.NotNil(t, err)
|
|
assert.Equal(t, errPortMismatch, err)
|
|
|
|
// identical id's
|
|
version = payload.NewVersion(1, 3000, "/NEO-GO/", 0, true)
|
|
err = s.handleVersionCmd(p, version)
|
|
assert.NotNil(t, err)
|
|
assert.Equal(t, errIdenticalID, err)
|
|
}
|
|
|
|
func TestRequestPeers(t *testing.T) {
|
|
var (
|
|
s = newTestServer()
|
|
p = newLocalPeer(t)
|
|
)
|
|
p.messageHandler = func(t *testing.T, msg *Message) {
|
|
assert.Nil(t, msg.Payload)
|
|
assert.Equal(t, CMDGetAddr, msg.CommandType())
|
|
}
|
|
s.requestPeerInfo(p)
|
|
}
|
|
|
|
func TestRequestHeaders(t *testing.T) {
|
|
var (
|
|
s = newTestServer()
|
|
p = newLocalPeer(t)
|
|
)
|
|
p.messageHandler = func(t *testing.T, msg *Message) {
|
|
assert.IsType(t, &payload.GetBlocks{}, msg.Payload)
|
|
assert.Equal(t, CMDGetHeaders, msg.CommandType())
|
|
}
|
|
s.requestHeaders(p)
|
|
}
|