package main import ( "bytes" "fmt" "os" "time" abcicli "github.com/tendermint/abci/client" "github.com/tendermint/abci/types" "github.com/tendermint/tmlibs/log" "github.com/tendermint/tmlibs/process" ) func startApp(abciApp string) *process.Process { // Start the app //outBuf := NewBufferCloser(nil) proc, err := process.StartProcess("abci_app", "", "bash", []string{"-c", fmt.Sprintf("abci-cli %s", abciApp)}, nil, os.Stdout, ) if err != nil { panicf("running abci_app: %v", err) } // TODO a better way to handle this? time.Sleep(time.Second) return proc } func startClient(abciType string) abcicli.Client { // Start client client, err := abcicli.NewClient("tcp://127.0.0.1:46658", abciType, true) if err != nil { panic(err.Error()) } logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout)) client.SetLogger(logger.With("module", "abcicli")) if _, err := client.Start(); err != nil { panicf("connecting to abci_app: %v", err.Error()) } return client } func setOption(client abcicli.Client, key, value string) { _, err := client.SetOptionSync(key, value) if err != nil { panicf("setting %v=%v: \nerr: %v", key, value, err) } } func commit(client abcicli.Client, hashExp []byte) { res, err := client.CommitSync() if err != nil { panicf("client error: %v", err) } if res.IsErr() { panicf("committing err %v\n", res) } if !bytes.Equal(res.Data, hashExp) { panicf("Commit hash was unexpected. Got %X expected %X", res.Data, hashExp) } } func deliverTx(client abcicli.Client, txBytes []byte, codeExp types.CodeType, dataExp []byte) { res, err := client.DeliverTxSync(txBytes) if err != nil { panicf("client error: %v", err) } if res.Code != codeExp { panicf("DeliverTx response code was unexpected. Got %v expected %v. Log: %v", res.Code, codeExp, res.Log) } if !bytes.Equal(res.Data, dataExp) { panicf("DeliverTx response data was unexpected. Got %X expected %X", res.Data, dataExp) } } /*func checkTx(client abcicli.Client, txBytes []byte, codeExp types.CodeType, dataExp []byte) { res, err := client.CheckTxSync(txBytes) if err != nil { panicf("client error: %v", err) } if res.IsErr() { panicf("checking tx %X: %v\nlog: %v", txBytes, res.Log) } if res.Code != codeExp { panicf("CheckTx response code was unexpected. Got %v expected %v. Log: %v", res.Code, codeExp, res.Log) } if !bytes.Equal(res.Data, dataExp) { panicf("CheckTx response data was unexpected. Got %X expected %X", res.Data, dataExp) } }*/ func panicf(format string, a ...interface{}) { panic(fmt.Sprintf(format, a)) }