cosmos-sdk/client/lcd/lcd_test.go

161 lines
4.2 KiB
Go
Raw Normal View History

2018-03-05 08:41:50 -08:00
package lcd
import (
"bytes"
"encoding/json"
"net/http"
"net/http/httptest"
"os"
"testing"
2018-03-08 06:50:12 -08:00
"github.com/cosmos/cosmos-sdk/baseapp"
2018-03-05 08:41:50 -08:00
"github.com/cosmos/cosmos-sdk/client"
keys "github.com/cosmos/cosmos-sdk/client/keys"
"github.com/cosmos/cosmos-sdk/examples/basecoin/app"
2018-03-08 06:50:12 -08:00
abci "github.com/tendermint/abci/types"
2018-03-05 08:41:50 -08:00
cryptoKeys "github.com/tendermint/go-crypto/keys"
2018-03-08 06:50:12 -08:00
"github.com/tendermint/tendermint/p2p"
2018-03-05 08:41:50 -08:00
dbm "github.com/tendermint/tmlibs/db"
2018-03-08 06:50:12 -08:00
"github.com/tendermint/tmlibs/log"
2018-03-05 08:41:50 -08:00
)
func TestKeys(t *testing.T) {
2018-03-08 06:50:12 -08:00
kb, db, err := initKeybase()
2018-03-05 08:41:50 -08:00
if err != nil {
t.Errorf("Couldn't init Keybase. Error $s", err.Error())
}
cdc := app.MakeCodec()
r := initRouter(cdc)
// empty keys
req, _ := http.NewRequest("GET", "/keys", nil)
res := httptest.NewRecorder()
r.ServeHTTP(res, req)
checkResponseCode(t, http.StatusOK, res.Code)
if body := res.Body.String(); body != "[]" {
t.Errorf("Expected an empty array. Got %s", body)
}
info, _, err := kb.Create("test", "1234567890", cryptoKeys.CryptoAlgo("ed25519"))
if err != nil {
t.Errorf("Couldn't add key. Error $s", err.Error())
}
// existing keys
req, _ = http.NewRequest("GET", "/keys", nil)
res = httptest.NewRecorder()
r.ServeHTTP(res, req)
checkResponseCode(t, http.StatusOK, res.Code)
var m [1]keys.KeyOutput
decoder := json.NewDecoder(res.Body)
err = decoder.Decode(&m)
if m[0].Name != "test" {
t.Errorf("Did not serve keys name correctly. Got %s", m[0].Name)
}
if m[0].Address != info.PubKey.Address().String() {
t.Errorf("Did not serve keys Address correctly. Got %s, Expected %s", m[0].Address, info.PubKey.Address().String())
}
// select key
req, _ = http.NewRequest("GET", "/keys/test", nil)
res = httptest.NewRecorder()
r.ServeHTTP(res, req)
checkResponseCode(t, http.StatusOK, res.Code)
var m2 keys.KeyOutput
decoder = json.NewDecoder(res.Body)
err = decoder.Decode(&m2)
if m2.Name != "test" {
t.Errorf("Did not serve keys name correctly. Got %s", m2.Name)
}
if m2.Address != info.PubKey.Address().String() {
t.Errorf("Did not serve keys Address correctly. Got %s, Expected %s", m2.Address, info.PubKey.Address().String())
}
// update key
var jsonStr = []byte(`{"old_password":"1234567890", "new_password":"12345678901"}`)
req, _ = http.NewRequest("PUT", "/keys/test", bytes.NewBuffer(jsonStr))
res = httptest.NewRecorder()
r.ServeHTTP(res, req)
checkResponseCode(t, http.StatusOK, res.Code)
// here it should say unauthorized as we changed the password before
req, _ = http.NewRequest("PUT", "/keys/test", bytes.NewBuffer(jsonStr))
res = httptest.NewRecorder()
r.ServeHTTP(res, req)
checkResponseCode(t, http.StatusUnauthorized, res.Code)
// delete key
jsonStr = []byte(`{"password":"12345678901"}`)
req, _ = http.NewRequest("DELETE", "/keys/test", bytes.NewBuffer(jsonStr))
res = httptest.NewRecorder()
r.ServeHTTP(res, req)
checkResponseCode(t, http.StatusOK, res.Code)
2018-03-08 06:50:12 -08:00
db.Close()
}
func TestNodeInfo(t *testing.T) {
prepareApp(t)
_, db, err := initKeybase()
if err != nil {
t.Errorf("Couldn't init Keybase. Error $s", err.Error())
}
cdc := app.MakeCodec()
r := initRouter(cdc)
req, _ := http.NewRequest("GET", "/node_info", nil)
res := httptest.NewRecorder()
r.ServeHTTP(res, req)
checkResponseCode(t, http.StatusOK, res.Code)
var m p2p.NodeInfo
decoder := json.NewDecoder(res.Body)
err = decoder.Decode(&m)
if err != nil {
t.Errorf("Couldn't parse node info, Got %s", res.Body.String())
}
db.Close()
}
func defaultLogger() log.Logger {
return log.NewTMLogger(log.NewSyncWriter(os.Stdout)).With("module", "sdk/app")
}
func prepareApp(t *testing.T) {
logger := defaultLogger()
db := dbm.NewMemDB()
name := t.Name()
app := baseapp.NewBaseApp(name, logger, db)
header := abci.Header{Height: 1}
app.BeginBlock(abci.RequestBeginBlock{Header: header})
app.Commit()
2018-03-05 08:41:50 -08:00
}
2018-03-08 06:50:12 -08:00
func initKeybase() (cryptoKeys.Keybase, *dbm.GoLevelDB, error) {
2018-03-05 08:41:50 -08:00
os.RemoveAll("./testKeybase")
db, err := dbm.NewGoLevelDB("keys", "./testKeybase")
if err != nil {
2018-03-08 06:50:12 -08:00
return nil, nil, err
2018-03-05 08:41:50 -08:00
}
kb := client.GetKeyBase(db)
keys.SetKeyBase(kb)
2018-03-08 06:50:12 -08:00
return kb, db, nil
2018-03-05 08:41:50 -08:00
}
func checkResponseCode(t *testing.T, expected, actual int) {
if expected != actual {
t.Errorf("Expected response code %d. Got %d\n", expected, actual)
}
}