package proxy
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"strings"
|
|
"testing"
|
|
|
|
abcicli "github.com/tendermint/tendermint/abci/client"
|
|
"github.com/tendermint/tendermint/abci/example/kvstore"
|
|
"github.com/tendermint/tendermint/abci/server"
|
|
"github.com/tendermint/tendermint/abci/types"
|
|
"github.com/tendermint/tendermint/libs/log"
|
|
tmrand "github.com/tendermint/tendermint/libs/rand"
|
|
)
|
|
|
|
//----------------------------------------
|
|
|
|
type appConnTestI interface {
|
|
EchoAsync(ctx context.Context, msg string) (*abcicli.ReqRes, error)
|
|
FlushSync(context.Context) error
|
|
InfoSync(context.Context, types.RequestInfo) (*types.ResponseInfo, error)
|
|
}
|
|
|
|
type appConnTest struct {
|
|
appConn abcicli.Client
|
|
}
|
|
|
|
func newAppConnTest(appConn abcicli.Client) appConnTestI {
|
|
return &appConnTest{appConn}
|
|
}
|
|
|
|
func (app *appConnTest) EchoAsync(ctx context.Context, msg string) (*abcicli.ReqRes, error) {
|
|
return app.appConn.EchoAsync(ctx, msg)
|
|
}
|
|
|
|
func (app *appConnTest) FlushSync(ctx context.Context) error {
|
|
return app.appConn.FlushSync(ctx)
|
|
}
|
|
|
|
func (app *appConnTest) InfoSync(ctx context.Context, req types.RequestInfo) (*types.ResponseInfo, error) {
|
|
return app.appConn.InfoSync(ctx, req)
|
|
}
|
|
|
|
//----------------------------------------
|
|
|
|
var SOCKET = "socket"
|
|
|
|
func TestEcho(t *testing.T) {
|
|
sockPath := fmt.Sprintf("unix:///tmp/echo_%v.sock", tmrand.Str(6))
|
|
clientCreator := NewRemoteClientCreator(sockPath, SOCKET, true)
|
|
|
|
// Start server
|
|
s := server.NewSocketServer(sockPath, kvstore.NewApplication())
|
|
s.SetLogger(log.TestingLogger().With("module", "abci-server"))
|
|
if err := s.Start(); err != nil {
|
|
t.Fatalf("Error starting socket server: %v", err.Error())
|
|
}
|
|
t.Cleanup(func() {
|
|
if err := s.Stop(); err != nil {
|
|
t.Error(err)
|
|
}
|
|
})
|
|
|
|
// Start client
|
|
cli, err := clientCreator.NewABCIClient()
|
|
if err != nil {
|
|
t.Fatalf("Error creating ABCI client: %v", err.Error())
|
|
}
|
|
cli.SetLogger(log.TestingLogger().With("module", "abci-client"))
|
|
if err := cli.Start(); err != nil {
|
|
t.Fatalf("Error starting ABCI client: %v", err.Error())
|
|
}
|
|
|
|
proxy := newAppConnTest(cli)
|
|
t.Log("Connected")
|
|
|
|
ctx := context.Background()
|
|
for i := 0; i < 1000; i++ {
|
|
_, err = proxy.EchoAsync(ctx, fmt.Sprintf("echo-%v", i))
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
// flush sometimes
|
|
if i%128 == 0 {
|
|
if err := proxy.FlushSync(ctx); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
}
|
|
if err := proxy.FlushSync(ctx); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func BenchmarkEcho(b *testing.B) {
|
|
b.StopTimer() // Initialize
|
|
sockPath := fmt.Sprintf("unix:///tmp/echo_%v.sock", tmrand.Str(6))
|
|
clientCreator := NewRemoteClientCreator(sockPath, SOCKET, true)
|
|
|
|
// Start server
|
|
s := server.NewSocketServer(sockPath, kvstore.NewApplication())
|
|
s.SetLogger(log.TestingLogger().With("module", "abci-server"))
|
|
if err := s.Start(); err != nil {
|
|
b.Fatalf("Error starting socket server: %v", err.Error())
|
|
}
|
|
b.Cleanup(func() {
|
|
if err := s.Stop(); err != nil {
|
|
b.Error(err)
|
|
}
|
|
})
|
|
|
|
// Start client
|
|
cli, err := clientCreator.NewABCIClient()
|
|
if err != nil {
|
|
b.Fatalf("Error creating ABCI client: %v", err.Error())
|
|
}
|
|
cli.SetLogger(log.TestingLogger().With("module", "abci-client"))
|
|
if err := cli.Start(); err != nil {
|
|
b.Fatalf("Error starting ABCI client: %v", err.Error())
|
|
}
|
|
|
|
proxy := newAppConnTest(cli)
|
|
b.Log("Connected")
|
|
echoString := strings.Repeat(" ", 200)
|
|
b.StartTimer() // Start benchmarking tests
|
|
|
|
ctx := context.Background()
|
|
for i := 0; i < b.N; i++ {
|
|
_, err = proxy.EchoAsync(ctx, echoString)
|
|
if err != nil {
|
|
b.Error(err)
|
|
}
|
|
// flush sometimes
|
|
if i%128 == 0 {
|
|
if err := proxy.FlushSync(ctx); err != nil {
|
|
b.Error(err)
|
|
}
|
|
}
|
|
}
|
|
if err := proxy.FlushSync(ctx); err != nil {
|
|
b.Error(err)
|
|
}
|
|
|
|
b.StopTimer()
|
|
// info := proxy.InfoSync(types.RequestInfo{""})
|
|
// b.Log("N: ", b.N, info)
|
|
}
|
|
|
|
func TestInfo(t *testing.T) {
|
|
sockPath := fmt.Sprintf("unix:///tmp/echo_%v.sock", tmrand.Str(6))
|
|
clientCreator := NewRemoteClientCreator(sockPath, SOCKET, true)
|
|
|
|
// Start server
|
|
s := server.NewSocketServer(sockPath, kvstore.NewApplication())
|
|
s.SetLogger(log.TestingLogger().With("module", "abci-server"))
|
|
if err := s.Start(); err != nil {
|
|
t.Fatalf("Error starting socket server: %v", err.Error())
|
|
}
|
|
t.Cleanup(func() {
|
|
if err := s.Stop(); err != nil {
|
|
t.Error(err)
|
|
}
|
|
})
|
|
|
|
// Start client
|
|
cli, err := clientCreator.NewABCIClient()
|
|
if err != nil {
|
|
t.Fatalf("Error creating ABCI client: %v", err.Error())
|
|
}
|
|
cli.SetLogger(log.TestingLogger().With("module", "abci-client"))
|
|
if err := cli.Start(); err != nil {
|
|
t.Fatalf("Error starting ABCI client: %v", err.Error())
|
|
}
|
|
|
|
proxy := newAppConnTest(cli)
|
|
t.Log("Connected")
|
|
|
|
resInfo, err := proxy.InfoSync(context.Background(), RequestInfo)
|
|
if err != nil {
|
|
t.Errorf("unexpected error: %v", err)
|
|
}
|
|
if resInfo.Data != "{\"size\":0}" {
|
|
t.Error("Expected ResponseInfo with one element '{\"size\":0}' but got something else")
|
|
}
|
|
}
|