mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
* PLT-7195: Added new config option, new license feature, and config UI to system console. Still need to implement behaviour change in email batching code * PLT-7195: Modified batch emails to respect email notification content type setting * PLT-7195: Tweaking the colours a bit * PLT-7195: Added support for email notification content type setting in immediate (non-batched) notification messages. Attempted to clean up the code somewhat. Unit tests coming in a future commit * PLT-7195: Added unit tests for non-batched emails * Checked license when applying email content settings * Changed return type of getFormattedPostTime
290 lines
8.8 KiB
Go
290 lines
8.8 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
package utils
|
|
|
|
import (
|
|
"os"
|
|
"strings"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/mattermost/platform/model"
|
|
)
|
|
|
|
func TestConfig(t *testing.T) {
|
|
TranslationsPreInit()
|
|
LoadConfig("config.json")
|
|
InitTranslations(Cfg.LocalizationSettings)
|
|
}
|
|
|
|
func TestConfigFromEnviroVars(t *testing.T) {
|
|
|
|
os.Setenv("MM_TEAMSETTINGS_SITENAME", "From Enviroment")
|
|
os.Setenv("MM_TEAMSETTINGS_CUSTOMBRANDTEXT", "Custom Brand")
|
|
os.Setenv("MM_SERVICESETTINGS_ENABLECOMMANDS", "false")
|
|
os.Setenv("MM_SERVICESETTINGS_READTIMEOUT", "400")
|
|
|
|
TranslationsPreInit()
|
|
EnableConfigFromEnviromentVars()
|
|
LoadConfig("config.json")
|
|
|
|
if Cfg.TeamSettings.SiteName != "From Enviroment" {
|
|
t.Fatal("Couldn't read config from enviroment var")
|
|
}
|
|
|
|
if *Cfg.TeamSettings.CustomBrandText != "Custom Brand" {
|
|
t.Fatal("Couldn't read config from enviroment var")
|
|
}
|
|
|
|
if *Cfg.ServiceSettings.EnableCommands != false {
|
|
t.Fatal("Couldn't read config from enviroment var")
|
|
}
|
|
|
|
if *Cfg.ServiceSettings.ReadTimeout != 400 {
|
|
t.Fatal("Couldn't read config from enviroment var")
|
|
}
|
|
|
|
os.Unsetenv("MM_TEAMSETTINGS_SITENAME")
|
|
os.Unsetenv("MM_TEAMSETTINGS_CUSTOMBRANDTEXT")
|
|
os.Unsetenv("MM_SERVICESETTINGS_ENABLECOMMANDS")
|
|
os.Unsetenv("MM_SERVICESETTINGS_READTIMEOUT")
|
|
|
|
Cfg.TeamSettings.SiteName = "Mattermost"
|
|
*Cfg.ServiceSettings.SiteURL = ""
|
|
*Cfg.ServiceSettings.EnableCommands = true
|
|
*Cfg.ServiceSettings.ReadTimeout = 300
|
|
SaveConfig(CfgFileName, Cfg)
|
|
|
|
LoadConfig("config.json")
|
|
|
|
if Cfg.TeamSettings.SiteName != "Mattermost" {
|
|
t.Fatal("should have been reset")
|
|
}
|
|
}
|
|
|
|
func TestRedirectStdLog(t *testing.T) {
|
|
TranslationsPreInit()
|
|
LoadConfig("config.json")
|
|
InitTranslations(Cfg.LocalizationSettings)
|
|
|
|
log := NewRedirectStdLog("test", false)
|
|
|
|
log.Println("[DEBUG] this is a message")
|
|
log.Println("[DEBG] this is a message")
|
|
log.Println("[WARN] this is a message")
|
|
log.Println("[ERROR] this is a message")
|
|
log.Println("[EROR] this is a message")
|
|
log.Println("[ERR] this is a message")
|
|
log.Println("[INFO] this is a message")
|
|
log.Println("this is a message")
|
|
|
|
time.Sleep(time.Second * 1)
|
|
}
|
|
|
|
func TestAddRemoveConfigListener(t *testing.T) {
|
|
if len(cfgListeners) != 0 {
|
|
t.Fatal("should've started with 0 listeners")
|
|
}
|
|
|
|
id1 := AddConfigListener(func(*model.Config, *model.Config) {
|
|
})
|
|
if len(cfgListeners) != 1 {
|
|
t.Fatal("should now have 1 listener")
|
|
}
|
|
|
|
id2 := AddConfigListener(func(*model.Config, *model.Config) {
|
|
})
|
|
if len(cfgListeners) != 2 {
|
|
t.Fatal("should now have 2 listeners")
|
|
}
|
|
|
|
RemoveConfigListener(id1)
|
|
if len(cfgListeners) != 1 {
|
|
t.Fatal("should've removed first listener")
|
|
}
|
|
|
|
RemoveConfigListener(id2)
|
|
if len(cfgListeners) != 0 {
|
|
t.Fatal("should've removed both listeners")
|
|
}
|
|
}
|
|
|
|
func TestConfigListener(t *testing.T) {
|
|
TranslationsPreInit()
|
|
EnableConfigFromEnviromentVars()
|
|
LoadConfig("config.json")
|
|
|
|
SiteName := Cfg.TeamSettings.SiteName
|
|
defer func() {
|
|
Cfg.TeamSettings.SiteName = SiteName
|
|
SaveConfig(CfgFileName, Cfg)
|
|
}()
|
|
Cfg.TeamSettings.SiteName = "test123"
|
|
|
|
listenerCalled := false
|
|
listener := func(oldConfig *model.Config, newConfig *model.Config) {
|
|
if listenerCalled {
|
|
t.Fatal("listener called twice")
|
|
}
|
|
|
|
if oldConfig.TeamSettings.SiteName != "test123" {
|
|
t.Fatal("old config contains incorrect site name")
|
|
} else if newConfig.TeamSettings.SiteName != "Mattermost" {
|
|
t.Fatal("new config contains incorrect site name")
|
|
}
|
|
|
|
listenerCalled = true
|
|
}
|
|
listenerId := AddConfigListener(listener)
|
|
defer RemoveConfigListener(listenerId)
|
|
|
|
listener2Called := false
|
|
listener2 := func(oldConfig *model.Config, newConfig *model.Config) {
|
|
if listener2Called {
|
|
t.Fatal("listener2 called twice")
|
|
}
|
|
|
|
listener2Called = true
|
|
}
|
|
listener2Id := AddConfigListener(listener2)
|
|
defer RemoveConfigListener(listener2Id)
|
|
|
|
LoadConfig("config.json")
|
|
|
|
if !listenerCalled {
|
|
t.Fatal("listener should've been called")
|
|
} else if !listener2Called {
|
|
t.Fatal("listener 2 should've been called")
|
|
}
|
|
}
|
|
|
|
func TestValidateLocales(t *testing.T) {
|
|
TranslationsPreInit()
|
|
LoadConfig("config.json")
|
|
|
|
defaultServerLocale := *Cfg.LocalizationSettings.DefaultServerLocale
|
|
defaultClientLocale := *Cfg.LocalizationSettings.DefaultClientLocale
|
|
availableLocales := *Cfg.LocalizationSettings.AvailableLocales
|
|
|
|
defer func() {
|
|
*Cfg.LocalizationSettings.DefaultClientLocale = defaultClientLocale
|
|
*Cfg.LocalizationSettings.DefaultServerLocale = defaultServerLocale
|
|
*Cfg.LocalizationSettings.AvailableLocales = availableLocales
|
|
}()
|
|
|
|
*Cfg.LocalizationSettings.DefaultServerLocale = "en"
|
|
*Cfg.LocalizationSettings.DefaultClientLocale = "en"
|
|
*Cfg.LocalizationSettings.AvailableLocales = ""
|
|
|
|
// t.Logf("*Cfg.LocalizationSettings.DefaultClientLocale: %+v", *Cfg.LocalizationSettings.DefaultClientLocale)
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
t.Fatal("Should have not returned an error")
|
|
}
|
|
|
|
// validate DefaultServerLocale
|
|
*Cfg.LocalizationSettings.DefaultServerLocale = "junk"
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
if *Cfg.LocalizationSettings.DefaultServerLocale != "en" {
|
|
t.Fatal("DefaultServerLocale should have assigned to en as a default value")
|
|
}
|
|
} else {
|
|
|
|
t.Fatal("Should have returned an error validating DefaultServerLocale")
|
|
}
|
|
|
|
*Cfg.LocalizationSettings.DefaultServerLocale = ""
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
if *Cfg.LocalizationSettings.DefaultServerLocale != "en" {
|
|
t.Fatal("DefaultServerLocale should have assigned to en as a default value")
|
|
}
|
|
} else {
|
|
t.Fatal("Should have returned an error validating DefaultServerLocale")
|
|
}
|
|
|
|
*Cfg.LocalizationSettings.AvailableLocales = "en"
|
|
*Cfg.LocalizationSettings.DefaultServerLocale = "de"
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
if strings.Contains(*Cfg.LocalizationSettings.AvailableLocales, *Cfg.LocalizationSettings.DefaultServerLocale) {
|
|
t.Fatal("DefaultServerLocale should not be added to AvailableLocales")
|
|
}
|
|
t.Fatal("Should have not returned an error validating DefaultServerLocale")
|
|
}
|
|
|
|
// validate DefaultClientLocale
|
|
*Cfg.LocalizationSettings.AvailableLocales = ""
|
|
*Cfg.LocalizationSettings.DefaultClientLocale = "junk"
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
if *Cfg.LocalizationSettings.DefaultClientLocale != "en" {
|
|
t.Fatal("DefaultClientLocale should have assigned to en as a default value")
|
|
}
|
|
} else {
|
|
|
|
t.Fatal("Should have returned an error validating DefaultClientLocale")
|
|
}
|
|
|
|
*Cfg.LocalizationSettings.DefaultClientLocale = ""
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
if *Cfg.LocalizationSettings.DefaultClientLocale != "en" {
|
|
t.Fatal("DefaultClientLocale should have assigned to en as a default value")
|
|
}
|
|
} else {
|
|
t.Fatal("Should have returned an error validating DefaultClientLocale")
|
|
}
|
|
|
|
*Cfg.LocalizationSettings.AvailableLocales = "en"
|
|
*Cfg.LocalizationSettings.DefaultClientLocale = "de"
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
if !strings.Contains(*Cfg.LocalizationSettings.AvailableLocales, *Cfg.LocalizationSettings.DefaultClientLocale) {
|
|
t.Fatal("DefaultClientLocale should have added to AvailableLocales")
|
|
}
|
|
} else {
|
|
t.Fatal("Should have returned an error validating DefaultClientLocale")
|
|
}
|
|
|
|
// validate AvailableLocales
|
|
*Cfg.LocalizationSettings.DefaultServerLocale = "en"
|
|
*Cfg.LocalizationSettings.DefaultClientLocale = "en"
|
|
*Cfg.LocalizationSettings.AvailableLocales = "junk"
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
if *Cfg.LocalizationSettings.AvailableLocales != "" {
|
|
t.Fatal("AvailableLocales should have assigned to empty string as a default value")
|
|
}
|
|
} else {
|
|
t.Fatal("Should have returned an error validating AvailableLocales")
|
|
}
|
|
|
|
*Cfg.LocalizationSettings.AvailableLocales = "en,de,junk"
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
if *Cfg.LocalizationSettings.AvailableLocales != "" {
|
|
t.Fatal("AvailableLocales should have assigned to empty string as a default value")
|
|
}
|
|
} else {
|
|
t.Fatal("Should have returned an error validating AvailableLocales")
|
|
}
|
|
|
|
*Cfg.LocalizationSettings.DefaultServerLocale = "fr"
|
|
*Cfg.LocalizationSettings.DefaultClientLocale = "de"
|
|
*Cfg.LocalizationSettings.AvailableLocales = "en"
|
|
if err := ValidateLocales(Cfg); err != nil {
|
|
if strings.Contains(*Cfg.LocalizationSettings.AvailableLocales, *Cfg.LocalizationSettings.DefaultServerLocale) {
|
|
t.Fatal("DefaultServerLocale should not be added to AvailableLocales")
|
|
}
|
|
if !strings.Contains(*Cfg.LocalizationSettings.AvailableLocales, *Cfg.LocalizationSettings.DefaultClientLocale) {
|
|
t.Fatal("DefaultClientLocale should have added to AvailableLocales")
|
|
}
|
|
} else {
|
|
t.Fatal("Should have returned an error validating AvailableLocales")
|
|
}
|
|
}
|
|
|
|
func TestGetClientConfig(t *testing.T) {
|
|
TranslationsPreInit()
|
|
LoadConfig("config.json")
|
|
|
|
configMap := getClientConfig(Cfg)
|
|
if configMap["EmailNotificationContentsType"] != *Cfg.EmailSettings.EmailNotificationContentsType {
|
|
t.Fatal("EmailSettings.EmailNotificationContentsType not exposed to client config")
|
|
}
|
|
}
|