1
0
mirror of https://github.com/mainflux/mainflux.git synced 2025-04-27 13:48:49 +08:00
Washington Kigani Kamadi e2992cbede
NOISSUE - Change import name aliases (#1868)
* Change import name aliases

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Change import name aliases

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Change import aliases

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Remove unused aliases

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

Fix aliases

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

FIx errors

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

Fix error

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

FIx merge

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

FIx merge

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

FIx merge

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix import alias

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix errors

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix linter

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix linter

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix import

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Add linter to CI pipeline

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Changes

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Remove unused aliases

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix merge issues

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix gci

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix gci

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix gci

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Add gofumpt

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Remove multiple gofupmt in CI

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Remove unnecessary changes

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix linter

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

* Fix CI pipeline

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>

---------

Signed-off-by: WashingtonKK <washingtonkigan@gmail.com>
2023-08-11 11:30:25 +02:00

86 lines
1.8 KiB
Go

// Copyright (c) Mainflux
// SPDX-License-Identifier: Apache-2.0
package mocks
import (
"context"
"encoding/json"
"github.com/gorilla/websocket"
"github.com/mainflux/mainflux/pkg/messaging"
"github.com/mainflux/mainflux/ws"
)
var _ messaging.PubSub = (*mockPubSub)(nil)
type MockPubSub interface {
// Publish publishes message to the channel.
Publish(context.Context, string, *messaging.Message) error
// Subscribe subscribes messages from the channel.
Subscribe(context.Context, string, string, messaging.MessageHandler) error
// Unsubscribe unsubscribes messages from the channel.
Unsubscribe(context.Context, string, string) error
// SetFail sets the fail flag.
SetFail(bool)
// SetConn sets the connection.
SetConn(*websocket.Conn)
// Close closes the connection.
Close() error
}
type mockPubSub struct {
fail bool
conn *websocket.Conn
}
// NewPubSub returns mock message publisher-subscriber.
func NewPubSub() MockPubSub {
return &mockPubSub{false, nil}
}
func (pubsub *mockPubSub) Publish(ctx context.Context, s string, msg *messaging.Message) error {
if pubsub.conn != nil {
data, err := json.Marshal(msg)
if err != nil {
return ws.ErrFailedMessagePublish
}
return pubsub.conn.WriteMessage(websocket.BinaryMessage, data)
}
if pubsub.fail {
return ws.ErrFailedMessagePublish
}
return nil
}
func (pubsub *mockPubSub) Subscribe(context.Context, string, string, messaging.MessageHandler) error {
if pubsub.fail {
return ws.ErrFailedSubscription
}
return nil
}
func (pubsub *mockPubSub) Unsubscribe(context.Context, string, string) error {
if pubsub.fail {
return ws.ErrFailedUnsubscribe
}
return nil
}
func (pubsub *mockPubSub) SetFail(fail bool) {
pubsub.fail = fail
}
func (pubsub *mockPubSub) SetConn(c *websocket.Conn) {
pubsub.conn = c
}
func (pubsub *mockPubSub) Close() error {
return nil
}