package proxy
|
|
|
|
import (
|
|
"bytes"
|
|
"strings"
|
|
"testing"
|
|
|
|
. "github.com/tendermint/go-common"
|
|
"github.com/tendermint/go-logio"
|
|
example "github.com/tendermint/tmsp/example"
|
|
"github.com/tendermint/tmsp/server"
|
|
)
|
|
|
|
func TestEcho(t *testing.T) {
|
|
sockPath := Fmt("unix:///tmp/echo_%v.sock", RandStr(6))
|
|
_, err := server.StartListener(sockPath, example.NewDummyApplication())
|
|
if err != nil {
|
|
Exit(err.Error())
|
|
}
|
|
conn, err := Connect(sockPath)
|
|
if err != nil {
|
|
Exit(err.Error())
|
|
} else {
|
|
t.Log("Connected")
|
|
}
|
|
|
|
logBuffer := bytes.NewBuffer(nil)
|
|
logConn := logio.NewLoggedConn(conn, logBuffer)
|
|
proxy := NewRemoteAppContext(logConn, 10)
|
|
proxy.SetResponseCallback(nil)
|
|
proxy.Start()
|
|
|
|
for i := 0; i < 1000; i++ {
|
|
proxy.EchoAsync(Fmt("echo-%v", i))
|
|
}
|
|
proxy.FlushSync()
|
|
|
|
/*
|
|
if t.Failed() {
|
|
logio.PrintReader(logBuffer)
|
|
}
|
|
*/
|
|
}
|
|
|
|
func BenchmarkEcho(b *testing.B) {
|
|
b.StopTimer() // Initialize
|
|
sockPath := Fmt("unix:///tmp/echo_%v.sock", RandStr(6))
|
|
_, err := server.StartListener(sockPath, example.NewDummyApplication())
|
|
if err != nil {
|
|
Exit(err.Error())
|
|
}
|
|
conn, err := Connect(sockPath)
|
|
if err != nil {
|
|
Exit(err.Error())
|
|
} else {
|
|
b.Log("Connected")
|
|
}
|
|
|
|
proxy := NewRemoteAppContext(conn, 10)
|
|
proxy.Start()
|
|
echoString := strings.Repeat(" ", 200)
|
|
b.StartTimer() // Start benchmarking tests
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
proxy.EchoAsync(echoString)
|
|
}
|
|
proxy.FlushSync()
|
|
|
|
b.StopTimer()
|
|
// info := proxy.InfoSync()
|
|
//b.Log("N: ", b.N, info)
|
|
}
|
|
|
|
func TestInfo(t *testing.T) {
|
|
sockPath := Fmt("unix:///tmp/echo_%v.sock", RandStr(6))
|
|
_, err := server.StartListener(sockPath, example.NewDummyApplication())
|
|
if err != nil {
|
|
Exit(err.Error())
|
|
}
|
|
conn, err := Connect(sockPath)
|
|
if err != nil {
|
|
Exit(err.Error())
|
|
} else {
|
|
t.Log("Connected")
|
|
}
|
|
|
|
logBuffer := bytes.NewBuffer(nil)
|
|
logConn := logio.NewLoggedConn(conn, logBuffer)
|
|
proxy := NewRemoteAppContext(logConn, 10)
|
|
proxy.Start()
|
|
data, err := proxy.InfoSync()
|
|
if err != nil {
|
|
t.Errorf("Unexpected error: %v", err)
|
|
}
|
|
if data[0] != "size:0" {
|
|
t.Error("Expected ResponseInfo with one element 'size:0' but got something else")
|
|
}
|
|
}
|