// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved. // See LICENSE.txt for license information. package slashcommands import ( "testing" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" "github.com/mattermost/mattermost/server/public/model" ) func TestRemoveProviderDoCommand(t *testing.T) { th := setup(t).initBasic(t) rp := RemoveProvider{} publicChannel, _ := th.App.CreateChannel(th.Context, &model.Channel{ DisplayName: "AA", Name: "aa" + model.NewId() + "a", Type: model.ChannelTypeOpen, TeamId: th.BasicTeam.Id, CreatorId: th.BasicUser.Id, }, false) privateChannel, _ := th.App.CreateChannel(th.Context, &model.Channel{ DisplayName: "BB", Name: "aa" + model.NewId() + "a", Type: model.ChannelTypeOpen, TeamId: th.BasicTeam.Id, CreatorId: th.BasicUser.Id, }, false) targetUser := th.createUser(t) _, _, err := th.App.AddUserToTeam(th.Context, th.BasicTeam.Id, targetUser.Id, targetUser.Id) require.Nil(t, err) _, err = th.App.AddUserToChannel(th.Context, targetUser, publicChannel, false) require.Nil(t, err) _, err = th.App.AddUserToChannel(th.Context, targetUser, privateChannel, false) require.Nil(t, err) // Try a public channel *without* permission. args := &model.CommandArgs{ T: func(s string, args ...any) string { return s }, ChannelId: publicChannel.Id, UserId: th.BasicUser.Id, } actual := rp.DoCommand(th.App, th.Context, args, targetUser.Username).Text assert.Equal(t, "api.command_remove.permission.app_error", actual) // Try a public channel *with* permission. _, err = th.App.AddUserToChannel(th.Context, th.BasicUser, publicChannel, false) require.Nil(t, err) args = &model.CommandArgs{ T: func(s string, args ...any) string { return s }, ChannelId: publicChannel.Id, UserId: th.BasicUser.Id, } actual = rp.DoCommand(th.App, th.Context, args, targetUser.Username).Text assert.Equal(t, "", actual) // Try a private channel *without* permission. args = &model.CommandArgs{ T: func(s string, args ...any) string { return s }, ChannelId: privateChannel.Id, UserId: th.BasicUser.Id, } actual = rp.DoCommand(th.App, th.Context, args, targetUser.Username).Text assert.Equal(t, "api.command_remove.permission.app_error", actual) // Try a private channel *with* permission. _, err = th.App.AddUserToChannel(th.Context, th.BasicUser, privateChannel, false) require.Nil(t, err) args = &model.CommandArgs{ T: func(s string, args ...any) string { return s }, ChannelId: privateChannel.Id, UserId: th.BasicUser.Id, } actual = rp.DoCommand(th.App, th.Context, args, targetUser.Username).Text assert.Equal(t, "", actual) // Try a group channel user1 := th.createUser(t) user2 := th.createUser(t) groupChannel := th.createGroupChannel(t, user1, user2) args = &model.CommandArgs{ T: func(s string, args ...any) string { return s }, ChannelId: groupChannel.Id, UserId: th.BasicUser.Id, } actual = rp.DoCommand(th.App, th.Context, args, user1.Username).Text assert.Equal(t, "api.command_remove.direct_group.app_error", actual) // Try a direct channel *with* being a member. directChannel := th.createDmChannel(t, user1) args = &model.CommandArgs{ T: func(s string, args ...any) string { return s }, ChannelId: directChannel.Id, UserId: th.BasicUser.Id, } actual = rp.DoCommand(th.App, th.Context, args, user1.Username).Text assert.Equal(t, "api.command_remove.direct_group.app_error", actual) // Try a public channel with a deactivated user. deactivatedUser := th.createUser(t) _, _, err = th.App.AddUserToTeam(th.Context, th.BasicTeam.Id, deactivatedUser.Id, deactivatedUser.Id) require.Nil(t, err) _, err = th.App.AddUserToChannel(th.Context, deactivatedUser, publicChannel, false) require.Nil(t, err) _, err = th.App.UpdateActive(th.Context, deactivatedUser, false) require.Nil(t, err) args = &model.CommandArgs{ T: func(s string, args ...any) string { return s }, ChannelId: publicChannel.Id, UserId: th.BasicUser.Id, } actual = rp.DoCommand(th.App, th.Context, args, deactivatedUser.Username).Text assert.Equal(t, "api.command_remove.missing.app_error", actual) }