2019-11-29 06:59:40 -05:00
|
|
|
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
|
|
|
// See LICENSE.txt for license information.
|
2018-12-06 13:19:32 -05:00
|
|
|
|
|
|
|
|
package testlib
|
|
|
|
|
|
|
|
|
|
import (
|
2020-11-09 08:55:51 -05:00
|
|
|
"sync"
|
|
|
|
|
|
2023-06-11 01:24:35 -04:00
|
|
|
"github.com/mattermost/mattermost/server/public/model"
|
2024-08-03 10:11:13 -04:00
|
|
|
"github.com/mattermost/mattermost/server/public/shared/request"
|
2023-06-11 01:24:35 -04:00
|
|
|
"github.com/mattermost/mattermost/server/v8/einterfaces"
|
2018-12-06 13:19:32 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type FakeClusterInterface struct {
|
|
|
|
|
clusterMessageHandler einterfaces.ClusterMessageHandler
|
2020-11-09 08:55:51 -05:00
|
|
|
mut sync.RWMutex
|
2019-07-18 14:05:53 -04:00
|
|
|
messages []*model.ClusterMessage
|
2018-12-06 13:19:32 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (c *FakeClusterInterface) StartInterNodeCommunication() {}
|
|
|
|
|
|
|
|
|
|
func (c *FakeClusterInterface) StopInterNodeCommunication() {}
|
|
|
|
|
|
2021-07-15 01:32:17 -04:00
|
|
|
func (c *FakeClusterInterface) RegisterClusterMessageHandler(event model.ClusterEvent, crm einterfaces.ClusterMessageHandler) {
|
2018-12-06 13:19:32 -05:00
|
|
|
c.clusterMessageHandler = crm
|
|
|
|
|
}
|
|
|
|
|
|
2020-06-24 09:16:33 -04:00
|
|
|
func (c *FakeClusterInterface) HealthScore() int {
|
|
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
|
2018-12-06 13:19:32 -05:00
|
|
|
func (c *FakeClusterInterface) GetClusterId() string { return "" }
|
|
|
|
|
|
|
|
|
|
func (c *FakeClusterInterface) IsLeader() bool { return false }
|
|
|
|
|
|
|
|
|
|
func (c *FakeClusterInterface) GetMyClusterInfo() *model.ClusterInfo { return nil }
|
|
|
|
|
|
2025-05-12 13:37:58 -04:00
|
|
|
func (c *FakeClusterInterface) GetClusterInfos() ([]*model.ClusterInfo, error) { return nil, nil }
|
2018-12-06 13:19:32 -05:00
|
|
|
|
2019-07-18 14:05:53 -04:00
|
|
|
func (c *FakeClusterInterface) SendClusterMessage(message *model.ClusterMessage) {
|
2020-11-09 08:55:51 -05:00
|
|
|
c.mut.Lock()
|
|
|
|
|
defer c.mut.Unlock()
|
2019-07-18 14:05:53 -04:00
|
|
|
c.messages = append(c.messages, message)
|
|
|
|
|
}
|
2018-12-06 13:19:32 -05:00
|
|
|
|
2021-04-28 13:59:32 -04:00
|
|
|
func (c *FakeClusterInterface) SendClusterMessageToNode(nodeID string, message *model.ClusterMessage) error {
|
|
|
|
|
c.mut.Lock()
|
|
|
|
|
defer c.mut.Unlock()
|
|
|
|
|
c.messages = append(c.messages, message)
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2018-12-06 13:19:32 -05:00
|
|
|
func (c *FakeClusterInterface) NotifyMsg(buf []byte) {}
|
|
|
|
|
|
2024-09-27 03:17:16 -04:00
|
|
|
func (c *FakeClusterInterface) GetClusterStats(rctx request.CTX) ([]*model.ClusterStats, *model.AppError) {
|
2018-12-06 13:19:32 -05:00
|
|
|
return nil, nil
|
|
|
|
|
}
|
|
|
|
|
|
2024-09-27 03:17:16 -04:00
|
|
|
func (c *FakeClusterInterface) GetLogs(rctx request.CTX, page, perPage int) ([]string, *model.AppError) {
|
2018-12-06 13:19:32 -05:00
|
|
|
return []string{}, nil
|
|
|
|
|
}
|
|
|
|
|
|
2024-09-27 03:17:16 -04:00
|
|
|
func (c *FakeClusterInterface) QueryLogs(rctx request.CTX, page, perPage int) (map[string][]string, *model.AppError) {
|
2023-02-14 05:39:10 -05:00
|
|
|
return make(map[string][]string), nil
|
|
|
|
|
}
|
|
|
|
|
|
2024-08-03 10:11:13 -04:00
|
|
|
func (c *FakeClusterInterface) GenerateSupportPacket(rctx request.CTX, options *model.SupportPacketOptions) (map[string][]model.FileData, error) {
|
|
|
|
|
return nil, nil
|
|
|
|
|
}
|
|
|
|
|
|
2018-12-06 13:19:32 -05:00
|
|
|
func (c *FakeClusterInterface) ConfigChanged(previousConfig *model.Config, newConfig *model.Config, sendToOtherServer bool) *model.AppError {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (c *FakeClusterInterface) SendClearRoleCacheMessage() {
|
2019-09-12 12:52:45 -04:00
|
|
|
if c.clusterMessageHandler != nil {
|
|
|
|
|
c.clusterMessageHandler(&model.ClusterMessage{
|
2021-07-12 14:05:36 -04:00
|
|
|
Event: model.ClusterEventInvalidateCacheForRoles,
|
2019-09-12 12:52:45 -04:00
|
|
|
})
|
|
|
|
|
}
|
2018-12-06 13:19:32 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (c *FakeClusterInterface) GetPluginStatuses() (model.PluginStatuses, *model.AppError) {
|
|
|
|
|
return nil, nil
|
|
|
|
|
}
|
2019-07-18 14:05:53 -04:00
|
|
|
|
|
|
|
|
func (c *FakeClusterInterface) GetMessages() []*model.ClusterMessage {
|
2020-11-09 08:55:51 -05:00
|
|
|
c.mut.RLock()
|
|
|
|
|
defer c.mut.RUnlock()
|
2019-07-18 14:05:53 -04:00
|
|
|
return c.messages
|
|
|
|
|
}
|
|
|
|
|
|
2021-04-01 13:44:56 -04:00
|
|
|
func (c *FakeClusterInterface) SelectMessages(filterCond func(message *model.ClusterMessage) bool) []*model.ClusterMessage {
|
|
|
|
|
c.mut.RLock()
|
|
|
|
|
defer c.mut.RUnlock()
|
|
|
|
|
|
|
|
|
|
filteredMessages := []*model.ClusterMessage{}
|
|
|
|
|
for _, msg := range c.messages {
|
|
|
|
|
if filterCond(msg) {
|
|
|
|
|
filteredMessages = append(filteredMessages, msg)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return filteredMessages
|
|
|
|
|
}
|
|
|
|
|
|
2019-07-18 14:05:53 -04:00
|
|
|
func (c *FakeClusterInterface) ClearMessages() {
|
2020-11-09 08:55:51 -05:00
|
|
|
c.mut.Lock()
|
|
|
|
|
defer c.mut.Unlock()
|
2019-07-18 14:05:53 -04:00
|
|
|
c.messages = nil
|
|
|
|
|
}
|
2024-04-30 09:58:55 -04:00
|
|
|
|
|
|
|
|
func (c *FakeClusterInterface) WebConnCountForUser(userID string) (int, *model.AppError) {
|
|
|
|
|
return 0, nil
|
|
|
|
|
}
|
2025-01-17 00:41:32 -05:00
|
|
|
|
|
|
|
|
func (c *FakeClusterInterface) GetWSQueues(userID, connectionID string, seqNum int64) (map[string]*model.WSQueues, error) {
|
|
|
|
|
return nil, nil
|
|
|
|
|
}
|