org_test.go 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. package sqlstore
  2. import (
  3. "context"
  4. "testing"
  5. "time"
  6. . "github.com/smartystreets/goconvey/convey"
  7. m "github.com/grafana/grafana/pkg/models"
  8. "github.com/grafana/grafana/pkg/setting"
  9. )
  10. func TestAccountDataAccess(t *testing.T) {
  11. Convey("Testing Account DB Access", t, func() {
  12. InitTestDB(t)
  13. Convey("Given single org mode", func() {
  14. setting.AutoAssignOrg = true
  15. setting.AutoAssignOrgRole = "Viewer"
  16. Convey("Users should be added to default organization", func() {
  17. ac1cmd := m.CreateUserCommand{Login: "ac1", Email: "ac1@test.com", Name: "ac1 name"}
  18. ac2cmd := m.CreateUserCommand{Login: "ac2", Email: "ac2@test.com", Name: "ac2 name"}
  19. err := CreateUser(context.Background(), &ac1cmd)
  20. So(err, ShouldBeNil)
  21. err = CreateUser(context.Background(), &ac2cmd)
  22. So(err, ShouldBeNil)
  23. q1 := m.GetUserOrgListQuery{UserId: ac1cmd.Result.Id}
  24. q2 := m.GetUserOrgListQuery{UserId: ac2cmd.Result.Id}
  25. GetUserOrgList(&q1)
  26. GetUserOrgList(&q2)
  27. So(q1.Result[0].OrgId, ShouldEqual, q2.Result[0].OrgId)
  28. So(q1.Result[0].Role, ShouldEqual, "Viewer")
  29. })
  30. })
  31. Convey("Given two saved users", func() {
  32. setting.AutoAssignOrg = false
  33. ac1cmd := m.CreateUserCommand{Login: "ac1", Email: "ac1@test.com", Name: "ac1 name"}
  34. ac2cmd := m.CreateUserCommand{Login: "ac2", Email: "ac2@test.com", Name: "ac2 name", IsAdmin: true}
  35. err := CreateUser(context.Background(), &ac1cmd)
  36. err = CreateUser(context.Background(), &ac2cmd)
  37. So(err, ShouldBeNil)
  38. ac1 := ac1cmd.Result
  39. ac2 := ac2cmd.Result
  40. Convey("Should be able to read user info projection", func() {
  41. query := m.GetUserProfileQuery{UserId: ac1.Id}
  42. err = GetUserProfile(&query)
  43. So(err, ShouldBeNil)
  44. So(query.Result.Email, ShouldEqual, "ac1@test.com")
  45. So(query.Result.Login, ShouldEqual, "ac1")
  46. })
  47. Convey("Can search users", func() {
  48. query := m.SearchUsersQuery{Query: ""}
  49. err := SearchUsers(&query)
  50. So(err, ShouldBeNil)
  51. So(query.Result.Users[0].Email, ShouldEqual, "ac1@test.com")
  52. So(query.Result.Users[1].Email, ShouldEqual, "ac2@test.com")
  53. })
  54. Convey("Given an added org user", func() {
  55. cmd := m.AddOrgUserCommand{
  56. OrgId: ac1.OrgId,
  57. UserId: ac2.Id,
  58. Role: m.ROLE_VIEWER,
  59. }
  60. err := AddOrgUser(&cmd)
  61. Convey("Should have been saved without error", func() {
  62. So(err, ShouldBeNil)
  63. })
  64. Convey("Can update org user role", func() {
  65. updateCmd := m.UpdateOrgUserCommand{OrgId: ac1.OrgId, UserId: ac2.Id, Role: m.ROLE_ADMIN}
  66. err = UpdateOrgUser(&updateCmd)
  67. So(err, ShouldBeNil)
  68. orgUsersQuery := m.GetOrgUsersQuery{OrgId: ac1.OrgId}
  69. err = GetOrgUsers(&orgUsersQuery)
  70. So(err, ShouldBeNil)
  71. So(orgUsersQuery.Result[1].Role, ShouldEqual, m.ROLE_ADMIN)
  72. })
  73. Convey("Can get logged in user projection", func() {
  74. query := m.GetSignedInUserQuery{UserId: ac2.Id}
  75. err := GetSignedInUser(&query)
  76. So(err, ShouldBeNil)
  77. So(query.Result.Email, ShouldEqual, "ac2@test.com")
  78. So(query.Result.OrgId, ShouldEqual, ac2.OrgId)
  79. So(query.Result.Name, ShouldEqual, "ac2 name")
  80. So(query.Result.Login, ShouldEqual, "ac2")
  81. So(query.Result.OrgRole, ShouldEqual, "Admin")
  82. So(query.Result.OrgName, ShouldEqual, "ac2@test.com")
  83. So(query.Result.IsGrafanaAdmin, ShouldBeTrue)
  84. })
  85. Convey("Can get user organizations", func() {
  86. query := m.GetUserOrgListQuery{UserId: ac2.Id}
  87. err := GetUserOrgList(&query)
  88. So(err, ShouldBeNil)
  89. So(len(query.Result), ShouldEqual, 2)
  90. })
  91. Convey("Can get organization users", func() {
  92. query := m.GetOrgUsersQuery{OrgId: ac1.OrgId}
  93. err := GetOrgUsers(&query)
  94. So(err, ShouldBeNil)
  95. So(len(query.Result), ShouldEqual, 2)
  96. So(query.Result[0].Role, ShouldEqual, "Admin")
  97. })
  98. Convey("Can get organization users with query", func() {
  99. query := m.GetOrgUsersQuery{
  100. OrgId: ac1.OrgId,
  101. Query: "ac1",
  102. }
  103. err := GetOrgUsers(&query)
  104. So(err, ShouldBeNil)
  105. So(len(query.Result), ShouldEqual, 1)
  106. So(query.Result[0].Email, ShouldEqual, ac1.Email)
  107. })
  108. Convey("Can get organization users with query and limit", func() {
  109. query := m.GetOrgUsersQuery{
  110. OrgId: ac1.OrgId,
  111. Query: "ac",
  112. Limit: 1,
  113. }
  114. err := GetOrgUsers(&query)
  115. So(err, ShouldBeNil)
  116. So(len(query.Result), ShouldEqual, 1)
  117. So(query.Result[0].Email, ShouldEqual, ac1.Email)
  118. })
  119. Convey("Can set using org", func() {
  120. cmd := m.SetUsingOrgCommand{UserId: ac2.Id, OrgId: ac1.OrgId}
  121. err := SetUsingOrg(&cmd)
  122. So(err, ShouldBeNil)
  123. Convey("SignedInUserQuery with a different org", func() {
  124. query := m.GetSignedInUserQuery{UserId: ac2.Id}
  125. err := GetSignedInUser(&query)
  126. So(err, ShouldBeNil)
  127. So(query.Result.OrgId, ShouldEqual, ac1.OrgId)
  128. So(query.Result.Email, ShouldEqual, "ac2@test.com")
  129. So(query.Result.Name, ShouldEqual, "ac2 name")
  130. So(query.Result.Login, ShouldEqual, "ac2")
  131. So(query.Result.OrgName, ShouldEqual, "ac1@test.com")
  132. So(query.Result.OrgRole, ShouldEqual, "Viewer")
  133. })
  134. Convey("Should set last org as current when removing user from current", func() {
  135. remCmd := m.RemoveOrgUserCommand{OrgId: ac1.OrgId, UserId: ac2.Id}
  136. err := RemoveOrgUser(&remCmd)
  137. So(err, ShouldBeNil)
  138. query := m.GetSignedInUserQuery{UserId: ac2.Id}
  139. err = GetSignedInUser(&query)
  140. So(err, ShouldBeNil)
  141. So(query.Result.OrgId, ShouldEqual, ac2.OrgId)
  142. })
  143. })
  144. Convey("Cannot delete last admin org user", func() {
  145. cmd := m.RemoveOrgUserCommand{OrgId: ac1.OrgId, UserId: ac1.Id}
  146. err := RemoveOrgUser(&cmd)
  147. So(err, ShouldEqual, m.ErrLastOrgAdmin)
  148. })
  149. Convey("Cannot update role so no one is admin user", func() {
  150. cmd := m.UpdateOrgUserCommand{OrgId: ac1.OrgId, UserId: ac1.Id, Role: m.ROLE_VIEWER}
  151. err := UpdateOrgUser(&cmd)
  152. So(err, ShouldEqual, m.ErrLastOrgAdmin)
  153. })
  154. Convey("Given an org user with dashboard permissions", func() {
  155. ac3cmd := m.CreateUserCommand{Login: "ac3", Email: "ac3@test.com", Name: "ac3 name", IsAdmin: false}
  156. err := CreateUser(context.Background(), &ac3cmd)
  157. So(err, ShouldBeNil)
  158. ac3 := ac3cmd.Result
  159. orgUserCmd := m.AddOrgUserCommand{
  160. OrgId: ac1.OrgId,
  161. UserId: ac3.Id,
  162. Role: m.ROLE_VIEWER,
  163. }
  164. err = AddOrgUser(&orgUserCmd)
  165. So(err, ShouldBeNil)
  166. query := m.GetOrgUsersQuery{OrgId: ac1.OrgId}
  167. err = GetOrgUsers(&query)
  168. So(err, ShouldBeNil)
  169. So(len(query.Result), ShouldEqual, 3)
  170. dash1 := insertTestDashboard("1 test dash", ac1.OrgId, 0, false, "prod", "webapp")
  171. dash2 := insertTestDashboard("2 test dash", ac3.OrgId, 0, false, "prod", "webapp")
  172. err = testHelperUpdateDashboardAcl(dash1.Id, m.DashboardAcl{DashboardId: dash1.Id, OrgId: ac1.OrgId, UserId: ac3.Id, Permission: m.PERMISSION_EDIT})
  173. So(err, ShouldBeNil)
  174. err = testHelperUpdateDashboardAcl(dash2.Id, m.DashboardAcl{DashboardId: dash2.Id, OrgId: ac3.OrgId, UserId: ac3.Id, Permission: m.PERMISSION_EDIT})
  175. So(err, ShouldBeNil)
  176. Convey("When org user is deleted", func() {
  177. cmdRemove := m.RemoveOrgUserCommand{OrgId: ac1.OrgId, UserId: ac3.Id}
  178. err := RemoveOrgUser(&cmdRemove)
  179. So(err, ShouldBeNil)
  180. Convey("Should remove dependent permissions for deleted org user", func() {
  181. permQuery := &m.GetDashboardAclInfoListQuery{DashboardId: 1, OrgId: ac1.OrgId}
  182. err = GetDashboardAclInfoList(permQuery)
  183. So(err, ShouldBeNil)
  184. So(len(permQuery.Result), ShouldEqual, 0)
  185. })
  186. Convey("Should not remove dashboard permissions for same user in another org", func() {
  187. permQuery := &m.GetDashboardAclInfoListQuery{DashboardId: 2, OrgId: ac3.OrgId}
  188. err = GetDashboardAclInfoList(permQuery)
  189. So(err, ShouldBeNil)
  190. So(len(permQuery.Result), ShouldEqual, 1)
  191. So(permQuery.Result[0].OrgId, ShouldEqual, ac3.OrgId)
  192. So(permQuery.Result[0].UserId, ShouldEqual, ac3.Id)
  193. })
  194. })
  195. })
  196. })
  197. })
  198. })
  199. }
  200. func testHelperUpdateDashboardAcl(dashboardId int64, items ...m.DashboardAcl) error {
  201. cmd := m.UpdateDashboardAclCommand{DashboardId: dashboardId}
  202. for _, item := range items {
  203. item.Created = time.Now()
  204. item.Updated = time.Now()
  205. cmd.Items = append(cmd.Items, &item)
  206. }
  207. return UpdateDashboardAcl(&cmd)
  208. }