diff options
author | Joram Wilander <jwawilander@gmail.com> | 2017-03-23 06:34:22 -0400 |
---|---|---|
committer | George Goldberg <george@gberg.me> | 2017-03-23 10:34:22 +0000 |
commit | 2a753949f10f70de26dba9fbff7c5ef9583d6c86 (patch) | |
tree | 4430844f254e62afdcf7b0e61da5870f2c8f7061 /api4/user_test.go | |
parent | 7e2e8238842c7d158211faafe03f814bffa78a8f (diff) | |
download | chat-2a753949f10f70de26dba9fbff7c5ef9583d6c86.tar.gz chat-2a753949f10f70de26dba9fbff7c5ef9583d6c86.tar.bz2 chat-2a753949f10f70de26dba9fbff7c5ef9583d6c86.zip |
Implement POST /users/search endpoint for APIv4 (#5822)
* Implement POST /users/search endpoint for APIv4
* PLT-2713 Added store functions for searching users that don't have a team
* PLT-2713 Added 'without_team' option when searching users
* PLT-2713 Added 'without_team' option when searching users (v4)
Diffstat (limited to 'api4/user_test.go')
-rw-r--r-- | api4/user_test.go | 150 |
1 files changed, 150 insertions, 0 deletions
diff --git a/api4/user_test.go b/api4/user_test.go index 923caa761..53dbd53e8 100644 --- a/api4/user_test.go +++ b/api4/user_test.go @@ -284,6 +284,156 @@ func TestGetUserByEmail(t *testing.T) { } } +func TestSearchUsers(t *testing.T) { + th := Setup().InitBasic().InitSystemAdmin() + defer TearDown() + Client := th.Client + + search := &model.UserSearch{Term: th.BasicUser.Username} + + users, resp := Client.SearchUsers(search) + CheckNoError(t, resp) + + if !findUserInList(th.BasicUser.Id, users) { + t.Fatal("should have found user") + } + + _, err := app.UpdateActiveNoLdap(th.BasicUser2.Id, false) + if err != nil { + t.Fatal(err) + } + + search.Term = th.BasicUser2.Username + search.AllowInactive = false + + users, resp = Client.SearchUsers(search) + CheckNoError(t, resp) + + if findUserInList(th.BasicUser2.Id, users) { + t.Fatal("should not have found user") + } + + search.AllowInactive = true + + users, resp = Client.SearchUsers(search) + CheckNoError(t, resp) + + if !findUserInList(th.BasicUser2.Id, users) { + t.Fatal("should have found user") + } + + search.Term = th.BasicUser.Username + search.AllowInactive = false + search.TeamId = th.BasicTeam.Id + + users, resp = Client.SearchUsers(search) + CheckNoError(t, resp) + + if !findUserInList(th.BasicUser.Id, users) { + t.Fatal("should have found user") + } + + search.NotInChannelId = th.BasicChannel.Id + + users, resp = Client.SearchUsers(search) + CheckNoError(t, resp) + + if findUserInList(th.BasicUser.Id, users) { + t.Fatal("should not have found user") + } + + search.TeamId = "" + search.NotInChannelId = "" + search.InChannelId = th.BasicChannel.Id + + users, resp = Client.SearchUsers(search) + CheckNoError(t, resp) + + if !findUserInList(th.BasicUser.Id, users) { + t.Fatal("should have found user") + } + + search.InChannelId = "" + search.NotInChannelId = th.BasicChannel.Id + _, resp = Client.SearchUsers(search) + CheckBadRequestStatus(t, resp) + + search.NotInChannelId = model.NewId() + search.TeamId = model.NewId() + _, resp = Client.SearchUsers(search) + CheckForbiddenStatus(t, resp) + + search.NotInChannelId = "" + search.TeamId = model.NewId() + _, resp = Client.SearchUsers(search) + CheckForbiddenStatus(t, resp) + + search.InChannelId = model.NewId() + search.TeamId = "" + _, resp = Client.SearchUsers(search) + CheckForbiddenStatus(t, resp) + + emailPrivacy := utils.Cfg.PrivacySettings.ShowEmailAddress + namePrivacy := utils.Cfg.PrivacySettings.ShowFullName + defer func() { + utils.Cfg.PrivacySettings.ShowEmailAddress = emailPrivacy + utils.Cfg.PrivacySettings.ShowFullName = namePrivacy + }() + utils.Cfg.PrivacySettings.ShowEmailAddress = false + utils.Cfg.PrivacySettings.ShowFullName = false + + _, err = app.UpdateActiveNoLdap(th.BasicUser2.Id, true) + if err != nil { + t.Fatal(err) + } + + search.InChannelId = "" + search.Term = th.BasicUser2.Email + users, resp = Client.SearchUsers(search) + CheckNoError(t, resp) + + if findUserInList(th.BasicUser2.Id, users) { + t.Fatal("should not have found user") + } + + search.Term = th.BasicUser2.FirstName + users, resp = Client.SearchUsers(search) + CheckNoError(t, resp) + + if findUserInList(th.BasicUser2.Id, users) { + t.Fatal("should not have found user") + } + + search.Term = th.BasicUser2.LastName + users, resp = Client.SearchUsers(search) + CheckNoError(t, resp) + + if findUserInList(th.BasicUser2.Id, users) { + t.Fatal("should not have found user") + } + + search.Term = th.BasicUser.FirstName + search.InChannelId = th.BasicChannel.Id + search.NotInChannelId = th.BasicChannel.Id + search.TeamId = th.BasicTeam.Id + users, resp = th.SystemAdminClient.SearchUsers(search) + CheckNoError(t, resp) + + if !findUserInList(th.BasicUser.Id, users) { + t.Fatal("should have found user") + } + +} + +func findUserInList(id string, users []*model.User) bool { + for _, user := range users { + if user.Id == id { + return true + } + } + return false +} + func TestAutocompleteUsers(t *testing.T) { th := Setup().InitBasic().InitSystemAdmin() defer TearDown() |