user_test.go 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  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. ss := InitTestDB(t)
  12. Convey("Creating a user", func() {
  13. cmd := &m.CreateUserCommand{
  14. Email: "usertest@test.com",
  15. Name: "user name",
  16. Login: "user_test_login",
  17. }
  18. err := CreateUser(context.Background(), cmd)
  19. So(err, ShouldBeNil)
  20. Convey("Loading a user", func() {
  21. query := m.GetUserByIdQuery{Id: cmd.Result.Id}
  22. err := GetUserById(&query)
  23. So(err, ShouldBeNil)
  24. So(query.Result.Email, ShouldEqual, "usertest@test.com")
  25. So(query.Result.Password, ShouldEqual, "")
  26. So(query.Result.Rands, ShouldHaveLength, 10)
  27. So(query.Result.Salt, ShouldHaveLength, 10)
  28. })
  29. })
  30. Convey("Given 5 users", func() {
  31. var err error
  32. var cmd *m.CreateUserCommand
  33. users := []m.User{}
  34. for i := 0; i < 5; i++ {
  35. cmd = &m.CreateUserCommand{
  36. Email: fmt.Sprint("user", i, "@test.com"),
  37. Name: fmt.Sprint("user", i),
  38. Login: fmt.Sprint("loginuser", i),
  39. }
  40. err = CreateUser(context.Background(), cmd)
  41. So(err, ShouldBeNil)
  42. users = append(users, cmd.Result)
  43. }
  44. Convey("Can return the first page of users and a total count", func() {
  45. query := m.SearchUsersQuery{Query: "", Page: 1, Limit: 3}
  46. err = SearchUsers(&query)
  47. So(err, ShouldBeNil)
  48. So(len(query.Result.Users), ShouldEqual, 3)
  49. So(query.Result.TotalCount, ShouldEqual, 5)
  50. })
  51. Convey("Can return the second page of users and a total count", func() {
  52. query := m.SearchUsersQuery{Query: "", Page: 2, Limit: 3}
  53. err = SearchUsers(&query)
  54. So(err, ShouldBeNil)
  55. So(len(query.Result.Users), ShouldEqual, 2)
  56. So(query.Result.TotalCount, ShouldEqual, 5)
  57. })
  58. Convey("Can return list of users matching query on user name", func() {
  59. query := m.SearchUsersQuery{Query: "use", Page: 1, Limit: 3}
  60. err = SearchUsers(&query)
  61. So(err, ShouldBeNil)
  62. So(len(query.Result.Users), ShouldEqual, 3)
  63. So(query.Result.TotalCount, ShouldEqual, 5)
  64. query = m.SearchUsersQuery{Query: "ser1", Page: 1, Limit: 3}
  65. err = SearchUsers(&query)
  66. So(err, ShouldBeNil)
  67. So(len(query.Result.Users), ShouldEqual, 1)
  68. So(query.Result.TotalCount, ShouldEqual, 1)
  69. query = m.SearchUsersQuery{Query: "USER1", Page: 1, Limit: 3}
  70. err = SearchUsers(&query)
  71. So(err, ShouldBeNil)
  72. So(len(query.Result.Users), ShouldEqual, 1)
  73. So(query.Result.TotalCount, ShouldEqual, 1)
  74. query = m.SearchUsersQuery{Query: "idontexist", Page: 1, Limit: 3}
  75. err = SearchUsers(&query)
  76. So(err, ShouldBeNil)
  77. So(len(query.Result.Users), ShouldEqual, 0)
  78. So(query.Result.TotalCount, ShouldEqual, 0)
  79. })
  80. Convey("Can return list of users matching query on email", func() {
  81. query := m.SearchUsersQuery{Query: "ser1@test.com", Page: 1, Limit: 3}
  82. err = SearchUsers(&query)
  83. So(err, ShouldBeNil)
  84. So(len(query.Result.Users), ShouldEqual, 1)
  85. So(query.Result.TotalCount, ShouldEqual, 1)
  86. })
  87. Convey("Can return list of users matching query on login name", func() {
  88. query := m.SearchUsersQuery{Query: "loginuser1", Page: 1, Limit: 3}
  89. err = SearchUsers(&query)
  90. So(err, ShouldBeNil)
  91. So(len(query.Result.Users), ShouldEqual, 1)
  92. So(query.Result.TotalCount, ShouldEqual, 1)
  93. })
  94. Convey("when a user is an org member and has been assigned permissions", func() {
  95. err = AddOrgUser(&m.AddOrgUserCommand{LoginOrEmail: users[1].Login, Role: m.ROLE_VIEWER, OrgId: users[0].OrgId, UserId: users[1].Id})
  96. So(err, ShouldBeNil)
  97. testHelperUpdateDashboardAcl(1, m.DashboardAcl{DashboardId: 1, OrgId: users[0].OrgId, UserId: users[1].Id, Permission: m.PERMISSION_EDIT})
  98. So(err, ShouldBeNil)
  99. err = SavePreferences(&m.SavePreferencesCommand{UserId: users[1].Id, OrgId: users[0].OrgId, HomeDashboardId: 1, Theme: "dark"})
  100. So(err, ShouldBeNil)
  101. Convey("when the user is deleted", func() {
  102. err = DeleteUser(&m.DeleteUserCommand{UserId: users[1].Id})
  103. So(err, ShouldBeNil)
  104. Convey("Should delete connected org users and permissions", func() {
  105. query := &m.GetOrgUsersQuery{OrgId: users[0].OrgId}
  106. err = GetOrgUsersForTest(query)
  107. So(err, ShouldBeNil)
  108. So(len(query.Result), ShouldEqual, 1)
  109. permQuery := &m.GetDashboardAclInfoListQuery{DashboardId: 1, OrgId: users[0].OrgId}
  110. err = GetDashboardAclInfoList(permQuery)
  111. So(err, ShouldBeNil)
  112. So(len(permQuery.Result), ShouldEqual, 0)
  113. prefsQuery := &m.GetPreferencesQuery{OrgId: users[0].OrgId, UserId: users[1].Id}
  114. err = GetPreferences(prefsQuery)
  115. So(err, ShouldBeNil)
  116. So(prefsQuery.Result.OrgId, ShouldEqual, 0)
  117. So(prefsQuery.Result.UserId, ShouldEqual, 0)
  118. })
  119. })
  120. Convey("when retreiving signed in user for orgId=0 result should return active org id", func() {
  121. ss.CacheService.Flush()
  122. query := &m.GetSignedInUserQuery{OrgId: users[1].OrgId, UserId: users[1].Id}
  123. err := ss.GetSignedInUserWithCache(query)
  124. So(err, ShouldBeNil)
  125. So(query.Result, ShouldNotBeNil)
  126. So(query.OrgId, ShouldEqual, users[1].OrgId)
  127. err = SetUsingOrg(&m.SetUsingOrgCommand{UserId: users[1].Id, OrgId: users[0].OrgId})
  128. So(err, ShouldBeNil)
  129. query = &m.GetSignedInUserQuery{OrgId: 0, UserId: users[1].Id}
  130. err = ss.GetSignedInUserWithCache(query)
  131. So(err, ShouldBeNil)
  132. So(query.Result, ShouldNotBeNil)
  133. So(query.Result.OrgId, ShouldEqual, users[0].OrgId)
  134. cacheKey := newSignedInUserCacheKey(query.Result.OrgId, query.UserId)
  135. _, found := ss.CacheService.Get(cacheKey)
  136. So(found, ShouldBeTrue)
  137. })
  138. })
  139. })
  140. Convey("Given one grafana admin user", func() {
  141. var err error
  142. createUserCmd := &m.CreateUserCommand{
  143. Email: fmt.Sprint("admin", "@test.com"),
  144. Name: fmt.Sprint("admin"),
  145. Login: fmt.Sprint("admin"),
  146. IsAdmin: true,
  147. }
  148. err = CreateUser(context.Background(), createUserCmd)
  149. So(err, ShouldBeNil)
  150. Convey("Cannot make themselves a non-admin", func() {
  151. updateUserPermsCmd := m.UpdateUserPermissionsCommand{IsGrafanaAdmin: false, UserId: 1}
  152. updatePermsError := UpdateUserPermissions(&updateUserPermsCmd)
  153. So(updatePermsError, ShouldEqual, m.ErrLastGrafanaAdmin)
  154. query := m.GetUserByIdQuery{Id: createUserCmd.Result.Id}
  155. getUserError := GetUserById(&query)
  156. So(getUserError, ShouldBeNil)
  157. So(query.Result.IsAdmin, ShouldEqual, true)
  158. })
  159. })
  160. })
  161. }
  162. func GetOrgUsersForTest(query *m.GetOrgUsersQuery) error {
  163. query.Result = make([]*m.OrgUserDTO, 0)
  164. sess := x.Table("org_user")
  165. sess.Join("LEFT ", x.Dialect().Quote("user"), fmt.Sprintf("org_user.user_id=%s.id", x.Dialect().Quote("user")))
  166. sess.Where("org_user.org_id=?", query.OrgId)
  167. sess.Cols("org_user.org_id", "org_user.user_id", "user.email", "user.login", "org_user.role")
  168. err := sess.Find(&query.Result)
  169. return err
  170. }