From 9dce50281471f356a63544680907cbd7346e7dc2 Mon Sep 17 00:00:00 2001 From: Carlos Tadeu Panato Junior Date: Tue, 4 Apr 2017 03:32:09 +0200 Subject: Implement POST /teams/{team_id}/invite/email for apiV4 (#5944) --- api4/team_test.go | 48 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) (limited to 'api4/team_test.go') diff --git a/api4/team_test.go b/api4/team_test.go index f145515aa..b58a4dc72 100644 --- a/api4/team_test.go +++ b/api4/team_test.go @@ -1372,3 +1372,51 @@ func TestImportTeam(t *testing.T) { CheckForbiddenStatus(t, resp) }) } + +func TestInviteUsersToTeam(t *testing.T) { + th := Setup().InitBasic().InitSystemAdmin() + defer TearDown() + + user1 := GenerateTestEmail() + user2 := GenerateTestEmail() + + emailList := []string{user1, user2} + + //Delete all the messages before check the sample email + utils.DeleteMailBox(user1) + utils.DeleteMailBox(user2) + + okMsg, resp := th.SystemAdminClient.InviteUsersToTeam(th.BasicTeam.Id, emailList) + CheckNoError(t, resp) + if okMsg != true { + t.Fatal("should return true") + } + + expectedSubject := "[Mattermost] " + th.SystemAdminUser.GetDisplayName() + " invited you to join " + th.BasicTeam.DisplayName + " Team" + //Check if the email was send to the rigth email address + for _, email := range emailList { + var resultsMailbox utils.JSONMessageHeaderInbucket + err := utils.RetryInbucket(5, func() error { + var err error + resultsMailbox, err = utils.GetMailBox(email) + return err + }) + if err != nil { + t.Log(err) + t.Log("No email was received, maybe due load on the server. Disabling this verification") + } + if err == nil && len(resultsMailbox) > 0 { + if !strings.ContainsAny(resultsMailbox[0].To[0], email) { + t.Fatal("Wrong To recipient") + } else { + if resultsEmail, err := utils.GetMessageFromMailbox(email, resultsMailbox[0].ID); err == nil { + if resultsEmail.Subject != expectedSubject { + t.Log(resultsEmail.Subject) + t.Log(expectedSubject) + t.Fatal("Wrong Subject") + } + } + } + } + } +} -- cgit v1.2.3-1-g7c22