2016-06-25 21:59:52 -04:00
|
|
|
package p2p
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"testing"
|
2017-05-02 11:53:32 +04:00
|
|
|
|
2018-07-01 22:21:29 -04:00
|
|
|
"github.com/tendermint/tendermint/config"
|
2018-07-01 22:36:49 -04:00
|
|
|
"github.com/tendermint/tendermint/libs/log"
|
2016-06-25 21:59:52 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestListener(t *testing.T) {
|
|
|
|
// Create a listener
|
2018-07-01 22:21:29 -04:00
|
|
|
cfg := &config.P2PConfig{
|
|
|
|
ListenAddress: "tcp://:8001",
|
|
|
|
}
|
|
|
|
l := NewDefaultListener(cfg, log.TestingLogger())
|
2016-06-25 21:59:52 -04:00
|
|
|
|
|
|
|
// Dial the listener
|
|
|
|
lAddr := l.ExternalAddress()
|
|
|
|
connOut, err := lAddr.Dial()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Could not connect to listener address %v", lAddr)
|
|
|
|
} else {
|
|
|
|
t.Logf("Created a connection to listener address %v", lAddr)
|
|
|
|
}
|
|
|
|
connIn, ok := <-l.Connections()
|
|
|
|
if !ok {
|
|
|
|
t.Fatalf("Could not get inbound connection from listener")
|
|
|
|
}
|
|
|
|
|
|
|
|
msg := []byte("hi!")
|
2017-09-21 12:38:48 -04:00
|
|
|
go func() {
|
|
|
|
_, err := connIn.Write(msg)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
}()
|
2016-06-25 21:59:52 -04:00
|
|
|
b := make([]byte, 32)
|
|
|
|
n, err := connOut.Read(b)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Error reading off connection: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
b = b[:n]
|
|
|
|
if !bytes.Equal(msg, b) {
|
|
|
|
t.Fatalf("Got %s, expected %s", b, msg)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Close the server, no longer needed.
|
|
|
|
l.Stop()
|
|
|
|
}
|