org_test.go 9.3 KB

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