Skip to content

Commit

Permalink
Do not rewrite messgaes from bots
Browse files Browse the repository at this point in the history
  • Loading branch information
Pawel Rozlach committed Mar 10, 2020
1 parent 5e53e3f commit 2c0ad05
Show file tree
Hide file tree
Showing 3 changed files with 132 additions and 0 deletions.
6 changes: 6 additions & 0 deletions server/autolink/autolink_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,12 @@ func setupTestPlugin(t *testing.T, l autolink.Autolink) *autolinkplugin.Plugin {
TeamId: "theteam_id0123456789012345",
Name: "thechannel_name",
}, (*model.AppError)(nil))

testUser := model.User{
IsBot: false,
}
api.On("GetUser", mock.AnythingOfType("string")).Return(&testUser, nil)

p.SetAPI(api)

err := l.Compile()
Expand Down
22 changes: 22 additions & 0 deletions server/autolinkplugin/plugin.go
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,29 @@ func contains(team string, channel string, list []string) bool {
return false
}

func (p *Plugin) isBotUser(userId string) (bool, *model.AppError) {
user, appErr := p.API.GetUser(userId)
if appErr != nil {
p.API.LogError("failed to check if message for rewriting was send by a bot", "error", appErr)
return false, appErr
}

return user.IsBot, nil
}

func (p *Plugin) ProcessPost(c *plugin.Context, post *model.Post) (*model.Post, string) {
isBot, appErr := p.isBotUser(post.UserId)
if appErr != nil {
// NOTE: Not sure how we want to handle errors here, we can either:
// * assume that occasional rewrites of Bot messges are ok
// * assume that occasional not rewriting of all messages is ok
// Let's assume for now that former is a lesser evil and carry on.
}
if isBot {
p.API.LogDebug("not rewriting message from bot", "userId", post.UserId)
return nil, ""
}

conf := p.getConfig()
postText := post.Message
offset := 0
Expand Down
104 changes: 104 additions & 0 deletions server/autolinkplugin/plugin_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,11 @@ func TestPlugin(t *testing.T) {
api.On("GetChannel", mock.AnythingOfType("string")).Return(&testChannel, nil)
api.On("GetTeam", mock.AnythingOfType("string")).Return(&testTeam, nil)

testUser := model.User{
IsBot: false,
}
api.On("GetUser", mock.AnythingOfType("string")).Return(&testUser, nil)

p := Plugin{}
p.SetAPI(api)
p.OnConfigurationChange()
Expand Down Expand Up @@ -106,6 +111,11 @@ func TestSpecialCases(t *testing.T) {
api.On("GetChannel", mock.AnythingOfType("string")).Return(&testChannel, nil)
api.On("GetTeam", mock.AnythingOfType("string")).Return(&testTeam, nil)

testUser := model.User{
IsBot: false,
}
api.On("GetUser", mock.AnythingOfType("string")).Return(&testUser, nil)

p := Plugin{}
p.SetAPI(api)
p.OnConfigurationChange()
Expand Down Expand Up @@ -279,6 +289,95 @@ func TestSpecialCases(t *testing.T) {
}
}

func TestBotMessagesAreRewritenWhenGetUserFails(t *testing.T) {
conf := Config{
Links: []autolink.Autolink{
autolink.Autolink{
Pattern: "(Mattermost)",
Template: "[Mattermost](https://mattermost.com)",
},
},
}

testChannel := model.Channel{
Name: "TestChanel",
}

testTeam := model.Team{
Name: "TestTeam",
}

api := &plugintest.API{}

api.On("LoadPluginConfiguration", mock.AnythingOfType("*autolinkplugin.Config")).Return(func(dest interface{}) error {
*dest.(*Config) = conf
return nil
}).Once()
api.On("UnregisterCommand", mock.AnythingOfType("string"), mock.AnythingOfType("string")).Return((*model.AppError)(nil)).Once()

api.On("GetChannel", mock.AnythingOfType("string")).Return(&testChannel, nil).Once()
api.On("GetTeam", mock.AnythingOfType("string")).Return(&testTeam, nil).Once()
api.On("LogError", mock.AnythingOfType("string"), mock.AnythingOfType("string"), mock.AnythingOfType("*model.AppError"))

err := &model.AppError{
Message: "foo error!",
}
api.On("GetUser", mock.AnythingOfType("string")).Return(nil, err).Once()

p := Plugin{}
p.SetAPI(api)
p.OnConfigurationChange()

post := &model.Post{Message: "Welcome to Mattermost!"}
rpost, _ := p.MessageWillBePosted(&plugin.Context{}, post)

assert.Equal(t, "Welcome to [Mattermost](https://mattermost.com)!", rpost.Message)
}

func TestBotMessagesAreNotRewriten(t *testing.T) {
conf := Config{
Links: []autolink.Autolink{
autolink.Autolink{
Pattern: "(Mattermost)",
Template: "[Mattermost](https://mattermost.com)",
},
},
}

testChannel := model.Channel{
Name: "TestChanel",
}

testTeam := model.Team{
Name: "TestTeam",
}

api := &plugintest.API{}

api.On("LoadPluginConfiguration", mock.AnythingOfType("*autolinkplugin.Config")).Return(func(dest interface{}) error {
*dest.(*Config) = conf
return nil
}).Once()
api.On("UnregisterCommand", mock.AnythingOfType("string"), mock.AnythingOfType("string")).Return((*model.AppError)(nil)).Once()

api.On("GetChannel", mock.AnythingOfType("string")).Return(&testChannel, nil).Once()
api.On("GetTeam", mock.AnythingOfType("string")).Return(&testTeam, nil).Once()
testUser := model.User{
IsBot: true,
}
api.On("GetUser", mock.AnythingOfType("string")).Return(&testUser, nil).Once()
api.On("LogDebug", mock.AnythingOfType("string"), mock.AnythingOfType("string"), mock.AnythingOfType("string"))

p := Plugin{}
p.SetAPI(api)
p.OnConfigurationChange()

post := &model.Post{Message: "Welcome to Mattermost!"}
rpost, _ := p.MessageWillBePosted(&plugin.Context{}, post)

assert.Nil(t, rpost)
}

func TestHashtags(t *testing.T) {
conf := Config{
Links: []autolink.Autolink{
Expand Down Expand Up @@ -312,6 +411,11 @@ func TestHashtags(t *testing.T) {
api.On("GetChannel", mock.AnythingOfType("string")).Return(&testChannel, nil)
api.On("GetTeam", mock.AnythingOfType("string")).Return(&testTeam, nil)

testUser := model.User{
IsBot: false,
}
api.On("GetUser", mock.AnythingOfType("string")).Return(&testUser, nil)

p := Plugin{}
p.SetAPI(api)
p.OnConfigurationChange()
Expand Down

0 comments on commit 2c0ad05

Please sign in to comment.