|
|
- package proxy
-
- import (
- "bytes"
- "strings"
- "testing"
-
- . "github.com/tendermint/go-common"
- "github.com/tendermint/go-logio"
- "github.com/tendermint/tmsp/example/golang"
- "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 := NewRemoteAppConn(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 := NewRemoteAppConn(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 := NewRemoteAppConn(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")
- }
- }
|