From cf7a05f80f68b5b1c8bcc0089679dd497cec2506 Mon Sep 17 00:00:00 2001 From: =Corey Hulen Date: Sun, 14 Jun 2015 23:53:32 -0800 Subject: first commit --- api/command_test.go | 146 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 146 insertions(+) create mode 100644 api/command_test.go (limited to 'api/command_test.go') diff --git a/api/command_test.go b/api/command_test.go new file mode 100644 index 000000000..d3b0da455 --- /dev/null +++ b/api/command_test.go @@ -0,0 +1,146 @@ +// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved. +// See License.txt for license information. + +package api + +import ( + "github.com/mattermost/platform/model" + "testing" +) + +func TestSuggestRootCommands(t *testing.T) { + Setup() + + team := &model.Team{Name: "Name", Domain: "z-z-" + model.NewId() + "a", Email: "test@nowhere.com", Type: model.TEAM_OPEN} + team = Client.Must(Client.CreateTeam(team)).Data.(*model.Team) + + user1 := &model.User{TeamId: team.Id, Email: model.NewId() + "corey@test.com", FullName: "Corey Hulen", Password: "pwd"} + user1 = Client.Must(Client.CreateUser(user1, "")).Data.(*model.User) + Srv.Store.User().VerifyEmail(user1.Id) + + Client.LoginByEmail(team.Domain, user1.Email, "pwd") + + if _, err := Client.Command("", "", true); err == nil { + t.Fatal("Should fail") + } + + rs1 := Client.Must(Client.Command("", "/", true)).Data.(*model.Command) + + hasLogout := false + for _, v := range rs1.Suggestions { + if v.Suggestion == "/logout" { + hasLogout = true + } + } + + if !hasLogout { + t.Log(rs1.Suggestions) + t.Fatal("should have logout cmd") + } + + rs2 := Client.Must(Client.Command("", "/log", true)).Data.(*model.Command) + + if rs2.Suggestions[0].Suggestion != "/logout" { + t.Fatal("should have logout cmd") + } + + rs3 := Client.Must(Client.Command("", "/joi", true)).Data.(*model.Command) + + if rs3.Suggestions[0].Suggestion != "/join" { + t.Fatal("should have join cmd") + } +} + +func TestLogoutCommands(t *testing.T) { + Setup() + + team := &model.Team{Name: "Name", Domain: "z-z-" + model.NewId() + "a", Email: "test@nowhere.com", Type: model.TEAM_OPEN} + team = Client.Must(Client.CreateTeam(team)).Data.(*model.Team) + + user1 := &model.User{TeamId: team.Id, Email: model.NewId() + "corey@test.com", FullName: "Corey Hulen", Password: "pwd"} + user1 = Client.Must(Client.CreateUser(user1, "")).Data.(*model.User) + Srv.Store.User().VerifyEmail(user1.Id) + + Client.LoginByEmail(team.Domain, user1.Email, "pwd") + + rs1 := Client.Must(Client.Command("", "/logout", false)).Data.(*model.Command) + if rs1.GotoLocation != "/logout" { + t.Fatal("failed to logout") + } +} + +func TestJoinCommands(t *testing.T) { + Setup() + + team := &model.Team{Name: "Name", Domain: "z-z-" + model.NewId() + "a", Email: "test@nowhere.com", Type: model.TEAM_OPEN} + team = Client.Must(Client.CreateTeam(team)).Data.(*model.Team) + + user1 := &model.User{TeamId: team.Id, Email: model.NewId() + "corey@test.com", FullName: "Corey Hulen", Password: "pwd"} + user1 = Client.Must(Client.CreateUser(user1, "")).Data.(*model.User) + Srv.Store.User().VerifyEmail(user1.Id) + + Client.LoginByEmail(team.Domain, user1.Email, "pwd") + + channel1 := &model.Channel{DisplayName: "AA", Name: "aa" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} + channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) + Client.Must(Client.LeaveChannel(channel1.Id)) + + channel2 := &model.Channel{DisplayName: "BB", Name: "bb" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} + channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) + Client.Must(Client.LeaveChannel(channel2.Id)) + + user2 := &model.User{TeamId: team.Id, Email: model.NewId() + "corey@test.com", FullName: "Corey Hulen", Password: "pwd"} + user2 = Client.Must(Client.CreateUser(user2, "")).Data.(*model.User) + Srv.Store.User().VerifyEmail(user1.Id) + + data := make(map[string]string) + data["user_id"] = user2.Id + channel3 := Client.Must(Client.CreateDirectChannel(data)).Data.(*model.Channel) + + rs1 := Client.Must(Client.Command("", "/join aa", true)).Data.(*model.Command) + if rs1.Suggestions[0].Suggestion != "/join "+channel1.Name { + t.Fatal("should have join cmd") + } + + rs2 := Client.Must(Client.Command("", "/join bb", true)).Data.(*model.Command) + if rs2.Suggestions[0].Suggestion != "/join "+channel2.Name { + t.Fatal("should have join cmd") + } + + rs3 := Client.Must(Client.Command("", "/join", true)).Data.(*model.Command) + if len(rs3.Suggestions) != 2 { + t.Fatal("should have 2 join cmd") + } + + rs4 := Client.Must(Client.Command("", "/join ", true)).Data.(*model.Command) + if len(rs4.Suggestions) != 2 { + t.Fatal("should have 2 join cmd") + } + + rs5 := Client.Must(Client.Command("", "/join "+channel2.Name, false)).Data.(*model.Command) + if rs5.GotoLocation != "/channels/"+channel2.Name { + t.Fatal("failed to join channel") + } + + rs6 := Client.Must(Client.Command("", "/join "+channel3.Name, false)).Data.(*model.Command) + if rs6.GotoLocation == "/channels/"+channel3.Name { + t.Fatal("should not have joined direct message channel") + } + + c1 := Client.Must(Client.GetChannels("")).Data.(*model.ChannelList) + + if len(c1.Channels) != 3 { // 3 because of town-square and direct + t.Fatal("didn't join channel") + } + + found := false + for _, c := range c1.Channels { + if c.Name == channel2.Name { + found = true + break + } + } + if !found { + t.Fatal("didn't join channel") + } +} -- cgit v1.2.3-1-g7c22