org_test.go 7.7 KB

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