mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-27 13:48:49 +08:00

* Add test setup for mqtt Signed-off-by: Darko Draskovic <darko.draskovic@gmail.com> * Add pubsub tests Signed-off-by: Darko Draskovic <darko.draskovic@gmail.com> * Add message and payload helper funcs Signed-off-by: Darko Draskovic <darko.draskovic@gmail.com> * Add time.Sleep after subscribe to topic Signed-off-by: Darko Draskovic <darko.draskovic@gmail.com> * Add NATS tests setup Signed-off-by: Darko Draskovic <darko.draskovic@gmail.com> * Add NATS test cases Signed-off-by: Darko Draskovic <darko.draskovic@gmail.com> * Add message forwarded check to handler Signed-off-by: Darko Draskovic <darko.draskovic@gmail.com> * Remove race affected mqtt tests Signed-off-by: Darko Draskovic <darko.draskovic@gmail.com>
75 lines
1.6 KiB
Go
75 lines
1.6 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package nats_test
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
"os"
|
|
"os/signal"
|
|
"syscall"
|
|
"testing"
|
|
|
|
"github.com/mainflux/mainflux/logger"
|
|
"github.com/mainflux/mainflux/pkg/messaging"
|
|
"github.com/mainflux/mainflux/pkg/messaging/nats"
|
|
dockertest "github.com/ory/dockertest/v3"
|
|
)
|
|
|
|
var (
|
|
publisher messaging.Publisher
|
|
pubsub messaging.PubSub
|
|
)
|
|
|
|
func TestMain(m *testing.M) {
|
|
pool, err := dockertest.NewPool("")
|
|
if err != nil {
|
|
log.Fatalf("Could not connect to docker: %s", err)
|
|
}
|
|
|
|
container, err := pool.Run("nats", "1.3.0", []string{})
|
|
if err != nil {
|
|
log.Fatalf("Could not start container: %s", err)
|
|
}
|
|
handleInterrupt(pool, container)
|
|
|
|
address := fmt.Sprintf("%s:%s", "localhost", container.GetPort("4222/tcp"))
|
|
if err := pool.Retry(func() error {
|
|
publisher, err = nats.NewPublisher(address)
|
|
return err
|
|
}); err != nil {
|
|
log.Fatalf("Could not connect to docker: %s", err)
|
|
}
|
|
|
|
logger, err := logger.New(os.Stdout, "error")
|
|
if err != nil {
|
|
log.Fatalf(err.Error())
|
|
}
|
|
if err := pool.Retry(func() error {
|
|
pubsub, err = nats.NewPubSub(address, "", logger)
|
|
return err
|
|
}); err != nil {
|
|
log.Fatalf("Could not connect to docker: %s", err)
|
|
}
|
|
|
|
code := m.Run()
|
|
if err := pool.Purge(container); err != nil {
|
|
log.Fatalf("Could not purge container: %s", err)
|
|
}
|
|
|
|
os.Exit(code)
|
|
}
|
|
|
|
func handleInterrupt(pool *dockertest.Pool, container *dockertest.Resource) {
|
|
c := make(chan os.Signal)
|
|
signal.Notify(c, os.Interrupt, syscall.SIGTERM)
|
|
go func() {
|
|
<-c
|
|
if err := pool.Purge(container); err != nil {
|
|
log.Fatalf("Could not purge container: %s", err)
|
|
}
|
|
os.Exit(0)
|
|
}()
|
|
}
|