mirror of
https://github.com/mattermost/focalboard.git
synced 2025-01-11 18:13:52 +02:00
098868387e
* initial implementation of SysAdmin/TeamAdmin feature * fix adminBadge tests * updating tests * more fixes for unit tests * lint fixes * update snapshots * update cypress test for call change * add additional unit tests * update test for lint errors * fix reviews implement tests * fix for merge, reset dialog before redirection * remove unused test code * fix more tests * fix swagger doc for missing parameters --------- Co-authored-by: Mattermost Build <build@mattermost.com>
65 lines
2.4 KiB
Go
65 lines
2.4 KiB
Go
package app
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/mattermost/focalboard/server/model"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestSearchUsers(t *testing.T) {
|
|
th, tearDown := SetupTestHelper(t)
|
|
defer tearDown()
|
|
th.App.config.ShowEmailAddress = false
|
|
th.App.config.ShowFullName = false
|
|
|
|
teamID := "team-id-1"
|
|
userID := "user-id-1"
|
|
|
|
t.Run("return empty users", func(t *testing.T) {
|
|
th.Store.EXPECT().SearchUsersByTeam(teamID, "", "", true, false, false).Return([]*model.User{}, nil)
|
|
|
|
users, err := th.App.SearchTeamUsers(teamID, "", "", true)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, 0, len(users))
|
|
})
|
|
|
|
t.Run("return user", func(t *testing.T) {
|
|
th.Store.EXPECT().SearchUsersByTeam(teamID, "", "", true, false, false).Return([]*model.User{{ID: userID}}, nil)
|
|
th.API.EXPECT().HasPermissionToTeam(userID, teamID, model.PermissionManageTeam).Return(false).Times(1)
|
|
th.API.EXPECT().HasPermissionTo(userID, model.PermissionManageSystem).Return(false).Times(1)
|
|
|
|
users, err := th.App.SearchTeamUsers(teamID, "", "", true)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, 1, len(users))
|
|
assert.Equal(t, 0, len(users[0].Permissions))
|
|
})
|
|
|
|
t.Run("return team admin", func(t *testing.T) {
|
|
th.Store.EXPECT().SearchUsersByTeam(teamID, "", "", true, false, false).Return([]*model.User{{ID: userID}}, nil)
|
|
th.App.config.ShowEmailAddress = false
|
|
th.App.config.ShowFullName = false
|
|
th.API.EXPECT().HasPermissionToTeam(userID, teamID, model.PermissionManageTeam).Return(true).Times(1)
|
|
th.API.EXPECT().HasPermissionTo(userID, model.PermissionManageSystem).Return(false).Times(1)
|
|
|
|
users, err := th.App.SearchTeamUsers(teamID, "", "", true)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, 1, len(users))
|
|
assert.Equal(t, users[0].Permissions[0], model.PermissionManageTeam.Id)
|
|
})
|
|
|
|
t.Run("return system admin", func(t *testing.T) {
|
|
th.Store.EXPECT().SearchUsersByTeam(teamID, "", "", true, false, false).Return([]*model.User{{ID: userID}}, nil)
|
|
th.App.config.ShowEmailAddress = false
|
|
th.App.config.ShowFullName = false
|
|
th.API.EXPECT().HasPermissionToTeam(userID, teamID, model.PermissionManageTeam).Return(true).Times(1)
|
|
th.API.EXPECT().HasPermissionTo(userID, model.PermissionManageSystem).Return(true).Times(1)
|
|
|
|
users, err := th.App.SearchTeamUsers(teamID, "", "", true)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, 1, len(users))
|
|
assert.Equal(t, users[0].Permissions[0], model.PermissionManageTeam.Id)
|
|
assert.Equal(t, users[0].Permissions[1], model.PermissionManageSystem.Id)
|
|
})
|
|
}
|