mirror of
https://github.com/fluencelabs/tendermint
synced 2025-05-04 19:12:14 +00:00
Merge pull request #117 from tendermint/cobra-not-urfave
use spf13/cobra instead of urfave/cli
This commit is contained in:
commit
66de53292e
16
Makefile
16
Makefile
@ -70,13 +70,13 @@ metalinter_test: tools
|
|||||||
--enable=vetshadow \
|
--enable=vetshadow \
|
||||||
./...
|
./...
|
||||||
|
|
||||||
#--enable=dupl \
|
#--enable=dupl \
|
||||||
#--enable=errcheck \
|
#--enable=errcheck \
|
||||||
#--enable=gocyclo \
|
#--enable=gocyclo \
|
||||||
#--enable=golint \ <== comments on anything exported
|
#--enable=golint \ <== comments on anything exported
|
||||||
#--enable=gotype \
|
#--enable=gotype \
|
||||||
#--enable=interfacer \
|
#--enable=interfacer \
|
||||||
#--enable=unparam \
|
#--enable=unparam \
|
||||||
#--enable=vet \
|
#--enable=vet \
|
||||||
|
|
||||||
.PHONY: all build test fmt get_deps tools
|
.PHONY: all build test fmt get_deps tools
|
||||||
|
@ -60,9 +60,9 @@ The `abci-cli` tool wraps any ABCI client and can be used for probing/testing an
|
|||||||
See [the documentation](http://tendermint.readthedocs.io/en/master/) for more details.
|
See [the documentation](http://tendermint.readthedocs.io/en/master/) for more details.
|
||||||
|
|
||||||
Multiple example apps are included:
|
Multiple example apps are included:
|
||||||
- the `counter` application, which illustrates nonce checking in txs
|
- the `abci-cli counter` application, which illustrates nonce checking in txs
|
||||||
- the `dummy` application, which illustrates a simple key-value merkle tree
|
- the `abci-cli dummy` application, which illustrates a simple key-value merkle tree
|
||||||
- the `dummy --persistent` application, which augments the dummy with persistence and validator set changes
|
- the `abci-cli dummy --persistent` application, which augments the dummy with persistence and validator set changes
|
||||||
|
|
||||||
## Specification
|
## Specification
|
||||||
|
|
||||||
|
@ -7,13 +7,18 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"os"
|
"os"
|
||||||
|
"os/exec"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
abcicli "github.com/tendermint/abci/client"
|
abcicli "github.com/tendermint/abci/client"
|
||||||
|
"github.com/tendermint/abci/example/counter"
|
||||||
|
"github.com/tendermint/abci/example/dummy"
|
||||||
|
"github.com/tendermint/abci/server"
|
||||||
"github.com/tendermint/abci/types"
|
"github.com/tendermint/abci/types"
|
||||||
"github.com/tendermint/abci/version"
|
cmn "github.com/tendermint/tmlibs/common"
|
||||||
"github.com/tendermint/tmlibs/log"
|
"github.com/tendermint/tmlibs/log"
|
||||||
"github.com/urfave/cli"
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Structure for data passed to print response.
|
// Structure for data passed to print response.
|
||||||
@ -38,149 +43,213 @@ var client abcicli.Client
|
|||||||
|
|
||||||
var logger log.Logger
|
var logger log.Logger
|
||||||
|
|
||||||
func main() {
|
// flags
|
||||||
|
var (
|
||||||
|
// global
|
||||||
|
address string
|
||||||
|
abci string
|
||||||
|
verbose bool
|
||||||
|
|
||||||
//workaround for the cli library (https://github.com/urfave/cli/issues/565)
|
// query
|
||||||
cli.OsExiter = func(_ int) {}
|
path string
|
||||||
|
height int
|
||||||
|
prove bool
|
||||||
|
|
||||||
app := cli.NewApp()
|
// counter
|
||||||
app.Name = "abci-cli"
|
addrC string
|
||||||
app.Usage = "abci-cli [command] [args...]"
|
serial bool
|
||||||
app.Version = version.Version
|
|
||||||
app.Flags = []cli.Flag{
|
|
||||||
cli.StringFlag{
|
|
||||||
Name: "address",
|
|
||||||
Value: "tcp://127.0.0.1:46658",
|
|
||||||
Usage: "address of application socket",
|
|
||||||
},
|
|
||||||
cli.StringFlag{
|
|
||||||
Name: "abci",
|
|
||||||
Value: "socket",
|
|
||||||
Usage: "socket or grpc",
|
|
||||||
},
|
|
||||||
cli.BoolFlag{
|
|
||||||
Name: "verbose",
|
|
||||||
Usage: "print the command and results as if it were a console session",
|
|
||||||
},
|
|
||||||
}
|
|
||||||
app.Commands = []cli.Command{
|
|
||||||
{
|
|
||||||
Name: "batch",
|
|
||||||
Usage: "Run a batch of abci commands against an application",
|
|
||||||
Action: func(c *cli.Context) error {
|
|
||||||
return cmdBatch(app, c)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Name: "console",
|
|
||||||
Usage: "Start an interactive abci console for multiple commands",
|
|
||||||
Action: func(c *cli.Context) error {
|
|
||||||
return cmdConsole(app, c)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Name: "echo",
|
|
||||||
Usage: "Have the application echo a message",
|
|
||||||
Action: func(c *cli.Context) error {
|
|
||||||
return cmdEcho(c)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Name: "info",
|
|
||||||
Usage: "Get some info about the application",
|
|
||||||
Action: func(c *cli.Context) error {
|
|
||||||
return cmdInfo(c)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Name: "set_option",
|
|
||||||
Usage: "Set an option on the application",
|
|
||||||
Action: func(c *cli.Context) error {
|
|
||||||
return cmdSetOption(c)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Name: "deliver_tx",
|
|
||||||
Usage: "Deliver a new tx to application",
|
|
||||||
Action: func(c *cli.Context) error {
|
|
||||||
return cmdDeliverTx(c)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Name: "check_tx",
|
|
||||||
Usage: "Validate a tx",
|
|
||||||
Action: func(c *cli.Context) error {
|
|
||||||
return cmdCheckTx(c)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Name: "commit",
|
|
||||||
Usage: "Commit the application state and return the Merkle root hash",
|
|
||||||
Action: func(c *cli.Context) error {
|
|
||||||
return cmdCommit(c)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Name: "query",
|
|
||||||
Usage: "Query application state",
|
|
||||||
Action: func(c *cli.Context) error {
|
|
||||||
return cmdQuery(c)
|
|
||||||
},
|
|
||||||
Flags: []cli.Flag{
|
|
||||||
cli.StringFlag{
|
|
||||||
Name: "path",
|
|
||||||
Value: "/store",
|
|
||||||
Usage: "Path to prefix the query with",
|
|
||||||
},
|
|
||||||
cli.IntFlag{
|
|
||||||
Name: "height",
|
|
||||||
Value: 0,
|
|
||||||
Usage: "Height to query the blockchain at",
|
|
||||||
},
|
|
||||||
cli.BoolFlag{
|
|
||||||
Name: "prove",
|
|
||||||
Usage: "Whether or not to return a merkle proof of the query result",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
app.Before = before
|
|
||||||
err := app.Run(os.Args)
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err.Error())
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
// dummy
|
||||||
|
addrD string
|
||||||
|
persist string
|
||||||
|
)
|
||||||
|
|
||||||
func before(c *cli.Context) error {
|
var RootCmd = &cobra.Command{
|
||||||
if logger == nil {
|
Use: "abci-cli",
|
||||||
logger = log.NewFilter(log.NewTMLogger(log.NewSyncWriter(os.Stdout)), log.AllowError())
|
Short: "",
|
||||||
}
|
Long: "",
|
||||||
if client == nil {
|
PersistentPreRunE: func(cmd *cobra.Command, args []string) error {
|
||||||
var err error
|
|
||||||
client, err = abcicli.NewClient(c.GlobalString("address"), c.GlobalString("abci"), false)
|
switch cmd.Use {
|
||||||
if err != nil {
|
// for the examples apps, don't pre-run
|
||||||
logger.Error(err.Error())
|
case "counter", "dummy":
|
||||||
os.Exit(1)
|
return nil
|
||||||
}
|
}
|
||||||
client.SetLogger(logger.With("module", "abci-client"))
|
|
||||||
if _, err := client.Start(); err != nil {
|
if logger == nil {
|
||||||
return err
|
logger = log.NewFilter(log.NewTMLogger(log.NewSyncWriter(os.Stdout)), log.AllowError())
|
||||||
}
|
}
|
||||||
}
|
if client == nil {
|
||||||
return nil
|
var err error
|
||||||
|
client, err = abcicli.NewClient(address, abci, false)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
client.SetLogger(logger.With("module", "abci-client"))
|
||||||
|
if _, err := client.Start(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
// badCmd is called when we invoke with an invalid first argument (just for console for now)
|
func Execute() {
|
||||||
func badCmd(c *cli.Context, cmd string) {
|
addGlobalFlags()
|
||||||
fmt.Println("Unknown command:", cmd)
|
addCommands()
|
||||||
fmt.Println("Please try one of the following:")
|
RootCmd.Execute()
|
||||||
fmt.Println("")
|
|
||||||
cli.DefaultAppComplete(c)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Generates new Args array based off of previous call args to maintain flag persistence
|
func addGlobalFlags() {
|
||||||
|
RootCmd.PersistentFlags().StringVarP(&address, "address", "", "tcp://127.0.0.1:46658", "Address of application socket")
|
||||||
|
RootCmd.PersistentFlags().StringVarP(&abci, "abci", "", "socket", "Either socket or grpc")
|
||||||
|
RootCmd.PersistentFlags().BoolVarP(&verbose, "verbose", "v", false, "Print the command and results as if it were a console session")
|
||||||
|
}
|
||||||
|
|
||||||
|
func addQueryFlags() {
|
||||||
|
queryCmd.PersistentFlags().StringVarP(&path, "path", "", "/store", "Path to prefix query with")
|
||||||
|
queryCmd.PersistentFlags().IntVarP(&height, "height", "", 0, "Height to query the blockchain at")
|
||||||
|
queryCmd.PersistentFlags().BoolVarP(&prove, "prove", "", false, "Whether or not to return a merkle proof of the query result")
|
||||||
|
}
|
||||||
|
|
||||||
|
func addCounterFlags() {
|
||||||
|
counterCmd.PersistentFlags().StringVarP(&addrC, "addr", "", "tcp://0.0.0.0:46658", "Listen address")
|
||||||
|
counterCmd.PersistentFlags().BoolVarP(&serial, "serial", "", false, "Enforce incrementing (serial) transactions")
|
||||||
|
}
|
||||||
|
|
||||||
|
func addDummyFlags() {
|
||||||
|
dummyCmd.PersistentFlags().StringVarP(&addrD, "addr", "", "tcp://0.0.0.0:46658", "Listen address")
|
||||||
|
dummyCmd.PersistentFlags().StringVarP(&persist, "persist", "", "", "Directory to use for a database")
|
||||||
|
}
|
||||||
|
func addCommands() {
|
||||||
|
RootCmd.AddCommand(batchCmd)
|
||||||
|
RootCmd.AddCommand(consoleCmd)
|
||||||
|
RootCmd.AddCommand(echoCmd)
|
||||||
|
RootCmd.AddCommand(infoCmd)
|
||||||
|
RootCmd.AddCommand(setOptionCmd)
|
||||||
|
RootCmd.AddCommand(deliverTxCmd)
|
||||||
|
RootCmd.AddCommand(checkTxCmd)
|
||||||
|
RootCmd.AddCommand(commitCmd)
|
||||||
|
addQueryFlags()
|
||||||
|
RootCmd.AddCommand(queryCmd)
|
||||||
|
|
||||||
|
// examples
|
||||||
|
addCounterFlags()
|
||||||
|
RootCmd.AddCommand(counterCmd)
|
||||||
|
addDummyFlags()
|
||||||
|
RootCmd.AddCommand(dummyCmd)
|
||||||
|
}
|
||||||
|
|
||||||
|
var batchCmd = &cobra.Command{
|
||||||
|
Use: "batch",
|
||||||
|
Short: "Run a batch of abci commands against an application",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(0),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdBatch(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
var consoleCmd = &cobra.Command{
|
||||||
|
Use: "console",
|
||||||
|
Short: "Start an interactive abci console for multiple commands",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(0),
|
||||||
|
ValidArgs: []string{"batch", "echo", "info", "set_option", "deliver_tx", "check_tx", "commit", "query"},
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdConsole(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
var echoCmd = &cobra.Command{
|
||||||
|
Use: "echo",
|
||||||
|
Short: "Have the application echo a message",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(1),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdEcho(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
var infoCmd = &cobra.Command{
|
||||||
|
Use: "info",
|
||||||
|
Short: "Get some info about the application",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(0),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdInfo(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
var setOptionCmd = &cobra.Command{
|
||||||
|
Use: "set_option",
|
||||||
|
Short: "Set an option on the application",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(2),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdSetOption(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
var deliverTxCmd = &cobra.Command{
|
||||||
|
Use: "deliver_tx",
|
||||||
|
Short: "Deliver a new transaction to the application",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(1),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdDeliverTx(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
var checkTxCmd = &cobra.Command{
|
||||||
|
Use: "check_tx",
|
||||||
|
Short: "Validate a transaction",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(1),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdCheckTx(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
var commitCmd = &cobra.Command{
|
||||||
|
Use: "commit",
|
||||||
|
Short: "Commit the application state and return the Merkle root hash",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(0),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdCommit(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
var queryCmd = &cobra.Command{
|
||||||
|
Use: "query",
|
||||||
|
Short: "Query the application state",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(1),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdQuery(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
var counterCmd = &cobra.Command{
|
||||||
|
Use: "counter",
|
||||||
|
Short: "ABCI demo example",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(0),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdCounter(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
var dummyCmd = &cobra.Command{
|
||||||
|
Use: "dummy",
|
||||||
|
Short: "ABCI demo example",
|
||||||
|
Long: "",
|
||||||
|
Args: cobra.ExactArgs(0),
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return cmdDummy(cmd, args)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
// Generates new Args array based off of previous call args to maintain flag persistence
|
||||||
func persistentArgs(line []byte) []string {
|
func persistentArgs(line []byte) []string {
|
||||||
|
|
||||||
// generate the arguments to run from original os.Args
|
// generate the arguments to run from original os.Args
|
||||||
@ -196,7 +265,7 @@ func persistentArgs(line []byte) []string {
|
|||||||
|
|
||||||
//--------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------
|
||||||
|
|
||||||
func cmdBatch(app *cli.App, c *cli.Context) error {
|
func cmdBatch(cmd *cobra.Command, args []string) error {
|
||||||
bufReader := bufio.NewReader(os.Stdin)
|
bufReader := bufio.NewReader(os.Stdin)
|
||||||
for {
|
for {
|
||||||
line, more, err := bufReader.ReadLine()
|
line, more, err := bufReader.ReadLine()
|
||||||
@ -210,18 +279,20 @@ func cmdBatch(app *cli.App, c *cli.Context) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
args := persistentArgs(line)
|
pArgs := persistentArgs(line)
|
||||||
app.Run(args) //cli prints error within its func call
|
out, err := exec.Command(pArgs[0], pArgs[1:]...).Output()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
fmt.Println(string(out))
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func cmdConsole(app *cli.App, c *cli.Context) error {
|
func cmdConsole(cmd *cobra.Command, args []string) error {
|
||||||
// don't hard exit on mistyped commands (eg. check vs check_tx)
|
|
||||||
app.CommandNotFound = badCmd
|
|
||||||
|
|
||||||
for {
|
for {
|
||||||
fmt.Printf("\n> ")
|
fmt.Printf("> ")
|
||||||
bufReader := bufio.NewReader(os.Stdin)
|
bufReader := bufio.NewReader(os.Stdin)
|
||||||
line, more, err := bufReader.ReadLine()
|
line, more, err := bufReader.ReadLine()
|
||||||
if more {
|
if more {
|
||||||
@ -230,27 +301,27 @@ func cmdConsole(app *cli.App, c *cli.Context) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
args := persistentArgs(line)
|
pArgs := persistentArgs(line)
|
||||||
app.Run(args) //cli prints error within its func call
|
out, err := exec.Command(pArgs[0], pArgs[1:]...).Output()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
fmt.Println(string(out))
|
||||||
}
|
}
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Have the application echo a message
|
// Have the application echo a message
|
||||||
func cmdEcho(c *cli.Context) error {
|
func cmdEcho(cmd *cobra.Command, args []string) error {
|
||||||
args := c.Args()
|
|
||||||
if len(args) != 1 {
|
|
||||||
return errors.New("Command echo takes 1 argument")
|
|
||||||
}
|
|
||||||
resEcho := client.EchoSync(args[0])
|
resEcho := client.EchoSync(args[0])
|
||||||
printResponse(c, response{
|
printResponse(cmd, args, response{
|
||||||
Data: resEcho.Data,
|
Data: resEcho.Data,
|
||||||
})
|
})
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get some info from the application
|
// Get some info from the application
|
||||||
func cmdInfo(c *cli.Context) error {
|
func cmdInfo(cmd *cobra.Command, args []string) error {
|
||||||
args := c.Args()
|
|
||||||
var version string
|
var version string
|
||||||
if len(args) == 1 {
|
if len(args) == 1 {
|
||||||
version = args[0]
|
version = args[0]
|
||||||
@ -259,37 +330,29 @@ func cmdInfo(c *cli.Context) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
printResponse(c, response{
|
printResponse(cmd, args, response{
|
||||||
Data: []byte(resInfo.Data),
|
Data: []byte(resInfo.Data),
|
||||||
})
|
})
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set an option on the application
|
// Set an option on the application
|
||||||
func cmdSetOption(c *cli.Context) error {
|
func cmdSetOption(cmd *cobra.Command, args []string) error {
|
||||||
args := c.Args()
|
|
||||||
if len(args) != 2 {
|
|
||||||
return errors.New("Command set_option takes 2 arguments (key, value)")
|
|
||||||
}
|
|
||||||
resSetOption := client.SetOptionSync(args[0], args[1])
|
resSetOption := client.SetOptionSync(args[0], args[1])
|
||||||
printResponse(c, response{
|
printResponse(cmd, args, response{
|
||||||
Log: resSetOption.Log,
|
Log: resSetOption.Log,
|
||||||
})
|
})
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Append a new tx to application
|
// Append a new tx to application
|
||||||
func cmdDeliverTx(c *cli.Context) error {
|
func cmdDeliverTx(cmd *cobra.Command, args []string) error {
|
||||||
args := c.Args()
|
txBytes, err := stringOrHexToBytes(args[0])
|
||||||
if len(args) != 1 {
|
|
||||||
return errors.New("Command deliver_tx takes 1 argument")
|
|
||||||
}
|
|
||||||
txBytes, err := stringOrHexToBytes(c.Args()[0])
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
res := client.DeliverTxSync(txBytes)
|
res := client.DeliverTxSync(txBytes)
|
||||||
printResponse(c, response{
|
printResponse(cmd, args, response{
|
||||||
Code: res.Code,
|
Code: res.Code,
|
||||||
Data: res.Data,
|
Data: res.Data,
|
||||||
Log: res.Log,
|
Log: res.Log,
|
||||||
@ -298,17 +361,13 @@ func cmdDeliverTx(c *cli.Context) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Validate a tx
|
// Validate a tx
|
||||||
func cmdCheckTx(c *cli.Context) error {
|
func cmdCheckTx(cmd *cobra.Command, args []string) error {
|
||||||
args := c.Args()
|
txBytes, err := stringOrHexToBytes(args[0])
|
||||||
if len(args) != 1 {
|
|
||||||
return errors.New("Command check_tx takes 1 argument")
|
|
||||||
}
|
|
||||||
txBytes, err := stringOrHexToBytes(c.Args()[0])
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
res := client.CheckTxSync(txBytes)
|
res := client.CheckTxSync(txBytes)
|
||||||
printResponse(c, response{
|
printResponse(cmd, args, response{
|
||||||
Code: res.Code,
|
Code: res.Code,
|
||||||
Data: res.Data,
|
Data: res.Data,
|
||||||
Log: res.Log,
|
Log: res.Log,
|
||||||
@ -317,9 +376,9 @@ func cmdCheckTx(c *cli.Context) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Get application Merkle root hash
|
// Get application Merkle root hash
|
||||||
func cmdCommit(c *cli.Context) error {
|
func cmdCommit(cmd *cobra.Command, args []string) error {
|
||||||
res := client.CommitSync()
|
res := client.CommitSync()
|
||||||
printResponse(c, response{
|
printResponse(cmd, args, response{
|
||||||
Code: res.Code,
|
Code: res.Code,
|
||||||
Data: res.Data,
|
Data: res.Data,
|
||||||
Log: res.Log,
|
Log: res.Log,
|
||||||
@ -328,22 +387,12 @@ func cmdCommit(c *cli.Context) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Query application state
|
// Query application state
|
||||||
func cmdQuery(c *cli.Context) error {
|
func cmdQuery(cmd *cobra.Command, args []string) error {
|
||||||
args := c.Args()
|
|
||||||
|
|
||||||
if len(args) != 1 {
|
|
||||||
return errors.New("Command query takes 1 argument, the query bytes")
|
|
||||||
}
|
|
||||||
|
|
||||||
queryBytes, err := stringOrHexToBytes(args[0])
|
queryBytes, err := stringOrHexToBytes(args[0])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
path := c.String("path")
|
|
||||||
height := c.Int("height")
|
|
||||||
prove := c.Bool("prove")
|
|
||||||
|
|
||||||
resQuery, err := client.QuerySync(types.RequestQuery{
|
resQuery, err := client.QuerySync(types.RequestQuery{
|
||||||
Data: queryBytes,
|
Data: queryBytes,
|
||||||
Path: path,
|
Path: path,
|
||||||
@ -353,7 +402,7 @@ func cmdQuery(c *cli.Context) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
printResponse(c, response{
|
printResponse(cmd, args, response{
|
||||||
Code: resQuery.Code,
|
Code: resQuery.Code,
|
||||||
Log: resQuery.Log,
|
Log: resQuery.Log,
|
||||||
Query: &queryResponse{
|
Query: &queryResponse{
|
||||||
@ -366,22 +415,78 @@ func cmdQuery(c *cli.Context) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func cmdCounter(cmd *cobra.Command, args []string) error {
|
||||||
|
|
||||||
|
app := counter.NewCounterApplication(serial)
|
||||||
|
|
||||||
|
logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout))
|
||||||
|
|
||||||
|
// Start the listener
|
||||||
|
srv, err := server.NewServer(addrC, abci, app)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
srv.SetLogger(logger.With("module", "abci-server"))
|
||||||
|
if _, err := srv.Start(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wait forever
|
||||||
|
cmn.TrapSignal(func() {
|
||||||
|
// Cleanup
|
||||||
|
srv.Stop()
|
||||||
|
})
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func cmdDummy(cmd *cobra.Command, args []string) error {
|
||||||
|
logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout))
|
||||||
|
|
||||||
|
// Create the application - in memory or persisted to disk
|
||||||
|
var app types.Application
|
||||||
|
if persist == "" {
|
||||||
|
app = dummy.NewDummyApplication()
|
||||||
|
} else {
|
||||||
|
app = dummy.NewPersistentDummyApplication(persist)
|
||||||
|
app.(*dummy.PersistentDummyApplication).SetLogger(logger.With("module", "dummy"))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Start the listener
|
||||||
|
srv, err := server.NewServer(addrD, abci, app)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
srv.SetLogger(logger.With("module", "abci-server"))
|
||||||
|
if _, err := srv.Start(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wait forever
|
||||||
|
cmn.TrapSignal(func() {
|
||||||
|
// Cleanup
|
||||||
|
srv.Stop()
|
||||||
|
})
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------
|
||||||
|
|
||||||
func printResponse(c *cli.Context, rsp response) {
|
func printResponse(cmd *cobra.Command, args []string, rsp response) {
|
||||||
|
|
||||||
verbose := c.GlobalBool("verbose")
|
|
||||||
|
|
||||||
if verbose {
|
if verbose {
|
||||||
fmt.Println(">", c.Command.Name, strings.Join(c.Args(), " "))
|
fmt.Println(">", cmd.Use, strings.Join(args, " "))
|
||||||
}
|
}
|
||||||
|
|
||||||
if !rsp.Code.IsOK() {
|
// Always print the status code.
|
||||||
fmt.Printf("-> code: %s\n", rsp.Code.String())
|
fmt.Printf("-> code: %s\n", rsp.Code.String())
|
||||||
}
|
|
||||||
if len(rsp.Data) != 0 {
|
if len(rsp.Data) != 0 {
|
||||||
fmt.Printf("-> data: %s\n", rsp.Data)
|
// Do no print this line when using the commit command
|
||||||
fmt.Printf("-> data.hex: %X\n", rsp.Data)
|
// because the string comes out as gibberish
|
||||||
|
if cmd.Use != "commit" {
|
||||||
|
fmt.Printf("-> data: %s\n", rsp.Data)
|
||||||
|
}
|
||||||
|
fmt.Printf("-> data.hex: 0x%X\n", rsp.Data)
|
||||||
}
|
}
|
||||||
if rsp.Log != "" {
|
if rsp.Log != "" {
|
||||||
fmt.Printf("-> log: %s\n", rsp.Log)
|
fmt.Printf("-> log: %s\n", rsp.Log)
|
||||||
@ -401,11 +506,6 @@ func printResponse(c *cli.Context, rsp response) {
|
|||||||
fmt.Printf("-> proof: %X\n", rsp.Query.Proof)
|
fmt.Printf("-> proof: %X\n", rsp.Query.Proof)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if verbose {
|
|
||||||
fmt.Println("")
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// NOTE: s is interpreted as a string unless prefixed with 0x
|
// NOTE: s is interpreted as a string unless prefixed with 0x
|
||||||
|
5
cmd/abci-cli/main.go
Normal file
5
cmd/abci-cli/main.go
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
Execute()
|
||||||
|
}
|
@ -1,41 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"flag"
|
|
||||||
"os"
|
|
||||||
|
|
||||||
"github.com/tendermint/abci/example/counter"
|
|
||||||
"github.com/tendermint/abci/server"
|
|
||||||
cmn "github.com/tendermint/tmlibs/common"
|
|
||||||
"github.com/tendermint/tmlibs/log"
|
|
||||||
)
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
|
|
||||||
addrPtr := flag.String("addr", "tcp://0.0.0.0:46658", "Listen address")
|
|
||||||
abciPtr := flag.String("abci", "socket", "ABCI server: socket | grpc")
|
|
||||||
serialPtr := flag.Bool("serial", false, "Enforce incrementing (serial) txs")
|
|
||||||
flag.Parse()
|
|
||||||
app := counter.NewCounterApplication(*serialPtr)
|
|
||||||
|
|
||||||
logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout))
|
|
||||||
|
|
||||||
// Start the listener
|
|
||||||
srv, err := server.NewServer(*addrPtr, *abciPtr, app)
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err.Error())
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
srv.SetLogger(logger.With("module", "abci-server"))
|
|
||||||
if _, err := srv.Start(); err != nil {
|
|
||||||
logger.Error(err.Error())
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Wait forever
|
|
||||||
cmn.TrapSignal(func() {
|
|
||||||
// Cleanup
|
|
||||||
srv.Stop()
|
|
||||||
})
|
|
||||||
|
|
||||||
}
|
|
@ -1,50 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"flag"
|
|
||||||
"os"
|
|
||||||
|
|
||||||
"github.com/tendermint/abci/example/dummy"
|
|
||||||
"github.com/tendermint/abci/server"
|
|
||||||
"github.com/tendermint/abci/types"
|
|
||||||
cmn "github.com/tendermint/tmlibs/common"
|
|
||||||
"github.com/tendermint/tmlibs/log"
|
|
||||||
)
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
|
|
||||||
addrPtr := flag.String("addr", "tcp://0.0.0.0:46658", "Listen address")
|
|
||||||
abciPtr := flag.String("abci", "socket", "socket | grpc")
|
|
||||||
persistencePtr := flag.String("persist", "", "directory to use for a database")
|
|
||||||
flag.Parse()
|
|
||||||
|
|
||||||
logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout))
|
|
||||||
|
|
||||||
// Create the application - in memory or persisted to disk
|
|
||||||
var app types.Application
|
|
||||||
if *persistencePtr == "" {
|
|
||||||
app = dummy.NewDummyApplication()
|
|
||||||
} else {
|
|
||||||
app = dummy.NewPersistentDummyApplication(*persistencePtr)
|
|
||||||
app.(*dummy.PersistentDummyApplication).SetLogger(logger.With("module", "dummy"))
|
|
||||||
}
|
|
||||||
|
|
||||||
// Start the listener
|
|
||||||
srv, err := server.NewServer(*addrPtr, *abciPtr, app)
|
|
||||||
if err != nil {
|
|
||||||
logger.Error(err.Error())
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
srv.SetLogger(logger.With("module", "abci-server"))
|
|
||||||
if _, err := srv.Start(); err != nil {
|
|
||||||
logger.Error(err.Error())
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Wait forever
|
|
||||||
cmn.TrapSignal(func() {
|
|
||||||
// Cleanup
|
|
||||||
srv.Stop()
|
|
||||||
})
|
|
||||||
|
|
||||||
}
|
|
14
glide.lock
generated
14
glide.lock
generated
@ -1,5 +1,5 @@
|
|||||||
hash: 876bc65024f66612325ebafcedeb3e4d5014d46b339cf7583f1c00c6bac6e32c
|
hash: 3c8680f0a289567a29f737be5f1d5f242c7e2afd84bdd023dd74596b88508fc2
|
||||||
updated: 2017-10-23T14:04:02.596189966+02:00
|
updated: 2017-10-26T08:45:51.300025559-04:00
|
||||||
imports:
|
imports:
|
||||||
- name: github.com/btcsuite/btcd
|
- name: github.com/btcsuite/btcd
|
||||||
version: b8df516b4b267acf2de46be593a9d948d1d2c420
|
version: b8df516b4b267acf2de46be593a9d948d1d2c420
|
||||||
@ -30,12 +30,18 @@ imports:
|
|||||||
- ptypes/any
|
- ptypes/any
|
||||||
- name: github.com/golang/snappy
|
- name: github.com/golang/snappy
|
||||||
version: 553a641470496b2327abcac10b36396bd98e45c9
|
version: 553a641470496b2327abcac10b36396bd98e45c9
|
||||||
|
- name: github.com/inconshreveable/mousetrap
|
||||||
|
version: 76626ae9c91c4f2a10f34cad8ce83ea42c93bb75
|
||||||
- name: github.com/jmhodges/levigo
|
- name: github.com/jmhodges/levigo
|
||||||
version: c42d9e0ca023e2198120196f842701bb4c55d7b9
|
version: c42d9e0ca023e2198120196f842701bb4c55d7b9
|
||||||
- name: github.com/kr/logfmt
|
- name: github.com/kr/logfmt
|
||||||
version: b84e30acd515aadc4b783ad4ff83aff3299bdfe0
|
version: b84e30acd515aadc4b783ad4ff83aff3299bdfe0
|
||||||
- name: github.com/pkg/errors
|
- name: github.com/pkg/errors
|
||||||
version: 645ef00459ed84a119197bfb8d8205042c6df63d
|
version: 645ef00459ed84a119197bfb8d8205042c6df63d
|
||||||
|
- name: github.com/spf13/cobra
|
||||||
|
version: 2df9a531813370438a4d79bfc33e21f58063ed87
|
||||||
|
- name: github.com/spf13/pflag
|
||||||
|
version: e57e3eeb33f795204c1ca35f56c44f83227c6e66
|
||||||
- name: github.com/syndtr/goleveldb
|
- name: github.com/syndtr/goleveldb
|
||||||
version: 8c81ea47d4c41a385645e133e15510fc6a2a74b4
|
version: 8c81ea47d4c41a385645e133e15510fc6a2a74b4
|
||||||
subpackages:
|
subpackages:
|
||||||
@ -63,7 +69,7 @@ imports:
|
|||||||
subpackages:
|
subpackages:
|
||||||
- data
|
- data
|
||||||
- name: github.com/tendermint/iavl
|
- name: github.com/tendermint/iavl
|
||||||
version: 721710e7aa59f61dbfbf558943a207ba3fe6b926
|
version: 595f3dcd5b6cd4a292e90757ae6d367fd7a6e653
|
||||||
- name: github.com/tendermint/tmlibs
|
- name: github.com/tendermint/tmlibs
|
||||||
version: 8e5266a9ef2527e68a1571f932db8228a331b556
|
version: 8e5266a9ef2527e68a1571f932db8228a331b556
|
||||||
subpackages:
|
subpackages:
|
||||||
@ -72,8 +78,6 @@ imports:
|
|||||||
- log
|
- log
|
||||||
- merkle
|
- merkle
|
||||||
- process
|
- process
|
||||||
- name: github.com/urfave/cli
|
|
||||||
version: 7bc6a0acffa589f415f88aca16cc1de5ffd66f9c
|
|
||||||
- name: golang.org/x/crypto
|
- name: golang.org/x/crypto
|
||||||
version: c7af5bf2638a1164f2eb5467c39c6cffbd13a02e
|
version: c7af5bf2638a1164f2eb5467c39c6cffbd13a02e
|
||||||
subpackages:
|
subpackages:
|
||||||
|
@ -18,7 +18,8 @@ import:
|
|||||||
- log
|
- log
|
||||||
- merkle
|
- merkle
|
||||||
- process
|
- process
|
||||||
- package: github.com/urfave/cli
|
- package: github.com/spf13/cobra
|
||||||
|
version: master
|
||||||
- package: golang.org/x/net
|
- package: golang.org/x/net
|
||||||
subpackages:
|
subpackages:
|
||||||
- context
|
- context
|
||||||
|
@ -24,30 +24,28 @@ make tools
|
|||||||
# Get VENDORED dependencies
|
# Get VENDORED dependencies
|
||||||
make get_vendor_deps
|
make get_vendor_deps
|
||||||
|
|
||||||
BINARIES=( "abci-cli" "dummy" "counter" )
|
BINARY="abci-cli"
|
||||||
|
|
||||||
for binary in ${BINARIES[@]}; do
|
# Build!
|
||||||
# Build!
|
echo "==> Building..."
|
||||||
echo "==> Building..."
|
"$(which gox)" \
|
||||||
"$(which gox)" \
|
-os="${XC_OS}" \
|
||||||
-os="${XC_OS}" \
|
-arch="${XC_ARCH}" \
|
||||||
-arch="${XC_ARCH}" \
|
-osarch="!darwin/arm !solaris/amd64 !freebsd/amd64" \
|
||||||
-osarch="!darwin/arm !solaris/amd64 !freebsd/amd64" \
|
-ldflags "-X ${GIT_IMPORT}.GitCommit='${GIT_COMMIT}' -X ${GIT_IMPORT}.GitDescribe='${GIT_DESCRIBE}'" \
|
||||||
-ldflags "-X ${GIT_IMPORT}.GitCommit='${GIT_COMMIT}' -X ${GIT_IMPORT}.GitDescribe='${GIT_DESCRIBE}'" \
|
-output "build/pkg/{{.OS}}_{{.Arch}}/$BINARY" \
|
||||||
-output "build/pkg/{{.OS}}_{{.Arch}}/$binary" \
|
-tags="${BUILD_TAGS}" \
|
||||||
-tags="${BUILD_TAGS}" \
|
github.com/tendermint/abci/cmd/$BINARY
|
||||||
github.com/tendermint/abci/cmd/$binary
|
|
||||||
|
|
||||||
# Zip all the files.
|
# Zip all the files.
|
||||||
echo "==> Packaging..."
|
echo "==> Packaging..."
|
||||||
for PLATFORM in $(find ./build/pkg -mindepth 1 -maxdepth 1 -type d); do
|
for PLATFORM in $(find ./build/pkg -mindepth 1 -maxdepth 1 -type d); do
|
||||||
OSARCH=$(basename "${PLATFORM}")
|
OSARCH=$(basename "${PLATFORM}")
|
||||||
echo "--> ${OSARCH}"
|
echo "--> ${OSARCH}"
|
||||||
|
|
||||||
pushd "$PLATFORM" >/dev/null 2>&1
|
pushd "$PLATFORM" >/dev/null 2>&1
|
||||||
zip "../${OSARCH}.zip" ./*
|
zip "../${OSARCH}.zip" ./*
|
||||||
popd >/dev/null 2>&1
|
popd >/dev/null 2>&1
|
||||||
done
|
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,36 +1,44 @@
|
|||||||
> echo hello
|
> echo hello
|
||||||
|
-> code: OK
|
||||||
-> data: hello
|
-> data: hello
|
||||||
-> data.hex: 68656C6C6F
|
-> data.hex: 0x68656C6C6F
|
||||||
|
|
||||||
> info
|
> info
|
||||||
|
-> code: OK
|
||||||
-> data: {"size":0}
|
-> data: {"size":0}
|
||||||
-> data.hex: 7B2273697A65223A307D
|
-> data.hex: 0x7B2273697A65223A307D
|
||||||
|
|
||||||
> commit
|
> commit
|
||||||
|
-> code: OK
|
||||||
|
|
||||||
> deliver_tx "abc"
|
> deliver_tx "abc"
|
||||||
|
-> code: OK
|
||||||
|
|
||||||
> info
|
> info
|
||||||
|
-> code: OK
|
||||||
-> data: {"size":1}
|
-> data: {"size":1}
|
||||||
-> data.hex: 7B2273697A65223A317D
|
-> data.hex: 0x7B2273697A65223A317D
|
||||||
|
|
||||||
> commit
|
> commit
|
||||||
-> data: IßÑ\ͬޮ—(ËûµèhŒ¥‹‘
|
-> code: OK
|
||||||
-> data.hex: 49DFD15CCDACDEAE9728CB01FBB5E8688CA58B91
|
-> data.hex: 0x49DFD15CCDACDEAE9728CB01FBB5E8688CA58B91
|
||||||
|
|
||||||
> query "abc"
|
> query "abc"
|
||||||
|
-> code: OK
|
||||||
-> log: exists
|
-> log: exists
|
||||||
-> height: 0
|
-> height: 0
|
||||||
-> value: abc
|
-> value: abc
|
||||||
-> value.hex: 616263
|
-> value.hex: 616263
|
||||||
|
|
||||||
> deliver_tx "def=xyz"
|
> deliver_tx "def=xyz"
|
||||||
|
-> code: OK
|
||||||
|
|
||||||
> commit
|
> commit
|
||||||
-> data: p-³"€7?¿?Ÿ‰Ú* Î,Ö+
|
-> code: OK
|
||||||
-> data.hex: 70102DB32280373FBF3F9F89DA2A20CE2CD62B0B
|
-> data.hex: 0x70102DB32280373FBF3F9F89DA2A20CE2CD62B0B
|
||||||
|
|
||||||
> query "def"
|
> query "def"
|
||||||
|
-> code: OK
|
||||||
-> log: exists
|
-> log: exists
|
||||||
-> height: 0
|
-> height: 0
|
||||||
-> value: xyz
|
-> value: xyz
|
||||||
|
@ -1,22 +1,28 @@
|
|||||||
> set_option serial on
|
> set_option serial on
|
||||||
|
-> code: OK
|
||||||
|
|
||||||
> check_tx 0x00
|
> check_tx 0x00
|
||||||
|
-> code: OK
|
||||||
|
|
||||||
> check_tx 0xff
|
> check_tx 0xff
|
||||||
|
-> code: OK
|
||||||
|
|
||||||
> deliver_tx 0x00
|
> deliver_tx 0x00
|
||||||
|
-> code: OK
|
||||||
|
|
||||||
> check_tx 0x00
|
> check_tx 0x00
|
||||||
-> code: BadNonce
|
-> code: BadNonce
|
||||||
-> log: Invalid nonce. Expected >= 1, got 0
|
-> log: Invalid nonce. Expected >= 1, got 0
|
||||||
|
|
||||||
> deliver_tx 0x01
|
> deliver_tx 0x01
|
||||||
|
-> code: OK
|
||||||
|
|
||||||
> deliver_tx 0x04
|
> deliver_tx 0x04
|
||||||
-> code: BadNonce
|
-> code: BadNonce
|
||||||
-> log: Invalid nonce. Expected 2, got 4
|
-> log: Invalid nonce. Expected 2, got 4
|
||||||
|
|
||||||
> info
|
> info
|
||||||
|
-> code: OK
|
||||||
-> data: {"hashes":0,"txs":2}
|
-> data: {"hashes":0,"txs":2}
|
||||||
-> data.hex: 7B22686173686573223A302C22747873223A327D
|
-> data.hex: 0x7B22686173686573223A302C22747873223A327D
|
||||||
|
|
||||||
|
@ -11,13 +11,13 @@ cd "$DIR" || exit
|
|||||||
function testExample() {
|
function testExample() {
|
||||||
N=$1
|
N=$1
|
||||||
INPUT=$2
|
INPUT=$2
|
||||||
APP=$3
|
APP="$3 $4"
|
||||||
|
|
||||||
echo "Example $N"
|
echo "Example $N: $APP"
|
||||||
$APP &> /dev/null &
|
$APP &> /dev/null &
|
||||||
sleep 2
|
sleep 2
|
||||||
abci-cli --verbose batch < "$INPUT" > "${INPUT}.out.new"
|
abci-cli --verbose batch < "$INPUT" > "${INPUT}.out.new"
|
||||||
killall "$APP"
|
killall $3
|
||||||
|
|
||||||
pre=$(shasum < "${INPUT}.out")
|
pre=$(shasum < "${INPUT}.out")
|
||||||
post=$(shasum < "${INPUT}.out.new")
|
post=$(shasum < "${INPUT}.out.new")
|
||||||
@ -34,8 +34,8 @@ function testExample() {
|
|||||||
rm "${INPUT}".out.new
|
rm "${INPUT}".out.new
|
||||||
}
|
}
|
||||||
|
|
||||||
testExample 1 tests/test_cli/ex1.abci dummy
|
testExample 1 tests/test_cli/ex1.abci abci-cli dummy
|
||||||
testExample 2 tests/test_cli/ex2.abci counter
|
testExample 2 tests/test_cli/ex2.abci abci-cli counter
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
echo "PASS"
|
echo "PASS"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user