mirror of
https://github.com/mattermost/mattermost.git
synced 2026-02-03 20:40:00 -05:00
It was a good decision in hindsight to keep the public module as 0.x because this would have been a breaking change again. https://mattermost.atlassian.net/browse/MM-53032 ```release-note Changed the Go module path from github.com/mattermost/mattermost-server/server/v8 to github.com/mattermost/mattermost/server/v8. For the public facing module, it's path is also changed from github.com/mattermost/mattermost-server/server/public to github.com/mattermost/mattermost/server/public ```
95 lines
2.6 KiB
Go
95 lines
2.6 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
package config
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/mattermost/mattermost/server/public/model"
|
|
"github.com/mattermost/mattermost/server/public/shared/mlog"
|
|
)
|
|
|
|
func TestEmitter(t *testing.T) {
|
|
var e emitter
|
|
|
|
expectedOldCfg := &model.Config{}
|
|
expectedNewCfg := &model.Config{}
|
|
|
|
listener1 := false
|
|
id1 := e.AddListener(func(oldCfg, newCfg *model.Config) {
|
|
assert.Equal(t, expectedOldCfg, oldCfg)
|
|
assert.Equal(t, expectedNewCfg, newCfg)
|
|
listener1 = true
|
|
})
|
|
|
|
listener2 := false
|
|
id2 := e.AddListener(func(oldCfg, newCfg *model.Config) {
|
|
assert.Equal(t, expectedOldCfg, oldCfg)
|
|
assert.Equal(t, expectedNewCfg, newCfg)
|
|
listener2 = true
|
|
})
|
|
|
|
e.invokeConfigListeners(expectedOldCfg, expectedNewCfg)
|
|
assert.True(t, listener1, "listener 1 not called")
|
|
assert.True(t, listener2, "listener 2 not called")
|
|
|
|
e.RemoveListener(id2)
|
|
|
|
listener1 = false
|
|
listener2 = false
|
|
e.invokeConfigListeners(expectedOldCfg, expectedNewCfg)
|
|
assert.True(t, listener1, "listener 1 not called")
|
|
assert.False(t, listener2, "listener 2 should not have been called")
|
|
|
|
e.RemoveListener(id1)
|
|
|
|
listener1 = false
|
|
listener2 = false
|
|
e.invokeConfigListeners(expectedOldCfg, expectedNewCfg)
|
|
assert.False(t, listener1, "listener 1 should not have been called")
|
|
assert.False(t, listener2, "listener 2 should not have been called")
|
|
}
|
|
|
|
func TestLogSrcEmitter(t *testing.T) {
|
|
var e logSrcEmitter
|
|
|
|
expectedOldCfg := make(mlog.LoggerConfiguration)
|
|
expectedNewCfg := make(mlog.LoggerConfiguration)
|
|
|
|
listener1 := false
|
|
id1 := e.AddListener(func(oldCfg, newCfg mlog.LoggerConfiguration) {
|
|
assert.Equal(t, expectedOldCfg, oldCfg)
|
|
assert.Equal(t, expectedNewCfg, newCfg)
|
|
listener1 = true
|
|
})
|
|
|
|
listener2 := false
|
|
id2 := e.AddListener(func(oldCfg, newCfg mlog.LoggerConfiguration) {
|
|
assert.Equal(t, expectedOldCfg, oldCfg)
|
|
assert.Equal(t, expectedNewCfg, newCfg)
|
|
listener2 = true
|
|
})
|
|
|
|
e.invokeConfigListeners(expectedOldCfg, expectedNewCfg)
|
|
assert.True(t, listener1, "listener 1 not called")
|
|
assert.True(t, listener2, "listener 2 not called")
|
|
|
|
e.RemoveListener(id2)
|
|
|
|
listener1 = false
|
|
listener2 = false
|
|
e.invokeConfigListeners(expectedOldCfg, expectedNewCfg)
|
|
assert.True(t, listener1, "listener 1 not called")
|
|
assert.False(t, listener2, "listener 2 should not have been called")
|
|
|
|
e.RemoveListener(id1)
|
|
|
|
listener1 = false
|
|
listener2 = false
|
|
e.invokeConfigListeners(expectedOldCfg, expectedNewCfg)
|
|
assert.False(t, listener1, "listener 1 should not have been called")
|
|
assert.False(t, listener2, "listener 2 should not have been called")
|
|
}
|