user_test.go 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  1. package sqlstore
  2. import (
  3. "context"
  4. "fmt"
  5. "testing"
  6. . "github.com/smartystreets/goconvey/convey"
  7. "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 := &models.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 := models.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 *models.CreateUserCommand
  33. users := []models.User{}
  34. for i := 0; i < 5; i++ {
  35. cmd = &models.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 := models.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 := models.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 := models.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 = models.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 = models.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 = models.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 := models.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 := models.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("can return list users based on their auth type", func() {
  95. // add users to auth table
  96. for index, user := range users {
  97. authModule := "killa"
  98. // define every second user as ldap
  99. if index%2 == 0 {
  100. authModule = "ldap"
  101. }
  102. cmd2 := &models.SetAuthInfoCommand{
  103. UserId: user.Id,
  104. AuthModule: authModule,
  105. AuthId: "gorilla",
  106. }
  107. err = SetAuthInfo(cmd2)
  108. So(err, ShouldBeNil)
  109. }
  110. query := models.SearchUsersQuery{AuthModule: "ldap"}
  111. err = SearchUsers(&query)
  112. So(err, ShouldBeNil)
  113. So(query.Result.Users, ShouldHaveLength, 3)
  114. zero, second, fourth := false, false, false
  115. for _, user := range query.Result.Users {
  116. if user.Name == "user0" {
  117. zero = true
  118. }
  119. if user.Name == "user2" {
  120. second = true
  121. }
  122. if user.Name == "user4" {
  123. fourth = true
  124. }
  125. }
  126. So(zero, ShouldBeTrue)
  127. So(second, ShouldBeTrue)
  128. So(fourth, ShouldBeTrue)
  129. })
  130. Convey("when a user is an org member and has been assigned permissions", func() {
  131. err = AddOrgUser(&models.AddOrgUserCommand{LoginOrEmail: users[1].Login, Role: models.ROLE_VIEWER, OrgId: users[0].OrgId, UserId: users[1].Id})
  132. So(err, ShouldBeNil)
  133. testHelperUpdateDashboardAcl(1, models.DashboardAcl{DashboardId: 1, OrgId: users[0].OrgId, UserId: users[1].Id, Permission: models.PERMISSION_EDIT})
  134. So(err, ShouldBeNil)
  135. err = SavePreferences(&models.SavePreferencesCommand{UserId: users[1].Id, OrgId: users[0].OrgId, HomeDashboardId: 1, Theme: "dark"})
  136. So(err, ShouldBeNil)
  137. Convey("when the user is deleted", func() {
  138. err = DeleteUser(&models.DeleteUserCommand{UserId: users[1].Id})
  139. So(err, ShouldBeNil)
  140. Convey("Should delete connected org users and permissions", func() {
  141. query := &models.GetOrgUsersQuery{OrgId: users[0].OrgId}
  142. err = GetOrgUsersForTest(query)
  143. So(err, ShouldBeNil)
  144. So(len(query.Result), ShouldEqual, 1)
  145. permQuery := &models.GetDashboardAclInfoListQuery{DashboardId: 1, OrgId: users[0].OrgId}
  146. err = GetDashboardAclInfoList(permQuery)
  147. So(err, ShouldBeNil)
  148. So(len(permQuery.Result), ShouldEqual, 0)
  149. prefsQuery := &models.GetPreferencesQuery{OrgId: users[0].OrgId, UserId: users[1].Id}
  150. err = GetPreferences(prefsQuery)
  151. So(err, ShouldBeNil)
  152. So(prefsQuery.Result.OrgId, ShouldEqual, 0)
  153. So(prefsQuery.Result.UserId, ShouldEqual, 0)
  154. })
  155. })
  156. Convey("when retreiving signed in user for orgId=0 result should return active org id", func() {
  157. ss.CacheService.Flush()
  158. query := &models.GetSignedInUserQuery{OrgId: users[1].OrgId, UserId: users[1].Id}
  159. err := ss.GetSignedInUserWithCache(query)
  160. So(err, ShouldBeNil)
  161. So(query.Result, ShouldNotBeNil)
  162. So(query.OrgId, ShouldEqual, users[1].OrgId)
  163. err = SetUsingOrg(&models.SetUsingOrgCommand{UserId: users[1].Id, OrgId: users[0].OrgId})
  164. So(err, ShouldBeNil)
  165. query = &models.GetSignedInUserQuery{OrgId: 0, UserId: users[1].Id}
  166. err = ss.GetSignedInUserWithCache(query)
  167. So(err, ShouldBeNil)
  168. So(query.Result, ShouldNotBeNil)
  169. So(query.Result.OrgId, ShouldEqual, users[0].OrgId)
  170. cacheKey := newSignedInUserCacheKey(query.Result.OrgId, query.UserId)
  171. _, found := ss.CacheService.Get(cacheKey)
  172. So(found, ShouldBeTrue)
  173. })
  174. })
  175. Convey("When batch disabling users", func() {
  176. userIdsToDisable := []int64{}
  177. for i := 0; i < 3; i++ {
  178. userIdsToDisable = append(userIdsToDisable, users[i].Id)
  179. }
  180. disableCmd := models.BatchDisableUsersCommand{UserIds: userIdsToDisable, IsDisabled: true}
  181. err = BatchDisableUsers(&disableCmd)
  182. So(err, ShouldBeNil)
  183. Convey("Should disable all provided users", func() {
  184. query := models.SearchUsersQuery{}
  185. err = SearchUsers(&query)
  186. So(query.Result.TotalCount, ShouldEqual, 5)
  187. for _, user := range query.Result.Users {
  188. shouldBeDisabled := false
  189. // Check if user id is in the userIdsToDisable list
  190. for _, disabledUserId := range userIdsToDisable {
  191. if user.Id == disabledUserId {
  192. So(user.IsDisabled, ShouldBeTrue)
  193. shouldBeDisabled = true
  194. }
  195. }
  196. // Otherwise user shouldn't be disabled
  197. if !shouldBeDisabled {
  198. So(user.IsDisabled, ShouldBeFalse)
  199. }
  200. }
  201. })
  202. })
  203. })
  204. Convey("Given one grafana admin user", func() {
  205. var err error
  206. createUserCmd := &models.CreateUserCommand{
  207. Email: fmt.Sprint("admin", "@test.com"),
  208. Name: fmt.Sprint("admin"),
  209. Login: fmt.Sprint("admin"),
  210. IsAdmin: true,
  211. }
  212. err = CreateUser(context.Background(), createUserCmd)
  213. So(err, ShouldBeNil)
  214. Convey("Cannot make themselves a non-admin", func() {
  215. updateUserPermsCmd := models.UpdateUserPermissionsCommand{IsGrafanaAdmin: false, UserId: 1}
  216. updatePermsError := UpdateUserPermissions(&updateUserPermsCmd)
  217. So(updatePermsError, ShouldEqual, models.ErrLastGrafanaAdmin)
  218. query := models.GetUserByIdQuery{Id: createUserCmd.Result.Id}
  219. getUserError := GetUserById(&query)
  220. So(getUserError, ShouldBeNil)
  221. So(query.Result.IsAdmin, ShouldEqual, true)
  222. })
  223. })
  224. })
  225. }
  226. func GetOrgUsersForTest(query *models.GetOrgUsersQuery) error {
  227. query.Result = make([]*models.OrgUserDTO, 0)
  228. sess := x.Table("org_user")
  229. sess.Join("LEFT ", x.Dialect().Quote("user"), fmt.Sprintf("org_user.user_id=%s.id", x.Dialect().Quote("user")))
  230. sess.Where("org_user.org_id=?", query.OrgId)
  231. sess.Cols("org_user.org_id", "org_user.user_id", "user.email", "user.login", "org_user.role")
  232. err := sess.Find(&query.Result)
  233. return err
  234. }