|
|
- 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
- }
|