Jürgen Eckel 3ca10dfff1
Verifying the availability of PoP participants (#274)
* feat: verify the availability of PoP participants

* simplified and improved logging
* added MQTT-based availability check for PoP participants
* extended MQTT mocking
* Only the block proposer will send out the MQTT messages to the pop participants
* Added a configuration value for the MQTT response timeout
* removed parallel execution of one test case
* added r/w locking to the MQTT response processing
* set MQTT timeout unit to ms

Signed-off-by: Julian Strobl <jmastr@mailbox.org>
2024-01-12 10:02:09 +01:00

118 lines
2.6 KiB
Go

package mocks
import (
"sync"
"time"
mqtt "github.com/eclipse/paho.mqtt.golang"
)
// MockMQTTClient is the mock mqtt client
type MockMQTTClient struct {
ConnectFunc func() mqtt.Token
DisconnectFunc func(quiesce uint)
PublishFunc func(topic string, qos byte, retained bool, payload interface{}) mqtt.Token
SubscribeFunc func(topic string, qos byte, callback mqtt.MessageHandler) mqtt.Token
UnsubscribeFunc func(topics ...string) mqtt.Token
}
// GetConnectFunc fetches the mock client's `Connect` func
func GetConnectFunc() mqtt.Token {
token := mqtt.DummyToken{}
return &token
}
// GetDisconnectFunc fetches the mock client's `Disconnect` func
func GetDisconnectFunc(_ uint) {
}
// GetPublishFunc fetches the mock client's `Publish` func
func GetPublishFunc(_ string, _ byte, _ bool, _ interface{}) mqtt.Token {
token := mqtt.DummyToken{}
return &token
}
type message struct {
duplicate bool
qos byte
retained bool
topic string
messageID uint16
payload []byte
ack func()
once sync.Once
}
func (m *message) Duplicate() bool {
return m.duplicate
}
func (m *message) Qos() byte {
return m.qos
}
func (m *message) Retained() bool {
return m.retained
}
func (m *message) Topic() string {
return m.topic
}
func (m *message) MessageID() uint16 {
return m.messageID
}
func (m *message) Payload() []byte {
return m.payload
}
func (m *message) Ack() {
m.once.Do(m.ack)
}
func SendCallbackResponse(topic string, callback mqtt.MessageHandler) {
time.Sleep(100 * time.Millisecond)
var opt mqtt.ClientOptions
client := mqtt.NewClient(&opt)
var msg message
msg.topic = topic
var msgInter mqtt.Message = &msg
callback(client, msgInter)
}
func GetSubscribeFunc(topic string, _ byte, callback mqtt.MessageHandler) mqtt.Token {
go SendCallbackResponse(topic, callback)
token := mqtt.DummyToken{}
return &token
}
func GetUnsubscribeFunc(_ ...string) mqtt.Token {
token := mqtt.DummyToken{}
return &token
}
// Connect is the mock client's `Disconnect` func
func (m *MockMQTTClient) Connect() mqtt.Token {
return GetConnectFunc()
}
// Disconnect is the mock client's `Disconnect` func
func (m *MockMQTTClient) Disconnect(quiesce uint) {
GetDisconnectFunc(quiesce)
}
// Publish is the mock client's `Publish` func
func (m *MockMQTTClient) Publish(topic string, qos byte, retained bool, payload interface{}) mqtt.Token {
return GetPublishFunc(topic, qos, retained, payload)
}
func (m *MockMQTTClient) Subscribe(topic string, qos byte, callback mqtt.MessageHandler) mqtt.Token {
return GetSubscribeFunc(topic, qos, callback)
}
func (m *MockMQTTClient) Unsubscribe(topics ...string) mqtt.Token {
return GetUnsubscribeFunc(topics...)
}