Documentation ¶
Overview ¶
Package mock implements an in-memory gRPC mock Ensign server that can be connected to using a bufconn. The mock is useful for testing client side code for publishers and subscribers without actually connecting to an Ensign server.
Index ¶
- Constants
- Variables
- func NewEvent() *api.Event
- func NewEventWrapper() *api.EventWrapper
- type DialOption
- type Ensign
- func (s *Ensign) Client(ctx context.Context, opts ...grpc.DialOption) (client api.EnsignClient, err error)
- func (s *Ensign) CreateTopic(ctx context.Context, in *api.Topic) (*api.Topic, error)
- func (s *Ensign) DeleteTopic(ctx context.Context, in *api.TopicMod) (*api.TopicTombstone, error)
- func (s *Ensign) EnSQL(in *api.Query, stream api.Ensign_EnSQLServer) error
- func (s *Ensign) Info(ctx context.Context, in *api.InfoRequest) (*api.ProjectInfo, error)
- func (s *Ensign) ListTopics(ctx context.Context, in *api.PageInfo) (*api.TopicsPage, error)
- func (s *Ensign) Publish(stream api.Ensign_PublishServer) error
- func (s *Ensign) Reset()
- func (s *Ensign) ResetClient(ctx context.Context, opts ...grpc.DialOption) (api.EnsignClient, error)
- func (s *Ensign) RetrieveTopic(ctx context.Context, in *api.Topic) (*api.Topic, error)
- func (s *Ensign) Shutdown()
- func (s *Ensign) Status(ctx context.Context, in *api.HealthCheck) (*api.ServiceState, error)
- func (s *Ensign) Subscribe(stream api.Ensign_SubscribeServer) error
- func (s *Ensign) TopicExists(ctx context.Context, in *api.TopicName) (*api.TopicExistsInfo, error)
- func (s *Ensign) TopicNames(ctx context.Context, in *api.PageInfo) (*api.TopicNamesPage, error)
- func (s *Ensign) UseError(rpc string, code codes.Code, msg string) error
- func (s *Ensign) UseFixture(rpc, path string) (err error)
- type EventFactory
- type Listener
- type PublishHandler
- type SubscribeHandler
Constants ¶
const ( PublishRPC = "/ensign.v1beta1.Ensign/Publish" SubscribeRPC = "/ensign.v1beta1.Ensign/Subscribe" EnSQLRPC = "/ensign.v1beta1.Ensign/EnSQL" ListTopicsRPC = "/ensign.v1beta1.Ensign/ListTopics" CreateTopicRPC = "/ensign.v1beta1.Ensign/CreateTopic" RetrieveTopicRPC = "/ensign.v1beta1.Ensign/RetrieveTopic" DeleteTopicRPC = "/ensign.v1beta1.Ensign/DeleteTopic" TopicNamesRPC = "/ensign.v1beta1.Ensign/TopicNames" TopicExistsRPC = "/ensign/v1beta1.Ensign/TopicExists" InfoRPC = "/ensign/v1beta1.Ensign/Info" StatusRPC = "/ensign.v1beta1.Ensign/Status" )
RPC Name constants based on the FullMethod that is returned from gRPC info. These constants can be used to reference RPCs in the mock code.
Variables ¶
Functions ¶
func NewEventWrapper ¶ added in v0.7.0
func NewEventWrapper() *api.EventWrapper
NewEventWrapper returns an event wrapper with random data inside. It is a quick method to create an event for the default "testing.123" topic.
Types ¶
type DialOption ¶
type DialOption func(*Listener)
DialOption -- optional arguments for constructing a Listener.
func WithBuffer ¶
func WithBuffer(sock *bufconn.Listener) DialOption
Allows you to pass an already instantiated grpc bufconn.Listener into the Listener.
func WithBufferSize ¶
func WithBufferSize(size int) DialOption
The default buffer size is 1MiB -- if ou need a larger buffer to send larger messages then specify this dial option with a larger size.
func WithTarget ¶
func WithTarget(target string) DialOption
WithTarget allows the user to change the "endpoint" of the connection from "bufnet" to some other endpoint. This is useful for tests that include mTLS to ensure that TLS certificate handling is correct.
type Ensign ¶
type Ensign struct { sync.RWMutex api.UnimplementedEnsignServer Calls map[string]int OnPublish func(api.Ensign_PublishServer) error OnSubscribe func(api.Ensign_SubscribeServer) error OnEnSQL func(*api.Query, api.Ensign_EnSQLServer) error OnListTopics func(context.Context, *api.PageInfo) (*api.TopicsPage, error) OnCreateTopic func(context.Context, *api.Topic) (*api.Topic, error) OnRetrieveTopic func(context.Context, *api.Topic) (*api.Topic, error) OnDeleteTopic func(context.Context, *api.TopicMod) (*api.TopicTombstone, error) OnTopicNames func(context.Context, *api.PageInfo) (*api.TopicNamesPage, error) OnTopicExists func(context.Context, *api.TopicName) (*api.TopicExistsInfo, error) OnInfo func(context.Context, *api.InfoRequest) (*api.ProjectInfo, error) OnStatus func(context.Context, *api.HealthCheck) (*api.ServiceState, error) // contains filtered or unexported fields }
Implements a mock gRPC server for testing Ensign client connections. The desired response of the Ensign server can be set by test users using the OnRPC functions or the WithFixture or WithError methods. The Calls map can be used to count the number of times a specific RPC was called.
func New ¶
func New(bufnet *Listener, opts ...grpc.ServerOption) *Ensign
New creates a mock Ensign server for testing Ensign responses to RPC calls. If the bufnet is nil, the default bufconn is created for use in testing. Arbitrary server options (e.g. for authentication or to add interceptors) can be passed in as well.
func (*Ensign) Client ¶
func (s *Ensign) Client(ctx context.Context, opts ...grpc.DialOption) (client api.EnsignClient, err error)
Create and connect an Ensign client to the mock server
func (*Ensign) CreateTopic ¶
func (*Ensign) DeleteTopic ¶
func (*Ensign) Info ¶ added in v0.7.0
func (s *Ensign) Info(ctx context.Context, in *api.InfoRequest) (*api.ProjectInfo, error)
func (*Ensign) ListTopics ¶
func (*Ensign) Reset ¶
func (s *Ensign) Reset()
Reset the calls map and all associated handlers in preparation for a new test.
func (*Ensign) ResetClient ¶
func (s *Ensign) ResetClient(ctx context.Context, opts ...grpc.DialOption) (api.EnsignClient, error)
Reset the client with the new dial options
func (*Ensign) RetrieveTopic ¶ added in v0.6.0
func (*Ensign) Shutdown ¶
func (s *Ensign) Shutdown()
Shutdown the sever and cleanup (cannot be used after shutdown)
func (*Ensign) Status ¶
func (s *Ensign) Status(ctx context.Context, in *api.HealthCheck) (*api.ServiceState, error)
func (*Ensign) TopicExists ¶ added in v0.6.0
func (*Ensign) TopicNames ¶ added in v0.6.0
func (*Ensign) UseError ¶
UseError allows you to specify a gRPC status error to return from the specified RPC.
func (*Ensign) UseFixture ¶
UseFixture loads a JSON fixture from disk (usually in the testdata folder) to use as the protocol buffer response to the specified RPC, simplifying handler mocking.
type EventFactory ¶ added in v0.7.0
type EventFactory struct { sync.Mutex Topic ulid.ULID Region region.Region // contains filtered or unexported fields }
EventFactory creates random events with standard defaults.
func (*EventFactory) Event ¶ added in v0.7.0
func (f *EventFactory) Event() *api.Event
func (*EventFactory) Make ¶ added in v0.7.0
func (f *EventFactory) Make() *api.EventWrapper
type Listener ¶
type Listener struct {
// contains filtered or unexported fields
}
Listener handles gRPC connections using an in-memory buffer that is useful for testing to prevent actual TCP network requests. Using a bufconn connection provides the most realistic gRPC server for tests that include serialization and deserialization of protocol buffers and an actual wire transfer between client and server. We prefer to use the bufconn over simply making method calls to the handlers.
func NewBufConn ¶
func NewBufConn(opts ...DialOption) *Listener
New creates a bufconn listener ready to attach servers and clients to. To provide a different target name (e.g. for mTLS buffers) use the WithTarget() dial option. You can also specify a different buffer size using WithBufferSize() or pass in an already instantiated bufconn.Listener using WithBuffer().
func (*Listener) Close ¶
Close the bufconn listener and prevent either clients or servers from communicating.
func (*Listener) Connect ¶
func (l *Listener) Connect(ctx context.Context, opts ...grpc.DialOption) (cc *grpc.ClientConn, err error)
Connect returns the client side of the bufconn connection.
type PublishHandler ¶ added in v0.7.0
type PublishHandler struct { OnInitialize func(in *api.OpenStream) (out *api.StreamReady, err error) OnEvent func(in *api.EventWrapper) (out *api.PublisherReply, err error) }
PublishHandler provides an OnPublish function that assists in the testing of publish streams by breaking down the initialization and messaging phase of the publisher stream. For example, this handler can be used to ensure that a specific number of events get published or to send acks or nacks to specific events.
func NewPublishHandler ¶ added in v0.7.0
func NewPublishHandler(topics map[string]ulid.ULID) *PublishHandler
By default new publish handlers ack all events and return the specified topic map.
func (*PublishHandler) OnPublish ¶ added in v0.7.0
func (s *PublishHandler) OnPublish(stream api.Ensign_PublishServer) (err error)
type SubscribeHandler ¶ added in v0.7.0
type SubscribeHandler struct { OnInitialize func(in *api.Subscription) (out *api.StreamReady, err error) OnAck func(in *api.Ack) (err error) OnNack func(in *api.Nack) (err error) Send chan<- *api.EventWrapper // contains filtered or unexported fields }
SubscribeHandler provides an OnSubscribe function that assists in the testing of subscribe streams by breaking down the initialization and messaging phases of the subscription stream. For example, this handler can be used to send 10 events before quitting or to send events at a routine interval.
func NewSubscribeHandler ¶ added in v0.7.0
func NewSubscribeHandler() *SubscribeHandler
func (*SubscribeHandler) OnSubscribe ¶ added in v0.7.0
func (s *SubscribeHandler) OnSubscribe(stream api.Ensign_SubscribeServer) (err error)
This method should be added to the mock as the OnSubscribe handler.
func (*SubscribeHandler) Shutdown ¶ added in v0.7.0
func (s *SubscribeHandler) Shutdown()
Shutdown the stream by sending a close stream message
func (*SubscribeHandler) UseTopicMap ¶ added in v0.7.0
func (s *SubscribeHandler) UseTopicMap(topics map[string]ulid.ULID)
UseTopicMap sets OnInitialize to use the topics in the topic map, returning an error if the subscription contains topics that are not in the topics map.