team_test.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. package sqlstore
  2. import (
  3. "fmt"
  4. "testing"
  5. . "github.com/smartystreets/goconvey/convey"
  6. m "github.com/grafana/grafana/pkg/models"
  7. )
  8. func TestTeamCommandsAndQueries(t *testing.T) {
  9. Convey("Testing Team commands & queries", t, func() {
  10. InitTestDB(t)
  11. Convey("Given saved users and two teams", func() {
  12. var userIds []int64
  13. for i := 0; i < 5; i++ {
  14. userCmd := &m.CreateUserCommand{
  15. Email: fmt.Sprint("user", i, "@test.com"),
  16. Name: fmt.Sprint("user", i),
  17. Login: fmt.Sprint("loginuser", i),
  18. }
  19. err := CreateUser(userCmd)
  20. So(err, ShouldBeNil)
  21. userIds = append(userIds, userCmd.Result.Id)
  22. }
  23. group1 := m.CreateTeamCommand{Name: "group1 name"}
  24. group2 := m.CreateTeamCommand{Name: "group2 name"}
  25. err := CreateTeam(&group1)
  26. So(err, ShouldBeNil)
  27. err = CreateTeam(&group2)
  28. So(err, ShouldBeNil)
  29. Convey("Should be able to create teams and add users", func() {
  30. query := &m.SearchTeamsQuery{Name: "group1 name", Page: 1, Limit: 10}
  31. err = SearchTeams(query)
  32. So(err, ShouldBeNil)
  33. So(query.Page, ShouldEqual, 1)
  34. team1 := query.Result.Teams[0]
  35. So(team1.Name, ShouldEqual, "group1 name")
  36. err = AddTeamMember(&m.AddTeamMemberCommand{OrgId: 1, TeamId: team1.Id, UserId: userIds[0]})
  37. So(err, ShouldBeNil)
  38. q1 := &m.GetTeamMembersQuery{TeamId: team1.Id}
  39. err = GetTeamMembers(q1)
  40. So(err, ShouldBeNil)
  41. So(q1.Result[0].TeamId, ShouldEqual, team1.Id)
  42. So(q1.Result[0].Login, ShouldEqual, "loginuser0")
  43. })
  44. Convey("Should be able to search for teams", func() {
  45. query := &m.SearchTeamsQuery{Query: "group", Page: 1}
  46. err = SearchTeams(query)
  47. So(err, ShouldBeNil)
  48. So(len(query.Result.Teams), ShouldEqual, 2)
  49. So(query.Result.TotalCount, ShouldEqual, 2)
  50. query2 := &m.SearchTeamsQuery{Query: ""}
  51. err = SearchTeams(query2)
  52. So(err, ShouldBeNil)
  53. So(len(query2.Result.Teams), ShouldEqual, 2)
  54. })
  55. Convey("Should be able to return all teams a user is member of", func() {
  56. groupId := group2.Result.Id
  57. err := AddTeamMember(&m.AddTeamMemberCommand{OrgId: 1, TeamId: groupId, UserId: userIds[0]})
  58. query := &m.GetTeamsByUserQuery{UserId: userIds[0]}
  59. err = GetTeamsByUser(query)
  60. So(err, ShouldBeNil)
  61. So(len(query.Result), ShouldEqual, 1)
  62. So(query.Result[0].Name, ShouldEqual, "group2 name")
  63. })
  64. Convey("Should be able to remove users from a group", func() {
  65. err = RemoveTeamMember(&m.RemoveTeamMemberCommand{TeamId: group1.Result.Id, UserId: userIds[0]})
  66. So(err, ShouldBeNil)
  67. q1 := &m.GetTeamMembersQuery{TeamId: group1.Result.Id}
  68. err = GetTeamMembers(q1)
  69. So(err, ShouldBeNil)
  70. So(len(q1.Result), ShouldEqual, 0)
  71. })
  72. Convey("Should be able to remove a group with users and permissions", func() {
  73. groupId := group2.Result.Id
  74. err := AddTeamMember(&m.AddTeamMemberCommand{OrgId: 1, TeamId: groupId, UserId: userIds[1]})
  75. So(err, ShouldBeNil)
  76. err = AddTeamMember(&m.AddTeamMemberCommand{OrgId: 1, TeamId: groupId, UserId: userIds[2]})
  77. So(err, ShouldBeNil)
  78. err = SetDashboardAcl(&m.SetDashboardAclCommand{DashboardId: 1, OrgId: 1, Permission: m.PERMISSION_EDIT, TeamId: groupId})
  79. err = DeleteTeam(&m.DeleteTeamCommand{Id: groupId})
  80. So(err, ShouldBeNil)
  81. query := &m.GetTeamByIdQuery{Id: groupId}
  82. err = GetTeamById(query)
  83. So(err, ShouldEqual, m.ErrTeamNotFound)
  84. permQuery := &m.GetDashboardAclInfoListQuery{DashboardId: 1, OrgId: 1}
  85. err = GetDashboardAclInfoList(permQuery)
  86. So(err, ShouldBeNil)
  87. So(len(permQuery.Result), ShouldEqual, 0)
  88. })
  89. })
  90. })
  91. }