tendermint/example/golang/dummy_test.go

98 lines
2.1 KiB
Go
Raw Normal View History

2015-11-27 15:42:00 -08:00
package example
2015-11-02 07:39:53 -08:00
import (
"reflect"
2015-11-02 07:39:53 -08:00
"testing"
"time"
2015-11-02 07:39:53 -08:00
. "github.com/tendermint/go-common"
"github.com/tendermint/go-wire"
"github.com/tendermint/tmsp/server"
"github.com/tendermint/tmsp/types"
)
func TestStream(t *testing.T) {
numAppendTxs := 200000
2015-11-02 07:39:53 -08:00
// Start the listener
2015-12-01 15:27:50 -08:00
_, err := server.StartListener("tcp://127.0.0.1:46658", NewDummyApplication())
2015-11-02 07:39:53 -08:00
if err != nil {
Exit(err.Error())
}
// Connect to the socket
2015-12-01 15:27:50 -08:00
conn, err := Connect("tcp://127.0.0.1:46658")
2015-11-02 07:39:53 -08:00
if err != nil {
Exit(err.Error())
}
// Read response data
done := make(chan struct{})
2015-11-02 07:39:53 -08:00
go func() {
counter := 0
2015-11-02 07:39:53 -08:00
for {
2015-11-10 12:49:07 -08:00
var n int
2015-11-02 07:39:53 -08:00
var err error
var res types.Response
wire.ReadBinaryPtrLengthPrefixed(&res, conn, 0, &n, &err)
2015-11-02 07:39:53 -08:00
if err != nil {
Exit(err.Error())
}
// Process response
switch res := res.(type) {
case types.ResponseAppendTx:
counter += 1
if res.Code != types.RetCodeOK {
t.Error("AppendTx failed with ret_code", res.Code)
}
if counter > numAppendTxs {
t.Fatal("Too many AppendTx responses")
}
t.Log("response", counter)
if counter == numAppendTxs {
go func() {
time.Sleep(time.Second * 2) // Wait for a bit to allow counter overflow
close(done)
}()
}
case types.ResponseFlush:
// ignore
default:
t.Error("Unexpected response type", reflect.TypeOf(res))
}
2015-11-02 07:39:53 -08:00
}
}()
// Write requests
for counter := 0; counter < numAppendTxs; counter++ {
// Send request
2015-11-10 12:49:07 -08:00
var n int
2015-11-02 07:39:53 -08:00
var err error
var req types.Request = types.RequestAppendTx{TxBytes: []byte("test")}
wire.WriteBinaryLengthPrefixed(struct{ types.Request }{req}, conn, &n, &err)
2015-11-02 07:39:53 -08:00
if err != nil {
t.Fatal(err.Error())
}
// Sometimes send flush messages
if counter%123 == 0 {
t.Log("flush")
wire.WriteBinaryLengthPrefixed(struct{ types.Request }{types.RequestFlush{}}, conn, &n, &err)
if err != nil {
t.Fatal(err.Error())
}
2015-11-02 07:39:53 -08:00
}
}
// Send final flush message
var n int
wire.WriteBinaryLengthPrefixed(struct{ types.Request }{types.RequestFlush{}}, conn, &n, &err)
if err != nil {
t.Fatal(err.Error())
}
<-done
2015-11-02 07:39:53 -08:00
}