user_test.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. package sqlstore
  2. import (
  3. "context"
  4. "fmt"
  5. "testing"
  6. . "github.com/smartystreets/goconvey/convey"
  7. m "github.com/grafana/grafana/pkg/models"
  8. )
  9. func TestUserDataAccess(t *testing.T) {
  10. Convey("Testing DB", t, func() {
  11. InitTestDB(t)
  12. Convey("Given 5 users", func() {
  13. var err error
  14. var cmd *m.CreateUserCommand
  15. users := []m.User{}
  16. for i := 0; i < 5; i++ {
  17. cmd = &m.CreateUserCommand{
  18. Email: fmt.Sprint("user", i, "@test.com"),
  19. Name: fmt.Sprint("user", i),
  20. Login: fmt.Sprint("loginuser", i),
  21. }
  22. err = CreateUser(context.Background(), cmd)
  23. So(err, ShouldBeNil)
  24. users = append(users, cmd.Result)
  25. }
  26. Convey("Can return the first page of users and a total count", func() {
  27. query := m.SearchUsersQuery{Query: "", Page: 1, Limit: 3}
  28. err = SearchUsers(&query)
  29. So(err, ShouldBeNil)
  30. So(len(query.Result.Users), ShouldEqual, 3)
  31. So(query.Result.TotalCount, ShouldEqual, 5)
  32. })
  33. Convey("Can return the second page of users and a total count", func() {
  34. query := m.SearchUsersQuery{Query: "", Page: 2, Limit: 3}
  35. err = SearchUsers(&query)
  36. So(err, ShouldBeNil)
  37. So(len(query.Result.Users), ShouldEqual, 2)
  38. So(query.Result.TotalCount, ShouldEqual, 5)
  39. })
  40. Convey("Can return list of users matching query on user name", func() {
  41. query := m.SearchUsersQuery{Query: "use", Page: 1, Limit: 3}
  42. err = SearchUsers(&query)
  43. So(err, ShouldBeNil)
  44. So(len(query.Result.Users), ShouldEqual, 3)
  45. So(query.Result.TotalCount, ShouldEqual, 5)
  46. query = m.SearchUsersQuery{Query: "ser1", Page: 1, Limit: 3}
  47. err = SearchUsers(&query)
  48. So(err, ShouldBeNil)
  49. So(len(query.Result.Users), ShouldEqual, 1)
  50. So(query.Result.TotalCount, ShouldEqual, 1)
  51. query = m.SearchUsersQuery{Query: "USER1", Page: 1, Limit: 3}
  52. err = SearchUsers(&query)
  53. So(err, ShouldBeNil)
  54. So(len(query.Result.Users), ShouldEqual, 1)
  55. So(query.Result.TotalCount, ShouldEqual, 1)
  56. query = m.SearchUsersQuery{Query: "idontexist", Page: 1, Limit: 3}
  57. err = SearchUsers(&query)
  58. So(err, ShouldBeNil)
  59. So(len(query.Result.Users), ShouldEqual, 0)
  60. So(query.Result.TotalCount, ShouldEqual, 0)
  61. })
  62. Convey("Can return list of users matching query on email", func() {
  63. query := m.SearchUsersQuery{Query: "ser1@test.com", Page: 1, Limit: 3}
  64. err = SearchUsers(&query)
  65. So(err, ShouldBeNil)
  66. So(len(query.Result.Users), ShouldEqual, 1)
  67. So(query.Result.TotalCount, ShouldEqual, 1)
  68. })
  69. Convey("Can return list of users matching query on login name", func() {
  70. query := m.SearchUsersQuery{Query: "loginuser1", Page: 1, Limit: 3}
  71. err = SearchUsers(&query)
  72. So(err, ShouldBeNil)
  73. So(len(query.Result.Users), ShouldEqual, 1)
  74. So(query.Result.TotalCount, ShouldEqual, 1)
  75. })
  76. Convey("when a user is an org member and has been assigned permissions", func() {
  77. err = AddOrgUser(&m.AddOrgUserCommand{LoginOrEmail: users[0].Login, Role: m.ROLE_VIEWER, OrgId: users[0].OrgId})
  78. So(err, ShouldBeNil)
  79. testHelperUpdateDashboardAcl(1, m.DashboardAcl{DashboardId: 1, OrgId: users[0].OrgId, UserId: users[0].Id, Permission: m.PERMISSION_EDIT})
  80. So(err, ShouldBeNil)
  81. err = SavePreferences(&m.SavePreferencesCommand{UserId: users[0].Id, OrgId: users[0].OrgId, HomeDashboardId: 1, Theme: "dark"})
  82. So(err, ShouldBeNil)
  83. Convey("when the user is deleted", func() {
  84. err = DeleteUser(&m.DeleteUserCommand{UserId: users[0].Id})
  85. So(err, ShouldBeNil)
  86. Convey("Should delete connected org users and permissions", func() {
  87. query := &m.GetOrgUsersQuery{OrgId: 1}
  88. err = GetOrgUsersForTest(query)
  89. So(err, ShouldBeNil)
  90. So(len(query.Result), ShouldEqual, 1)
  91. permQuery := &m.GetDashboardAclInfoListQuery{DashboardId: 1, OrgId: 1}
  92. err = GetDashboardAclInfoList(permQuery)
  93. So(err, ShouldBeNil)
  94. So(len(permQuery.Result), ShouldEqual, 0)
  95. prefsQuery := &m.GetPreferencesQuery{OrgId: users[0].OrgId, UserId: users[0].Id}
  96. err = GetPreferences(prefsQuery)
  97. So(err, ShouldBeNil)
  98. So(prefsQuery.Result.OrgId, ShouldEqual, 0)
  99. So(prefsQuery.Result.UserId, ShouldEqual, 0)
  100. })
  101. })
  102. })
  103. })
  104. })
  105. }
  106. func GetOrgUsersForTest(query *m.GetOrgUsersQuery) error {
  107. query.Result = make([]*m.OrgUserDTO, 0)
  108. sess := x.Table("org_user")
  109. sess.Join("LEFT ", "user", fmt.Sprintf("org_user.user_id=%s.id", x.Dialect().Quote("user")))
  110. sess.Where("org_user.org_id=?", query.OrgId)
  111. sess.Cols("org_user.org_id", "org_user.user_id", "user.email", "user.login", "org_user.role")
  112. err := sess.Find(&query.Result)
  113. return err
  114. }