| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- package sqlstore
- import (
- "testing"
- . "github.com/smartystreets/goconvey/convey"
- m "github.com/grafana/grafana/pkg/models"
- )
- func TestDashboardAclDataAccess(t *testing.T) {
- Convey("Testing DB", t, func() {
- InitTestDB(t)
- Convey("Given a dashboard folder and a user", func() {
- currentUser := createUser("viewer", "Viewer", false)
- savedFolder := insertTestDashboard("1 test dash folder", 1, 0, true, "prod", "webapp")
- childDash := insertTestDashboard("2 test dash", 1, savedFolder.Id, false, "prod", "webapp")
- Convey("When adding dashboard permission with userId and userGroupId set to 0", func() {
- err := AddOrUpdateDashboardPermission(&m.AddOrUpdateDashboardPermissionCommand{
- OrgId: 1,
- DashboardId: savedFolder.Id,
- Permissions: m.PERMISSION_EDIT,
- })
- So(err, ShouldEqual, m.ErrDashboardPermissionUserOrUserGroupEmpty)
- })
- Convey("Should be able to add dashboard permission", func() {
- err := AddOrUpdateDashboardPermission(&m.AddOrUpdateDashboardPermissionCommand{
- OrgId: 1,
- UserId: currentUser.Id,
- DashboardId: savedFolder.Id,
- Permissions: m.PERMISSION_EDIT,
- })
- So(err, ShouldBeNil)
- q1 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
- err = GetDashboardPermissions(q1)
- So(err, ShouldBeNil)
- So(q1.Result[0].DashboardId, ShouldEqual, savedFolder.Id)
- So(q1.Result[0].Permissions, ShouldEqual, m.PERMISSION_EDIT)
- So(q1.Result[0].PermissionName, ShouldEqual, "Edit")
- So(q1.Result[0].UserId, ShouldEqual, currentUser.Id)
- So(q1.Result[0].UserLogin, ShouldEqual, currentUser.Login)
- So(q1.Result[0].UserEmail, ShouldEqual, currentUser.Email)
- Convey("Should update hasAcl field to true for dashboard folder and its children", func() {
- q2 := &m.GetDashboardsQuery{DashboardIds: []int64{savedFolder.Id, childDash.Id}}
- err := GetDashboards(q2)
- So(err, ShouldBeNil)
- So(q2.Result[0].HasAcl, ShouldBeTrue)
- So(q2.Result[1].HasAcl, ShouldBeTrue)
- })
- Convey("Should be able to update an existing permission", func() {
- err := AddOrUpdateDashboardPermission(&m.AddOrUpdateDashboardPermissionCommand{
- OrgId: 1,
- UserId: 1,
- DashboardId: savedFolder.Id,
- Permissions: m.PERMISSION_READ_ONLY_EDIT,
- })
- So(err, ShouldBeNil)
- q3 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
- err = GetDashboardPermissions(q3)
- So(err, ShouldBeNil)
- So(len(q3.Result), ShouldEqual, 1)
- So(q3.Result[0].DashboardId, ShouldEqual, savedFolder.Id)
- So(q3.Result[0].Permissions, ShouldEqual, m.PERMISSION_READ_ONLY_EDIT)
- So(q3.Result[0].UserId, ShouldEqual, 1)
- })
- Convey("Should be able to delete an existing permission", func() {
- err := RemoveDashboardPermission(&m.RemoveDashboardPermissionCommand{
- OrgId: 1,
- UserId: 1,
- DashboardId: savedFolder.Id,
- })
- So(err, ShouldBeNil)
- q3 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
- err = GetDashboardPermissions(q3)
- So(err, ShouldBeNil)
- So(len(q3.Result), ShouldEqual, 0)
- })
- })
- Convey("Given a user group", func() {
- group1 := m.CreateUserGroupCommand{Name: "group1 name", OrgId: 1}
- err := CreateUserGroup(&group1)
- So(err, ShouldBeNil)
- Convey("Should be able to add a user permission for a user group", func() {
- err := AddOrUpdateDashboardPermission(&m.AddOrUpdateDashboardPermissionCommand{
- OrgId: 1,
- UserGroupId: group1.Result.Id,
- DashboardId: savedFolder.Id,
- Permissions: m.PERMISSION_EDIT,
- })
- So(err, ShouldBeNil)
- q1 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
- err = GetDashboardPermissions(q1)
- So(err, ShouldBeNil)
- So(q1.Result[0].DashboardId, ShouldEqual, savedFolder.Id)
- So(q1.Result[0].Permissions, ShouldEqual, m.PERMISSION_EDIT)
- So(q1.Result[0].UserGroupId, ShouldEqual, group1.Result.Id)
- })
- Convey("Should be able to update an existing permission for a user group", func() {
- err := AddOrUpdateDashboardPermission(&m.AddOrUpdateDashboardPermissionCommand{
- OrgId: 1,
- UserGroupId: group1.Result.Id,
- DashboardId: savedFolder.Id,
- Permissions: m.PERMISSION_READ_ONLY_EDIT,
- })
- So(err, ShouldBeNil)
- q3 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
- err = GetDashboardPermissions(q3)
- So(err, ShouldBeNil)
- So(len(q3.Result), ShouldEqual, 1)
- So(q3.Result[0].DashboardId, ShouldEqual, savedFolder.Id)
- So(q3.Result[0].Permissions, ShouldEqual, m.PERMISSION_READ_ONLY_EDIT)
- So(q3.Result[0].UserGroupId, ShouldEqual, group1.Result.Id)
- })
- Convey("Should be able to delete an existing permission for a user group", func() {
- err := RemoveDashboardPermission(&m.RemoveDashboardPermissionCommand{
- OrgId: 1,
- UserGroupId: group1.Result.Id,
- DashboardId: savedFolder.Id,
- })
- So(err, ShouldBeNil)
- q3 := &m.GetDashboardPermissionsQuery{DashboardId: savedFolder.Id}
- err = GetDashboardPermissions(q3)
- So(err, ShouldBeNil)
- So(len(q3.Result), ShouldEqual, 0)
- })
- })
- })
- })
- }
|