package mock
|
|
|
|
import (
|
|
"log"
|
|
"reflect"
|
|
|
|
gokitlog "github.com/go-kit/kit/log"
|
|
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
|
em "github.com/tendermint/tools/tm-monitor/eventmeter"
|
|
)
|
|
|
|
type EventMeter struct {
|
|
latencyCallback em.LatencyCallbackFunc
|
|
disconnectCallback em.DisconnectCallbackFunc
|
|
eventCallback em.EventCallbackFunc
|
|
}
|
|
|
|
func (e *EventMeter) Start() error { return nil }
|
|
func (e *EventMeter) Stop() {}
|
|
func (e *EventMeter) SetLogger(l gokitlog.Logger) {}
|
|
func (e *EventMeter) RegisterLatencyCallback(cb em.LatencyCallbackFunc) { e.latencyCallback = cb }
|
|
func (e *EventMeter) RegisterDisconnectCallback(cb em.DisconnectCallbackFunc) {
|
|
e.disconnectCallback = cb
|
|
}
|
|
func (e *EventMeter) Subscribe(eventID string, cb em.EventCallbackFunc) error {
|
|
e.eventCallback = cb
|
|
return nil
|
|
}
|
|
func (e *EventMeter) Unsubscribe(eventID string) error {
|
|
e.eventCallback = nil
|
|
return nil
|
|
}
|
|
|
|
func (e *EventMeter) Call(callback string, args ...interface{}) {
|
|
switch callback {
|
|
case "latencyCallback":
|
|
e.latencyCallback(args[0].(float64))
|
|
case "disconnectCallback":
|
|
e.disconnectCallback()
|
|
case "eventCallback":
|
|
e.eventCallback(args[0].(*em.EventMetric), args[1])
|
|
}
|
|
}
|
|
|
|
type RpcClient struct {
|
|
Stubs map[string]ctypes.TMResult
|
|
}
|
|
|
|
func (c *RpcClient) Call(method string, params map[string]interface{}, result interface{}) (interface{}, error) {
|
|
s, ok := c.Stubs[method]
|
|
if !ok {
|
|
log.Fatalf("Call to %s, but no stub is defined for it", method)
|
|
}
|
|
|
|
rv, rt := reflect.ValueOf(result), reflect.TypeOf(result)
|
|
rv, rt = rv.Elem(), rt.Elem()
|
|
rv.Set(reflect.ValueOf(s))
|
|
|
|
return s, nil
|
|
}
|