dashboard_acl_test.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. package sqlstore
  2. import (
  3. "testing"
  4. . "github.com/smartystreets/goconvey/convey"
  5. m "github.com/grafana/grafana/pkg/models"
  6. )
  7. func TestDashboardAclDataAccess(t *testing.T) {
  8. Convey("Testing DB", t, func() {
  9. InitTestDB(t)
  10. Convey("Given a dashboard folder and a user", func() {
  11. currentUser := createUser("viewer", "Viewer", false)
  12. savedFolder := insertTestDashboard("1 test dash folder", 1, 0, true, "prod", "webapp")
  13. childDash := insertTestDashboard("2 test dash", 1, savedFolder.Id, false, "prod", "webapp")
  14. Convey("Should be able to add dashboard permission", func() {
  15. err := AddOrUpdateDashboardPermission(&m.AddOrUpdateDashboardPermissionCommand{
  16. OrgId: 1,
  17. UserId: currentUser.Id,
  18. DashboardId: savedFolder.Id,
  19. PermissionType: m.PERMISSION_EDIT,
  20. })
  21. So(err, ShouldBeNil)
  22. q1 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
  23. err = GetDashboardPermissions(q1)
  24. So(err, ShouldBeNil)
  25. So(q1.Result[0].DashboardId, ShouldEqual, savedFolder.Id)
  26. So(q1.Result[0].Permissions, ShouldEqual, m.PERMISSION_EDIT)
  27. So(q1.Result[0].UserId, ShouldEqual, currentUser.Id)
  28. So(q1.Result[0].UserLogin, ShouldEqual, currentUser.Login)
  29. So(q1.Result[0].UserEmail, ShouldEqual, currentUser.Email)
  30. Convey("Should update hasAcl field to true for dashboard folder and its children", func() {
  31. q2 := &m.GetDashboardsQuery{DashboardIds: []int64{savedFolder.Id, childDash.Id}}
  32. err := GetDashboards(q2)
  33. So(err, ShouldBeNil)
  34. So(q2.Result[0].HasAcl, ShouldBeTrue)
  35. So(q2.Result[1].HasAcl, ShouldBeTrue)
  36. })
  37. Convey("Should be able to update an existing permission", func() {
  38. err := AddOrUpdateDashboardPermission(&m.AddOrUpdateDashboardPermissionCommand{
  39. OrgId: 1,
  40. UserId: 1,
  41. DashboardId: savedFolder.Id,
  42. PermissionType: m.PERMISSION_READ_ONLY_EDIT,
  43. })
  44. So(err, ShouldBeNil)
  45. q3 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
  46. err = GetDashboardPermissions(q3)
  47. So(err, ShouldBeNil)
  48. So(len(q3.Result), ShouldEqual, 1)
  49. So(q3.Result[0].DashboardId, ShouldEqual, savedFolder.Id)
  50. So(q3.Result[0].Permissions, ShouldEqual, m.PERMISSION_READ_ONLY_EDIT)
  51. So(q3.Result[0].UserId, ShouldEqual, 1)
  52. })
  53. Convey("Should be able to delete an existing permission", func() {
  54. err := RemoveDashboardPermission(&m.RemoveDashboardPermissionCommand{
  55. OrgId: 1,
  56. UserId: 1,
  57. DashboardId: savedFolder.Id,
  58. })
  59. So(err, ShouldBeNil)
  60. q3 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
  61. err = GetDashboardPermissions(q3)
  62. So(err, ShouldBeNil)
  63. So(len(q3.Result), ShouldEqual, 0)
  64. })
  65. })
  66. Convey("Given a user group", func() {
  67. group1 := m.CreateUserGroupCommand{Name: "group1 name", OrgId: 1}
  68. err := CreateUserGroup(&group1)
  69. So(err, ShouldBeNil)
  70. Convey("Should be able to add a user permission for a user group", func() {
  71. err := AddOrUpdateDashboardPermission(&m.AddOrUpdateDashboardPermissionCommand{
  72. OrgId: 1,
  73. UserGroupId: group1.Result.Id,
  74. DashboardId: savedFolder.Id,
  75. PermissionType: m.PERMISSION_EDIT,
  76. })
  77. So(err, ShouldBeNil)
  78. q1 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
  79. err = GetDashboardPermissions(q1)
  80. So(err, ShouldBeNil)
  81. So(q1.Result[0].DashboardId, ShouldEqual, savedFolder.Id)
  82. So(q1.Result[0].Permissions, ShouldEqual, m.PERMISSION_EDIT)
  83. So(q1.Result[0].UserGroupId, ShouldEqual, group1.Result.Id)
  84. })
  85. Convey("Should be able to update an existing permission for a user group", func() {
  86. err := AddOrUpdateDashboardPermission(&m.AddOrUpdateDashboardPermissionCommand{
  87. OrgId: 1,
  88. UserGroupId: group1.Result.Id,
  89. DashboardId: savedFolder.Id,
  90. PermissionType: m.PERMISSION_READ_ONLY_EDIT,
  91. })
  92. So(err, ShouldBeNil)
  93. q3 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
  94. err = GetDashboardPermissions(q3)
  95. So(err, ShouldBeNil)
  96. So(len(q3.Result), ShouldEqual, 1)
  97. So(q3.Result[0].DashboardId, ShouldEqual, savedFolder.Id)
  98. So(q3.Result[0].Permissions, ShouldEqual, m.PERMISSION_READ_ONLY_EDIT)
  99. So(q3.Result[0].UserGroupId, ShouldEqual, group1.Result.Id)
  100. })
  101. Convey("Should be able to delete an existing permission for a user group", func() {
  102. err := RemoveDashboardPermission(&m.RemoveDashboardPermissionCommand{
  103. OrgId: 1,
  104. UserGroupId: group1.Result.Id,
  105. DashboardId: savedFolder.Id,
  106. })
  107. So(err, ShouldBeNil)
  108. q3 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
  109. err = GetDashboardPermissions(q3)
  110. So(err, ShouldBeNil)
  111. So(len(q3.Result), ShouldEqual, 0)
  112. })
  113. })
  114. })
  115. })
  116. }