1
0
mirror of https://github.com/mainflux/mainflux.git synced 2025-04-29 13:49:28 +08:00
Mainflux.mainflux/ws/adapter_test.go
beres 61b2d6b87b MF-596 - Add subtopic to RawMessage (#642)
* Commit for mainflux-596
Modified and tested:
- cli
- http
- mqtt
- normalizer
- all readers
- sdk messages
- all writers
- ws
Missing:
- coap
- lora

Signed-off-by: ale <ale@metaverso.org>

* - fix subtopic name in, when starting with dot, http/ws/mqtt
- add some test on readers

Signed-off-by: ale <ale@metaverso.org>

* - fix string concatenation
- update http/transport regexp to match subtopic names with only \w-
- update ws/transport regexp like http ones with also the wildcard * and >

Signed-off-by: ale <ale@metaverso.org>

* added subtopic support to coap adapter

Signed-off-by: ale <ale@metaverso.org>

* - update replace functions with replaceall when needed
- renamed getDestChannel to fmtSubject
- update api/transport and ws/transport route to be more readable
- fix mqtt syntax
- renamed func andQuery to query as suggested by @anovakovic01
- have a nice we :)

Signed-off-by: ale <ale@metaverso.org>

* - fix error declaration on ws/nat/publisher
- fix regexp added missing allowed chars - and _ on coap/api/transport
- fix subtopic clean suffix / if present on coap/api/transport
- improve regexp on http and ws /api/transport, now does not accept url that do not strictly match
- add some ws subtopic tests

Signed-off-by: ale <ale@metaverso.org>

* - enabled wildcard chars on coap/api/transport
- allow use special chars on http and ws api/transport

Signed-off-by: ale <ale@metaverso.org>

* - use strings.Replace() insted ReplaceAll()

Signed-off-by: ale <ale@metaverso.org>

* - allow every chars on subtopics
- fix replace error on mqtt

Signed-off-by: ale <ale@metaverso.org>

* fix cassandra test

Signed-off-by: ale <ale@metaverso.org>

* fix ws test with invalid subtopic

Signed-off-by: ale <ale@metaverso.org>

* fix invalid GOCACHE in go1.12, replaced by -count 1, see https://golang.org/doc/go1.10#test

Signed-off-by: ale <ale@metaverso.org>

* - improve regexp on http/ws api/transport
- minor changes

Signed-off-by: ale <ale@metaverso.org>

* - add generic function parseSubtopic on ws/http adapters

Signed-off-by: ale <ale@metaverso.org>

* - add generic function fmtSubtopic on coap adapter

Signed-off-by: ale <ale@metaverso.org>
2019-03-15 18:38:07 +01:00

124 lines
2.6 KiB
Go

//
// Copyright (c) 2018
// Mainflux
//
// SPDX-License-Identifier: Apache-2.0
//
package ws_test
import (
"fmt"
"testing"
"github.com/mainflux/mainflux/ws"
"github.com/mainflux/mainflux/ws/mocks"
broker "github.com/nats-io/go-nats"
"github.com/stretchr/testify/assert"
"github.com/mainflux/mainflux"
)
const (
chanID = "1"
pubID = "1"
protocol = "ws"
)
var msg = mainflux.RawMessage{
Channel: chanID,
Publisher: pubID,
Protocol: protocol,
Payload: []byte(`[{"n":"current","t":-5,"v":1.2}]`),
}
func newService(channel *ws.Channel) ws.Service {
subs := map[string]*ws.Channel{chanID: channel}
pubsub := mocks.NewService(subs, broker.ErrInvalidMsg)
return ws.New(pubsub)
}
func TestPublish(t *testing.T) {
channel := ws.NewChannel()
svc := newService(channel)
cases := []struct {
desc string
msg mainflux.RawMessage
err error
}{
{
desc: "publish valid message",
msg: msg,
err: nil,
},
{
desc: "publish empty message",
msg: mainflux.RawMessage{},
err: ws.ErrFailedMessagePublish,
},
}
for _, tc := range cases {
// Check if message was sent.
go func(desc string, tcMsg mainflux.RawMessage) {
receivedMsg := <-channel.Messages
assert.Equal(t, tcMsg, receivedMsg, fmt.Sprintf("%s: expected %v got %v\n", desc, tcMsg, receivedMsg))
}(tc.desc, tc.msg)
// Check if publish succeeded.
err := svc.Publish(tc.msg)
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
}
}
func TestSubscribe(t *testing.T) {
channel := ws.NewChannel()
svc := newService(channel)
cases := []struct {
desc string
chanID string
subtopic string
channel *ws.Channel
err error
}{
{
desc: "subscription to valid channel",
chanID: chanID,
channel: channel,
err: nil,
},
{
desc: "subscription to channel that should fail",
chanID: "0",
channel: channel,
err: ws.ErrFailedSubscription,
},
}
for _, tc := range cases {
err := svc.Subscribe(tc.chanID, tc.subtopic, tc.channel)
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
}
}
func TestSend(t *testing.T) {
channel := ws.NewChannel()
go func(channel *ws.Channel) {
receivedMsg := <-channel.Messages
assert.Equal(t, msg, receivedMsg, fmt.Sprintf("send message to channel: expected %v got %v\n", msg, receivedMsg))
}(channel)
channel.Send(msg)
}
func TestClose(t *testing.T) {
channel := ws.NewChannel()
go func() {
closed := <-channel.Closed
assert.True(t, closed, "channel closed stayed open")
}()
channel.Close()
}