tendermint/example/nil/nil_test.go

94 lines
1.9 KiB
Go
Raw Normal View History

2016-02-26 20:04:28 -05:00
package nilapp
import (
2016-05-14 03:09:47 -04:00
"reflect"
2016-02-26 20:04:28 -05:00
"testing"
"time"
. "github.com/tendermint/go-common"
"github.com/tendermint/tmsp/server"
"github.com/tendermint/tmsp/types"
)
func TestStream(t *testing.T) {
numAppendTxs := 200000
// Start the listener
2016-02-29 21:53:04 -08:00
server, err := server.NewServer("unix://test.sock", NewNilApplication())
2016-02-26 20:04:28 -05:00
if err != nil {
Exit(err.Error())
}
2016-02-29 21:53:04 -08:00
defer server.Stop()
2016-02-26 20:04:28 -05:00
// Connect to the socket
2016-02-29 21:53:04 -08:00
conn, err := Connect("unix://test.sock")
2016-02-26 20:04:28 -05:00
if err != nil {
Exit(err.Error())
}
// Read response data
done := make(chan struct{})
go func() {
counter := 0
for {
var res = &types.Response{}
err := types.ReadMessage(conn, res)
if err != nil {
Exit(err.Error())
}
// Process response
2016-05-14 03:09:47 -04:00
switch r := res.Responses.(type) {
case *types.Response_AppendTx:
2016-02-26 20:04:28 -05:00
counter += 1
2016-05-14 03:09:47 -04:00
if r.AppendTx.Code != types.CodeType_OK {
t.Error("AppendTx failed with ret_code", r.AppendTx.Code)
2016-02-26 20:04:28 -05:00
}
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)
}()
}
2016-05-14 03:09:47 -04:00
case *types.Response_Flush:
2016-02-26 20:04:28 -05:00
// ignore
default:
2016-05-14 03:09:47 -04:00
t.Error("Unexpected response type", reflect.TypeOf(res.Responses))
2016-02-26 20:04:28 -05:00
}
}
}()
// Write requests
for counter := 0; counter < numAppendTxs; counter++ {
// Send request
2016-05-14 03:09:47 -04:00
var req = types.ToRequestAppendTx([]byte("test"))
2016-02-26 20:04:28 -05:00
err := types.WriteMessage(req, conn)
if err != nil {
t.Fatal(err.Error())
}
// Sometimes send flush messages
if counter%123 == 0 {
t.Log("flush")
2016-05-14 03:09:47 -04:00
err := types.WriteMessage(types.ToRequestFlush(), conn)
2016-02-26 20:04:28 -05:00
if err != nil {
t.Fatal(err.Error())
}
}
}
// Send final flush message
2016-05-14 03:09:47 -04:00
err = types.WriteMessage(types.ToRequestFlush(), conn)
2016-02-26 20:04:28 -05:00
if err != nil {
t.Fatal(err.Error())
}
<-done
}