From 09dbde52454d862117675e88adc1110674f866a5 Mon Sep 17 00:00:00 2001 From: JeffMboya Date: Wed, 10 Apr 2024 15:15:43 +0300 Subject: [PATCH] Add mocks with mockery for mqtt Signed-off-by: JeffMboya --- mqtt/events/streams.go | 1 + mqtt/handler_test.go | 20 +++++++------- mqtt/mocks/redis.go | 62 +++++++++++++++++++++++++++++++++++------- 3 files changed, 63 insertions(+), 20 deletions(-) diff --git a/mqtt/events/streams.go b/mqtt/events/streams.go index ee03a243ab0..bd5325bd8c8 100644 --- a/mqtt/events/streams.go +++ b/mqtt/events/streams.go @@ -12,6 +12,7 @@ import ( const streamID = "magistrala.mqtt" +//go:generate mockery --name EventStore --output=../mocks --filename redis.go --quiet --note "Copyright (c) Abstract Machines" type EventStore interface { Connect(ctx context.Context, clientID string) error Disconnect(ctx context.Context, clientID string) error diff --git a/mqtt/handler_test.go b/mqtt/handler_test.go index 0dd52808e2e..8fe2b384e73 100644 --- a/mqtt/handler_test.go +++ b/mqtt/handler_test.go @@ -64,7 +64,7 @@ var ( ) func TestAuthConnect(t *testing.T) { - handler, _ := newHandler() + handler, _ := newHandler(t) cases := []struct { desc string @@ -117,7 +117,7 @@ func TestAuthConnect(t *testing.T) { } func TestAuthPublish(t *testing.T) { - handler, auth := newHandler() + handler, auth := newHandler(t) cases := []struct { desc string @@ -169,7 +169,7 @@ func TestAuthPublish(t *testing.T) { } func TestAuthSubscribe(t *testing.T) { - handler, auth := newHandler() + handler, auth := newHandler(t) cases := []struct { desc string @@ -222,7 +222,7 @@ func TestAuthSubscribe(t *testing.T) { } func TestConnect(t *testing.T) { - handler, _ := newHandler() + handler, _ := newHandler(t) logBuffer.Reset() cases := []struct { @@ -256,7 +256,7 @@ func TestConnect(t *testing.T) { } func TestPublish(t *testing.T) { - handler, _ := newHandler() + handler, _ := newHandler(t) logBuffer.Reset() malformedSubtopics := topic + "/" + subtopic + "%" @@ -335,7 +335,7 @@ func TestPublish(t *testing.T) { } func TestSubscribe(t *testing.T) { - handler, _ := newHandler() + handler, _ := newHandler(t) logBuffer.Reset() cases := []struct { @@ -371,7 +371,7 @@ func TestSubscribe(t *testing.T) { } func TestUnsubscribe(t *testing.T) { - handler, _ := newHandler() + handler, _ := newHandler(t) logBuffer.Reset() cases := []struct { @@ -407,7 +407,7 @@ func TestUnsubscribe(t *testing.T) { } func TestDisconnect(t *testing.T) { - handler, _ := newHandler() + handler, _ := newHandler(t) logBuffer.Reset() cases := []struct { @@ -442,12 +442,12 @@ func TestDisconnect(t *testing.T) { } } -func newHandler() (session.Handler, *authmocks.AuthClient) { +func newHandler(t *testing.T) (session.Handler, *authmocks.AuthClient) { logger, err := mglog.New(&logBuffer, "debug") if err != nil { log.Fatalf("failed to create logger: %s", err) } auth := new(authmocks.AuthClient) - eventStore := mocks.NewEventStore() + eventStore := mocks.NewEventStore(t) return mqtt.NewHandler(mocks.NewPublisher(), eventStore, logger, auth), auth } diff --git a/mqtt/mocks/redis.go b/mqtt/mocks/redis.go index be63be8a44c..d7ba830bad5 100644 --- a/mqtt/mocks/redis.go +++ b/mqtt/mocks/redis.go @@ -1,24 +1,66 @@ +// Code generated by mockery v2.42.1. DO NOT EDIT. + // Copyright (c) Abstract Machines -// SPDX-License-Identifier: Apache-2.0 package mocks import ( - "context" + context "context" - "github.com/absmach/magistrala/mqtt/events" + mock "github.com/stretchr/testify/mock" ) -type MockEventStore struct{} +// EventStore is an autogenerated mock type for the EventStore type +type EventStore struct { + mock.Mock +} + +// Connect provides a mock function with given fields: ctx, clientID +func (_m *EventStore) Connect(ctx context.Context, clientID string) error { + ret := _m.Called(ctx, clientID) + + if len(ret) == 0 { + panic("no return value specified for Connect") + } + + var r0 error + if rf, ok := ret.Get(0).(func(context.Context, string) error); ok { + r0 = rf(ctx, clientID) + } else { + r0 = ret.Error(0) + } -func NewEventStore() events.EventStore { - return MockEventStore{} + return r0 } -func (es MockEventStore) Connect(ctx context.Context, clientID string) error { - return nil +// Disconnect provides a mock function with given fields: ctx, clientID +func (_m *EventStore) Disconnect(ctx context.Context, clientID string) error { + ret := _m.Called(ctx, clientID) + + if len(ret) == 0 { + panic("no return value specified for Disconnect") + } + + var r0 error + if rf, ok := ret.Get(0).(func(context.Context, string) error); ok { + r0 = rf(ctx, clientID) + } else { + r0 = ret.Error(0) + } + + return r0 } -func (es MockEventStore) Disconnect(ctx context.Context, clientID string) error { - return nil +// NewEventStore creates a new instance of EventStore. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +// The first argument is typically a *testing.T value. +func NewEventStore(t interface { + mock.TestingT + Cleanup(func()) +}) *EventStore { + mock := &EventStore{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock }