mirror of
https://github.com/mattermost/mattermost.git
synced 2026-02-19 02:28:08 -05: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
280 lines
7.5 KiB
Go
280 lines
7.5 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
package api
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/mattermost/platform/model"
|
|
"github.com/mattermost/platform/utils"
|
|
)
|
|
|
|
func TestListCommands(t *testing.T) {
|
|
th := Setup().InitBasic()
|
|
Client := th.BasicClient
|
|
|
|
if results, err := Client.ListCommands(); err != nil {
|
|
t.Fatal(err)
|
|
} else {
|
|
commands := results.Data.([]*model.Command)
|
|
foundEcho := false
|
|
|
|
for _, command := range commands {
|
|
if command.Trigger == "echo" {
|
|
foundEcho = true
|
|
}
|
|
}
|
|
|
|
if !foundEcho {
|
|
t.Fatal("Couldn't find echo command")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestCreateCommand(t *testing.T) {
|
|
th := Setup().InitBasic().InitSystemAdmin()
|
|
Client := th.BasicClient
|
|
user := th.SystemAdminUser
|
|
team := th.SystemAdminTeam
|
|
|
|
enableCommands := *utils.Cfg.ServiceSettings.EnableCommands
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableCommands = &enableCommands
|
|
}()
|
|
*utils.Cfg.ServiceSettings.EnableCommands = true
|
|
|
|
cmd1 := &model.Command{
|
|
CreatorId: user.Id,
|
|
TeamId: team.Id,
|
|
URL: "http://nowhere.com",
|
|
Method: model.COMMAND_METHOD_POST,
|
|
Trigger: "trigger"}
|
|
|
|
if _, err := Client.CreateCommand(cmd1); err == nil {
|
|
t.Fatal("should have failed because not admin")
|
|
}
|
|
|
|
Client = th.SystemAdminClient
|
|
|
|
cmd2 := &model.Command{
|
|
CreatorId: user.Id,
|
|
TeamId: team.Id,
|
|
URL: "http://nowhere.com",
|
|
Method: model.COMMAND_METHOD_POST,
|
|
Trigger: "trigger"}
|
|
|
|
var rcmd *model.Command
|
|
if result, err := Client.CreateCommand(cmd2); err != nil {
|
|
t.Fatal(err)
|
|
} else {
|
|
rcmd = result.Data.(*model.Command)
|
|
}
|
|
|
|
if rcmd.CreatorId != user.Id {
|
|
t.Fatal("user ids didn't match")
|
|
}
|
|
|
|
if rcmd.TeamId != team.Id {
|
|
t.Fatal("team ids didn't match")
|
|
}
|
|
|
|
cmd3 := &model.Command{
|
|
CreatorId: "123",
|
|
TeamId: "456",
|
|
URL: "http://nowhere.com",
|
|
Method: model.COMMAND_METHOD_POST,
|
|
Trigger: "trigger"}
|
|
if _, err := Client.CreateCommand(cmd3); err == nil {
|
|
t.Fatal("trigger cannot be duplicated")
|
|
}
|
|
|
|
cmd4 := cmd3
|
|
if _, err := Client.CreateCommand(cmd4); err == nil {
|
|
t.Fatal("command cannot be duplicated")
|
|
}
|
|
}
|
|
|
|
func TestListTeamCommands(t *testing.T) {
|
|
th := Setup().InitSystemAdmin()
|
|
Client := th.SystemAdminClient
|
|
|
|
enableCommands := *utils.Cfg.ServiceSettings.EnableCommands
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableCommands = &enableCommands
|
|
}()
|
|
*utils.Cfg.ServiceSettings.EnableCommands = true
|
|
|
|
cmd1 := &model.Command{URL: "http://nowhere.com", Method: model.COMMAND_METHOD_POST, Trigger: "trigger"}
|
|
cmd1 = Client.Must(Client.CreateCommand(cmd1)).Data.(*model.Command)
|
|
|
|
if result, err := Client.ListTeamCommands(); err != nil {
|
|
t.Fatal(err)
|
|
} else {
|
|
cmds := result.Data.([]*model.Command)
|
|
|
|
if len(cmds) != 1 {
|
|
t.Fatal("incorrect number of cmd")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestUpdateCommand(t *testing.T) {
|
|
th := Setup().InitSystemAdmin()
|
|
Client := th.SystemAdminClient
|
|
user := th.SystemAdminUser
|
|
team := th.SystemAdminTeam
|
|
|
|
enableCommands := *utils.Cfg.ServiceSettings.EnableCommands
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableCommands = &enableCommands
|
|
}()
|
|
*utils.Cfg.ServiceSettings.EnableCommands = true
|
|
|
|
cmd1 := &model.Command{
|
|
CreatorId: user.Id,
|
|
TeamId: team.Id,
|
|
URL: "http://nowhere.com",
|
|
Method: model.COMMAND_METHOD_POST,
|
|
Trigger: "trigger"}
|
|
|
|
cmd1 = Client.Must(Client.CreateCommand(cmd1)).Data.(*model.Command)
|
|
|
|
cmd2 := &model.Command{
|
|
CreatorId: user.Id,
|
|
TeamId: team.Id,
|
|
URL: "http://nowhere.com",
|
|
Method: model.COMMAND_METHOD_POST,
|
|
Trigger: "trigger2",
|
|
Token: cmd1.Token,
|
|
Id: cmd1.Id}
|
|
|
|
if result, err := Client.UpdateCommand(cmd2); err != nil {
|
|
t.Fatal(err)
|
|
} else {
|
|
if result.Data.(*model.Command).Trigger == cmd1.Trigger {
|
|
t.Fatal("update didn't work properly")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestRegenToken(t *testing.T) {
|
|
th := Setup().InitSystemAdmin()
|
|
Client := th.SystemAdminClient
|
|
|
|
enableCommands := *utils.Cfg.ServiceSettings.EnableCommands
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableCommands = &enableCommands
|
|
}()
|
|
*utils.Cfg.ServiceSettings.EnableCommands = true
|
|
|
|
cmd := &model.Command{URL: "http://nowhere.com", Method: model.COMMAND_METHOD_POST, Trigger: "trigger"}
|
|
cmd = Client.Must(Client.CreateCommand(cmd)).Data.(*model.Command)
|
|
|
|
data := make(map[string]string)
|
|
data["id"] = cmd.Id
|
|
|
|
if result, err := Client.RegenCommandToken(data); err != nil {
|
|
t.Fatal(err)
|
|
} else {
|
|
if result.Data.(*model.Command).Token == cmd.Token {
|
|
t.Fatal("regen didn't work properly")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestDeleteCommand(t *testing.T) {
|
|
th := Setup().InitBasic().InitSystemAdmin()
|
|
Client := th.SystemAdminClient
|
|
|
|
enableCommands := *utils.Cfg.ServiceSettings.EnableCommands
|
|
onlyAdminIntegration := *utils.Cfg.ServiceSettings.EnableOnlyAdminIntegrations
|
|
defer func() {
|
|
*utils.Cfg.ServiceSettings.EnableCommands = enableCommands
|
|
*utils.Cfg.ServiceSettings.EnableOnlyAdminIntegrations = onlyAdminIntegration
|
|
}()
|
|
*utils.Cfg.ServiceSettings.EnableCommands = true
|
|
*utils.Cfg.ServiceSettings.EnableOnlyAdminIntegrations = false
|
|
|
|
cmd := &model.Command{URL: "http://nowhere.com", Method: model.COMMAND_METHOD_POST, Trigger: "trigger"}
|
|
cmd = Client.Must(Client.CreateCommand(cmd)).Data.(*model.Command)
|
|
|
|
data := make(map[string]string)
|
|
data["id"] = cmd.Id
|
|
|
|
if _, err := Client.DeleteCommand(data); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
cmds := Client.Must(Client.ListTeamCommands()).Data.([]*model.Command)
|
|
if len(cmds) != 0 {
|
|
t.Fatal("delete didn't work properly")
|
|
}
|
|
|
|
cmd2 := &model.Command{URL: "http://nowhere.com", Method: model.COMMAND_METHOD_POST, Trigger: "trigger2"}
|
|
cmd2 = Client.Must(Client.CreateCommand(cmd2)).Data.(*model.Command)
|
|
|
|
data2 := make(map[string]string)
|
|
data2["id"] = cmd2.Id
|
|
if _, err := th.BasicClient.DeleteCommand(data2); err == nil {
|
|
t.Fatal("Should have errored. Your not allowed to delete other's commands")
|
|
}
|
|
|
|
cmds2 := Client.Must(Client.ListTeamCommands()).Data.([]*model.Command)
|
|
if len(cmds2) != 1 {
|
|
t.Fatal("Client was able to delete command without permission.")
|
|
}
|
|
}
|
|
|
|
func TestTestCommand(t *testing.T) {
|
|
th := Setup().InitSystemAdmin()
|
|
Client := th.SystemAdminClient
|
|
channel1 := th.SystemAdminChannel
|
|
|
|
enableCommands := *utils.Cfg.ServiceSettings.EnableCommands
|
|
defer func() {
|
|
utils.Cfg.ServiceSettings.EnableCommands = &enableCommands
|
|
}()
|
|
*utils.Cfg.ServiceSettings.EnableCommands = true
|
|
|
|
cmd1 := &model.Command{
|
|
URL: "http://localhost" + utils.Cfg.ServiceSettings.ListenAddress + model.API_URL_SUFFIX_V3 + "/teams/command_test",
|
|
Method: model.COMMAND_METHOD_POST,
|
|
Trigger: "testcommand",
|
|
}
|
|
|
|
cmd1 = Client.Must(Client.CreateCommand(cmd1)).Data.(*model.Command)
|
|
|
|
r1 := Client.Must(Client.Command(channel1.Id, "/testcommand")).Data.(*model.CommandResponse)
|
|
if r1 == nil {
|
|
t.Fatal("Test command failed to execute")
|
|
}
|
|
|
|
time.Sleep(100 * time.Millisecond)
|
|
|
|
p1 := Client.Must(Client.GetPosts(channel1.Id, 0, 2, "")).Data.(*model.PostList)
|
|
if len(p1.Order) != 1 {
|
|
t.Fatal("Test command failed to send")
|
|
}
|
|
|
|
cmd2 := &model.Command{
|
|
URL: "http://localhost" + utils.Cfg.ServiceSettings.ListenAddress + model.API_URL_SUFFIX_V3 + "/teams/command_test",
|
|
Method: model.COMMAND_METHOD_GET,
|
|
Trigger: "test2",
|
|
}
|
|
|
|
cmd2 = Client.Must(Client.CreateCommand(cmd2)).Data.(*model.Command)
|
|
|
|
r2 := Client.Must(Client.Command(channel1.Id, "/test2")).Data.(*model.CommandResponse)
|
|
if r2 == nil {
|
|
t.Fatal("Test2 command failed to execute")
|
|
}
|
|
|
|
time.Sleep(100 * time.Millisecond)
|
|
|
|
p2 := Client.Must(Client.GetPosts(channel1.Id, 0, 2, "")).Data.(*model.PostList)
|
|
if len(p2.Order) != 2 {
|
|
t.Fatal("Test command failed to send")
|
|
}
|
|
}
|