From 3836f9992056410e00041004132f5d53b4e43300 Mon Sep 17 00:00:00 2001 From: Joey Lee Date: Sat, 18 Nov 2017 03:17:59 +1100 Subject: PLT-7824 Added support for mentions with <@userid> and (#7615) (#7737) --- app/slack_test.go | 83 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 app/slack_test.go (limited to 'app/slack_test.go') diff --git a/app/slack_test.go b/app/slack_test.go new file mode 100644 index 000000000..370942ba0 --- /dev/null +++ b/app/slack_test.go @@ -0,0 +1,83 @@ +package app + +import ( + "testing" + + "github.com/mattermost/mattermost-server/model" +) + +func TestProcessSlackText(t *testing.T) { + th := Setup().InitBasic() + defer th.TearDown() + + if th.App.ProcessSlackText(" foo ") != "@channel foo @channel" { + t.Fail() + } + + if th.App.ProcessSlackText(" bar ") != "@here bar @here" { + t.Fail() + } + + if th.App.ProcessSlackText(" bar ") != "@all bar @all" { + t.Fail() + } + + userId := th.BasicUser.Id + username := th.BasicUser.Username + if th.App.ProcessSlackText("<@"+userId+"> hello") != "@"+username+" hello" { + t.Fail() + } +} + +func TestProcessSlackAnnouncement(t *testing.T) { + th := Setup().InitBasic() + defer th.TearDown() + + userId := th.BasicUser.Id + username := th.BasicUser.Username + + attachments := []*model.SlackAttachment{ + { + Pretext: " pretext ", + Text: " text ", + Title: " title ", + Fields: []*model.SlackAttachmentField{ + { + Title: "foo", + Value: " bar ", + Short: true, + }, + }, + }, + { + Pretext: "<@" + userId + "> pretext", + Text: "<@" + userId + "> text", + Title: "<@" + userId + "> title", + Fields: []*model.SlackAttachmentField{ + { + Title: "foo", + Value: "<@" + userId + "> bar", + Short: true, + }, + }, + }, + } + attachments = th.App.ProcessSlackAttachments(attachments) + if len(attachments) != 2 || len(attachments[0].Fields) != 1 || len(attachments[1].Fields) != 1 { + t.Fail() + } + + if attachments[0].Pretext != "@channel pretext @here" || + attachments[0].Text != "@channel text @here" || + attachments[0].Title != "@channel title @here" || + attachments[0].Fields[0].Value != "@channel bar @here" { + t.Fail() + } + + if attachments[1].Pretext != "@"+username+" pretext" || + attachments[1].Text != "@"+username+" text" || + attachments[1].Title != "@"+username+" title" || + attachments[1].Fields[0].Value != "@"+username+" bar" { + t.Fail() + } +} -- cgit v1.2.3-1-g7c22