mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
* PLT-6787 Fixed being able to send a post before files finished uploading (#6617) * Fix quick switcher for channels/users not stored locally (#6610) * Fix button text on confirm mention modal (#6609) * fix post delete permission of channel admin (#6608) * open comment thread for the most recent reply-able message (#6605) * Use mutex flag with yarn to prevent concurrent builds interfering (#6619) * Use mutex flag with yarn to prevent concurrent builds interfering * Remove yarn mutex file with clean * Minor bug fixes (#6615) * PLT-6774 - Fixing color for offline icon * PLT-6784 - Fixing status icon * Fixing icon margin * Updating caret position * PLT-6070 Have ChannelMentionProvider stop searching after a term returns no results (#6620) * Fixing JS error (#6623) * Minor bug fixes (#6622) * PLT-6808 - Updating channel switcher on mobile * PLT-6743 - Updating scrollbar styling * Login instead of failing if user exists in OAuth sign-up flow (#6627) * PLT-6802 Disable team switcher (#6626) * Disable team switcher * Fix ESLint errors * PLT-6807 Ensured select teams page can scroll on iOS (#6630) * Do not redirect from account switch pages on 401 (#6631) * Fixing loadtest command and renaming to /test (#6624) * PLT-6820 Update mattermost-redux dependency (#6632) * translations PR 20170612 (#6629) * Bump HTTP client timeout to 30 seconds (#6633) * For team unreads return empty array instead of null (#6636) * PLT-6831 Fix status modal localization IDs (#6637) * Fix status modal localization IDs * Update test snapshot
201 lines
6.6 KiB
Go
201 lines
6.6 KiB
Go
// Copyright (c) 2016-present Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
package api
|
|
|
|
import (
|
|
"strings"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/mattermost/platform/model"
|
|
"github.com/mattermost/platform/utils"
|
|
)
|
|
|
|
func TestLoadTestHelpCommands(t *testing.T) {
|
|
th := Setup().InitBasic()
|
|
Client := th.BasicClient
|
|
channel := th.BasicChannel
|
|
|
|
// enable testing to use /loadtest but don't save it since we don't want to overwrite config.json
|
|
enableTesting := utils.Cfg.ServiceSettings.EnableTesting
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableTesting = enableTesting
|
|
}()
|
|
|
|
utils.Cfg.ServiceSettings.EnableTesting = true
|
|
|
|
rs := Client.Must(Client.Command(channel.Id, "/test help")).Data.(*model.CommandResponse)
|
|
if !strings.Contains(rs.Text, "Mattermost testing commands to help") {
|
|
t.Fatal(rs.Text)
|
|
}
|
|
|
|
time.Sleep(2 * time.Second)
|
|
}
|
|
|
|
func TestLoadTestSetupCommands(t *testing.T) {
|
|
th := Setup().InitBasic()
|
|
Client := th.BasicClient
|
|
channel := th.BasicChannel
|
|
|
|
// enable testing to use /test but don't save it since we don't want to overwrite config.json
|
|
enableTesting := utils.Cfg.ServiceSettings.EnableTesting
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableTesting = enableTesting
|
|
}()
|
|
|
|
utils.Cfg.ServiceSettings.EnableTesting = true
|
|
|
|
rs := Client.Must(Client.Command(channel.Id, "/test setup fuzz 1 1 1")).Data.(*model.CommandResponse)
|
|
if rs.Text != "Created enviroment" {
|
|
t.Fatal(rs.Text)
|
|
}
|
|
|
|
time.Sleep(2 * time.Second)
|
|
}
|
|
|
|
func TestLoadTestUsersCommands(t *testing.T) {
|
|
th := Setup().InitBasic()
|
|
Client := th.BasicClient
|
|
channel := th.BasicChannel
|
|
|
|
// enable testing to use /test but don't save it since we don't want to overwrite config.json
|
|
enableTesting := utils.Cfg.ServiceSettings.EnableTesting
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableTesting = enableTesting
|
|
}()
|
|
|
|
utils.Cfg.ServiceSettings.EnableTesting = true
|
|
|
|
rs := Client.Must(Client.Command(channel.Id, "/test users fuzz 1 2")).Data.(*model.CommandResponse)
|
|
if rs.Text != "Added users" {
|
|
t.Fatal(rs.Text)
|
|
}
|
|
|
|
time.Sleep(2 * time.Second)
|
|
}
|
|
|
|
func TestLoadTestChannelsCommands(t *testing.T) {
|
|
th := Setup().InitBasic()
|
|
Client := th.BasicClient
|
|
channel := th.BasicChannel
|
|
|
|
// enable testing to use /loadtest but don't save it since we don't want to overwrite config.json
|
|
enableTesting := utils.Cfg.ServiceSettings.EnableTesting
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableTesting = enableTesting
|
|
}()
|
|
|
|
utils.Cfg.ServiceSettings.EnableTesting = true
|
|
|
|
rs := Client.Must(Client.Command(channel.Id, "/test channels fuzz 1 2")).Data.(*model.CommandResponse)
|
|
if rs.Text != "Added channels" {
|
|
t.Fatal(rs.Text)
|
|
}
|
|
|
|
time.Sleep(2 * time.Second)
|
|
}
|
|
|
|
func TestLoadTestPostsCommands(t *testing.T) {
|
|
th := Setup().InitBasic()
|
|
Client := th.BasicClient
|
|
channel := th.BasicChannel
|
|
|
|
// enable testing to use /loadtest but don't save it since we don't want to overwrite config.json
|
|
enableTesting := utils.Cfg.ServiceSettings.EnableTesting
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableTesting = enableTesting
|
|
}()
|
|
|
|
utils.Cfg.ServiceSettings.EnableTesting = true
|
|
|
|
rs := Client.Must(Client.Command(channel.Id, "/test posts fuzz 2 3 2")).Data.(*model.CommandResponse)
|
|
if rs.Text != "Added posts" {
|
|
t.Fatal(rs.Text)
|
|
}
|
|
|
|
time.Sleep(2 * time.Second)
|
|
}
|
|
|
|
func TestLoadTestUrlCommands(t *testing.T) {
|
|
//th := Setup().InitBasic()
|
|
//Client := th.BasicClient
|
|
//channel := th.BasicChannel
|
|
|
|
// enable testing to use /loadtest but don't save it since we don't want to overwrite config.json
|
|
//enableTesting := utils.Cfg.ServiceSettings.EnableTesting
|
|
//defer func() {
|
|
// utils.Cfg.ServiceSettings.EnableTesting = enableTesting
|
|
//}()
|
|
|
|
//utils.Cfg.ServiceSettings.EnableTesting = true
|
|
|
|
//command := "/loadtest url "
|
|
//if r := Client.Must(Client.Command(channel.Id, command, false)).Data.(*model.CommandResponse); r.Text != "Command must contain a url" {
|
|
// t.Fatal("/loadtest url with no url should've failed")
|
|
//}
|
|
//
|
|
//command = "/loadtest url http://missingfiletonwhere/path/asdf/qwerty"
|
|
//if r := Client.Must(Client.Command(channel.Id, command, false)).Data.(*model.CommandResponse); r.Text != "Unable to get file" {
|
|
// t.Log(r.Text)
|
|
// t.Fatal("/loadtest url with invalid url should've failed")
|
|
//}
|
|
//
|
|
//command = "/loadtest url https://raw.githubusercontent.com/mattermost/platform/master/README.md"
|
|
//if r := Client.Must(Client.Command(channel.Id, command, false)).Data.(*model.CommandResponse); r.Text != "Loaded data" {
|
|
// t.Fatal("/loadtest url for README.md should've executed")
|
|
//}
|
|
|
|
// Removing these tests since they break compatibilty with previous release branches because the url pulls from github master
|
|
|
|
// command = "/loadtest url test-emoticons1.md"
|
|
// if r := Client.Must(Client.Command(channel.Id, command, false)).Data.(*model.CommandResponse); r.Text != "Loading data..." {
|
|
// t.Fatal("/loadtest url for test-emoticons.md should've executed")
|
|
// }
|
|
|
|
// command = "/loadtest url test-emoticons1"
|
|
// if r := Client.Must(Client.Command(channel.Id, command, false)).Data.(*model.CommandResponse); r.Text != "Loading data..." {
|
|
// t.Fatal("/loadtest url for test-emoticons should've executed")
|
|
// }
|
|
|
|
// posts := Client.Must(Client.GetPosts(channel.Id, 0, 5, "")).Data.(*model.PostList)
|
|
// // note that this may make more than 3 posts if files are too long to fit in an individual post
|
|
// if len(posts.Order) < 3 {
|
|
// t.Fatal("/loadtest url made too few posts, perhaps there needs to be a delay before GetPosts in the test?")
|
|
// }
|
|
|
|
//time.Sleep(2 * time.Second)
|
|
}
|
|
|
|
func TestLoadTestJsonCommands(t *testing.T) {
|
|
//th := Setup().InitBasic()
|
|
//Client := th.BasicClient
|
|
//channel := th.BasicChannel
|
|
|
|
// enable testing to use /loadtest but don't save it since we don't want to overwrite config.json
|
|
//enableTesting := utils.Cfg.ServiceSettings.EnableTesting
|
|
//defer func() {
|
|
// utils.Cfg.ServiceSettings.EnableTesting = enableTesting
|
|
//}()
|
|
|
|
//utils.Cfg.ServiceSettings.EnableTesting = true
|
|
|
|
//command := "/loadtest json "
|
|
//if r := Client.Must(Client.Command(channel.Id, command, false)).Data.(*model.CommandResponse); r.Text != "Command must contain a url" {
|
|
// t.Fatal("/loadtest url with no url should've failed")
|
|
//}
|
|
//
|
|
//command = "/loadtest json http://missingfiletonwhere/path/asdf/qwerty"
|
|
//if r := Client.Must(Client.Command(channel.Id, command, false)).Data.(*model.CommandResponse); r.Text != "Unable to get file" {
|
|
// t.Log(r.Text)
|
|
// t.Fatal("/loadtest url with invalid url should've failed")
|
|
//}
|
|
//
|
|
//command = "/loadtest json test-slack-attachments"
|
|
//if r := Client.Must(Client.Command(channel.Id, command, false)).Data.(*model.CommandResponse); r.Text != "Loaded data" {
|
|
// t.Fatal("/loadtest json should've executed")
|
|
//}
|
|
|
|
//time.Sleep(2 * time.Second)
|
|
}
|