2020-10-16 02:46:14 -05:00
|
|
|
// +build integration
|
|
|
|
|
2014-12-19 02:43:16 -06:00
|
|
|
package sqlstore
|
|
|
|
|
|
|
|
import (
|
2018-06-15 14:23:57 -05:00
|
|
|
"context"
|
2019-09-03 12:34:44 -05:00
|
|
|
"fmt"
|
2014-12-19 02:43:16 -06:00
|
|
|
"testing"
|
2018-03-15 18:08:25 -05:00
|
|
|
"time"
|
2014-12-19 02:43:16 -06:00
|
|
|
|
2020-02-29 06:35:15 -06:00
|
|
|
"github.com/grafana/grafana/pkg/models"
|
2015-02-05 03:37:13 -06:00
|
|
|
"github.com/grafana/grafana/pkg/setting"
|
2019-09-03 12:34:44 -05:00
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
2014-12-19 02:43:16 -06:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestAccountDataAccess(t *testing.T) {
|
|
|
|
Convey("Testing Account DB Access", t, func() {
|
2021-03-17 10:06:10 -05:00
|
|
|
sqlStore := InitTestDB(t)
|
2014-12-19 02:43:16 -06:00
|
|
|
|
2019-09-03 12:34:44 -05:00
|
|
|
Convey("Given we have organizations, we can query them by IDs", func() {
|
|
|
|
var err error
|
2020-02-29 06:35:15 -06:00
|
|
|
var cmd *models.CreateOrgCommand
|
2019-09-03 12:34:44 -05:00
|
|
|
ids := []int64{}
|
|
|
|
|
|
|
|
for i := 1; i < 4; i++ {
|
2020-02-29 06:35:15 -06:00
|
|
|
cmd = &models.CreateOrgCommand{Name: fmt.Sprint("Org #", i)}
|
2019-09-03 12:34:44 -05:00
|
|
|
err = CreateOrg(cmd)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
ids = append(ids, cmd.Result.Id)
|
|
|
|
}
|
|
|
|
|
2020-02-29 06:35:15 -06:00
|
|
|
query := &models.SearchOrgsQuery{Ids: ids}
|
2019-09-03 12:34:44 -05:00
|
|
|
err = SearchOrgs(query)
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(len(query.Result), ShouldEqual, 3)
|
|
|
|
})
|
|
|
|
|
2020-08-12 02:59:07 -05:00
|
|
|
Convey("Given we have organizations, we can limit and paginate search", func() {
|
|
|
|
for i := 1; i < 4; i++ {
|
|
|
|
cmd := &models.CreateOrgCommand{Name: fmt.Sprint("Org #", i)}
|
|
|
|
err := CreateOrg(cmd)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
}
|
|
|
|
|
|
|
|
Convey("Should be able to search with defaults", func() {
|
|
|
|
query := &models.SearchOrgsQuery{}
|
|
|
|
err := SearchOrgs(query)
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(len(query.Result), ShouldEqual, 3)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("Should be able to limit search", func() {
|
|
|
|
query := &models.SearchOrgsQuery{Limit: 1}
|
|
|
|
err := SearchOrgs(query)
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(len(query.Result), ShouldEqual, 1)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("Should be able to limit and paginate search", func() {
|
|
|
|
query := &models.SearchOrgsQuery{Limit: 2, Page: 1}
|
|
|
|
err := SearchOrgs(query)
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(len(query.Result), ShouldEqual, 1)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2015-02-23 13:48:43 -06:00
|
|
|
Convey("Given single org mode", func() {
|
2015-03-11 10:19:29 -05:00
|
|
|
setting.AutoAssignOrg = true
|
2018-07-13 14:14:40 -05:00
|
|
|
setting.AutoAssignOrgId = 1
|
2015-03-11 10:19:29 -05:00
|
|
|
setting.AutoAssignOrgRole = "Viewer"
|
2015-01-27 08:14:53 -06:00
|
|
|
|
2015-02-23 13:07:49 -06:00
|
|
|
Convey("Users should be added to default organization", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
ac1cmd := models.CreateUserCommand{Login: "ac1", Email: "ac1@test.com", Name: "ac1 name"}
|
|
|
|
ac2cmd := models.CreateUserCommand{Login: "ac2", Email: "ac2@test.com", Name: "ac2 name"}
|
2015-01-27 08:14:53 -06:00
|
|
|
|
2021-03-17 10:06:10 -05:00
|
|
|
ac1, err := sqlStore.CreateUser(context.Background(), ac1cmd)
|
2015-01-27 08:14:53 -06:00
|
|
|
So(err, ShouldBeNil)
|
2021-03-17 10:06:10 -05:00
|
|
|
ac2, err := sqlStore.CreateUser(context.Background(), ac2cmd)
|
2015-01-27 08:14:53 -06:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2021-03-17 10:06:10 -05:00
|
|
|
q1 := models.GetUserOrgListQuery{UserId: ac1.Id}
|
|
|
|
q2 := models.GetUserOrgListQuery{UserId: ac2.Id}
|
2019-10-22 07:08:18 -05:00
|
|
|
err = GetUserOrgList(&q1)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
err = GetUserOrgList(&q2)
|
|
|
|
So(err, ShouldBeNil)
|
2015-01-27 08:14:53 -06:00
|
|
|
|
2015-02-23 13:07:49 -06:00
|
|
|
So(q1.Result[0].OrgId, ShouldEqual, q2.Result[0].OrgId)
|
2015-01-27 08:14:53 -06:00
|
|
|
So(q1.Result[0].Role, ShouldEqual, "Viewer")
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2015-01-19 11:01:04 -06:00
|
|
|
Convey("Given two saved users", func() {
|
2015-03-11 10:19:29 -05:00
|
|
|
setting.AutoAssignOrg = false
|
2015-01-27 08:14:53 -06:00
|
|
|
|
2020-02-29 06:35:15 -06:00
|
|
|
ac1cmd := models.CreateUserCommand{Login: "ac1", Email: "ac1@test.com", Name: "ac1 name"}
|
|
|
|
ac2cmd := models.CreateUserCommand{Login: "ac2", Email: "ac2@test.com", Name: "ac2 name", IsAdmin: true}
|
2014-12-19 04:53:27 -06:00
|
|
|
|
2021-03-17 10:06:10 -05:00
|
|
|
ac1, err := sqlStore.CreateUser(context.Background(), ac1cmd)
|
|
|
|
ac2, err := sqlStore.CreateUser(context.Background(), ac2cmd)
|
2014-12-19 03:45:22 -06:00
|
|
|
So(err, ShouldBeNil)
|
2014-12-19 02:43:16 -06:00
|
|
|
|
2015-01-19 11:01:04 -06:00
|
|
|
Convey("Should be able to read user info projection", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.GetUserProfileQuery{UserId: ac1.Id}
|
2015-02-28 07:30:08 -06:00
|
|
|
err = GetUserProfile(&query)
|
2014-12-19 02:43:16 -06:00
|
|
|
|
2014-12-19 03:45:22 -06:00
|
|
|
So(err, ShouldBeNil)
|
2014-12-19 04:53:27 -06:00
|
|
|
So(query.Result.Email, ShouldEqual, "ac1@test.com")
|
2015-01-16 00:45:37 -06:00
|
|
|
So(query.Result.Login, ShouldEqual, "ac1")
|
|
|
|
})
|
|
|
|
|
2015-01-19 11:01:04 -06:00
|
|
|
Convey("Can search users", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.SearchUsersQuery{Query: ""}
|
2015-01-19 11:01:04 -06:00
|
|
|
err := SearchUsers(&query)
|
2015-01-16 00:45:37 -06:00
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
2017-02-08 07:20:07 -06:00
|
|
|
So(query.Result.Users[0].Email, ShouldEqual, "ac1@test.com")
|
|
|
|
So(query.Result.Users[1].Email, ShouldEqual, "ac2@test.com")
|
2014-12-19 03:45:22 -06:00
|
|
|
})
|
2014-12-19 02:43:16 -06:00
|
|
|
|
2015-02-23 13:48:43 -06:00
|
|
|
Convey("Given an added org user", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
cmd := models.AddOrgUserCommand{
|
2015-02-23 13:48:43 -06:00
|
|
|
OrgId: ac1.OrgId,
|
|
|
|
UserId: ac2.Id,
|
2020-02-29 06:35:15 -06:00
|
|
|
Role: models.ROLE_VIEWER,
|
2014-12-19 03:45:22 -06:00
|
|
|
}
|
|
|
|
|
2015-02-23 13:48:43 -06:00
|
|
|
err := AddOrgUser(&cmd)
|
2015-01-16 07:32:18 -06:00
|
|
|
Convey("Should have been saved without error", func() {
|
2014-12-19 03:45:22 -06:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
})
|
|
|
|
|
2015-05-01 02:48:07 -05:00
|
|
|
Convey("Can update org user role", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
updateCmd := models.UpdateOrgUserCommand{OrgId: ac1.OrgId, UserId: ac2.Id, Role: models.ROLE_ADMIN}
|
2015-05-01 02:48:07 -05:00
|
|
|
err = UpdateOrgUser(&updateCmd)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2020-02-29 06:35:15 -06:00
|
|
|
orgUsersQuery := models.GetOrgUsersQuery{OrgId: ac1.OrgId}
|
2015-05-01 02:48:07 -05:00
|
|
|
err = GetOrgUsers(&orgUsersQuery)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2020-02-29 06:35:15 -06:00
|
|
|
So(orgUsersQuery.Result[1].Role, ShouldEqual, models.ROLE_ADMIN)
|
2015-05-01 02:48:07 -05:00
|
|
|
})
|
|
|
|
|
2015-01-16 07:32:18 -06:00
|
|
|
Convey("Can get logged in user projection", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.GetSignedInUserQuery{UserId: ac2.Id}
|
2015-01-16 07:32:18 -06:00
|
|
|
err := GetSignedInUser(&query)
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
2015-01-19 11:01:04 -06:00
|
|
|
So(query.Result.Email, ShouldEqual, "ac2@test.com")
|
2015-02-23 13:48:43 -06:00
|
|
|
So(query.Result.OrgId, ShouldEqual, ac2.OrgId)
|
2015-01-19 11:01:04 -06:00
|
|
|
So(query.Result.Name, ShouldEqual, "ac2 name")
|
|
|
|
So(query.Result.Login, ShouldEqual, "ac2")
|
2015-02-23 13:48:43 -06:00
|
|
|
So(query.Result.OrgRole, ShouldEqual, "Admin")
|
|
|
|
So(query.Result.OrgName, ShouldEqual, "ac2@test.com")
|
2015-01-16 07:32:18 -06:00
|
|
|
So(query.Result.IsGrafanaAdmin, ShouldBeTrue)
|
|
|
|
})
|
|
|
|
|
2015-02-23 13:48:43 -06:00
|
|
|
Convey("Can get user organizations", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.GetUserOrgListQuery{UserId: ac2.Id}
|
2015-02-23 13:48:43 -06:00
|
|
|
err := GetUserOrgList(&query)
|
2014-12-19 04:08:49 -06:00
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
2015-01-19 11:01:04 -06:00
|
|
|
So(len(query.Result), ShouldEqual, 2)
|
2014-12-19 04:08:49 -06:00
|
|
|
})
|
2014-12-19 06:12:47 -06:00
|
|
|
|
2015-02-23 13:48:43 -06:00
|
|
|
Convey("Can get organization users", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.GetOrgUsersQuery{OrgId: ac1.OrgId}
|
2015-02-23 13:48:43 -06:00
|
|
|
err := GetOrgUsers(&query)
|
2015-01-20 08:23:14 -06:00
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(len(query.Result), ShouldEqual, 2)
|
|
|
|
So(query.Result[0].Role, ShouldEqual, "Admin")
|
|
|
|
})
|
|
|
|
|
2018-02-09 03:42:37 -06:00
|
|
|
Convey("Can get organization users with query", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.GetOrgUsersQuery{
|
2018-02-09 03:42:37 -06:00
|
|
|
OrgId: ac1.OrgId,
|
|
|
|
Query: "ac1",
|
|
|
|
}
|
|
|
|
err := GetOrgUsers(&query)
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(len(query.Result), ShouldEqual, 1)
|
|
|
|
So(query.Result[0].Email, ShouldEqual, ac1.Email)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("Can get organization users with query and limit", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.GetOrgUsersQuery{
|
2018-02-09 03:42:37 -06:00
|
|
|
OrgId: ac1.OrgId,
|
|
|
|
Query: "ac",
|
|
|
|
Limit: 1,
|
|
|
|
}
|
|
|
|
err := GetOrgUsers(&query)
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(len(query.Result), ShouldEqual, 1)
|
|
|
|
So(query.Result[0].Email, ShouldEqual, ac1.Email)
|
|
|
|
})
|
|
|
|
|
2015-02-23 13:48:43 -06:00
|
|
|
Convey("Can set using org", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
cmd := models.SetUsingOrgCommand{UserId: ac2.Id, OrgId: ac1.OrgId}
|
2015-02-23 13:48:43 -06:00
|
|
|
err := SetUsingOrg(&cmd)
|
2014-12-19 06:12:47 -06:00
|
|
|
So(err, ShouldBeNil)
|
2015-01-16 07:32:18 -06:00
|
|
|
|
2015-02-23 13:48:43 -06:00
|
|
|
Convey("SignedInUserQuery with a different org", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.GetSignedInUserQuery{UserId: ac2.Id}
|
2015-01-16 07:32:18 -06:00
|
|
|
err := GetSignedInUser(&query)
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
2018-06-13 11:01:50 -05:00
|
|
|
So(query.Result.OrgId, ShouldEqual, ac1.OrgId)
|
2015-01-19 11:01:04 -06:00
|
|
|
So(query.Result.Email, ShouldEqual, "ac2@test.com")
|
|
|
|
So(query.Result.Name, ShouldEqual, "ac2 name")
|
|
|
|
So(query.Result.Login, ShouldEqual, "ac2")
|
2015-02-23 13:48:43 -06:00
|
|
|
So(query.Result.OrgName, ShouldEqual, "ac1@test.com")
|
|
|
|
So(query.Result.OrgRole, ShouldEqual, "Viewer")
|
2015-01-16 07:32:18 -06:00
|
|
|
})
|
2018-06-13 11:01:50 -05:00
|
|
|
|
|
|
|
Convey("Should set last org as current when removing user from current", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
remCmd := models.RemoveOrgUserCommand{OrgId: ac1.OrgId, UserId: ac2.Id}
|
2018-06-13 11:01:50 -05:00
|
|
|
err := RemoveOrgUser(&remCmd)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.GetSignedInUserQuery{UserId: ac2.Id}
|
2018-06-13 11:01:50 -05:00
|
|
|
err = GetSignedInUser(&query)
|
|
|
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(query.Result.OrgId, ShouldEqual, ac2.OrgId)
|
|
|
|
})
|
2014-12-19 06:12:47 -06:00
|
|
|
})
|
2015-01-20 08:48:19 -06:00
|
|
|
|
2018-10-11 00:48:35 -05:00
|
|
|
Convey("Removing user from org should delete user completely if in no other org", func() {
|
|
|
|
// make sure ac2 has no org
|
2020-02-29 06:35:15 -06:00
|
|
|
err := DeleteOrg(&models.DeleteOrgCommand{Id: ac2.OrgId})
|
2018-10-11 00:48:35 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2018-12-04 16:29:34 -06:00
|
|
|
// remove ac2 user from ac1 org
|
2020-02-29 06:35:15 -06:00
|
|
|
remCmd := models.RemoveOrgUserCommand{OrgId: ac1.OrgId, UserId: ac2.Id, ShouldDeleteOrphanedUser: true}
|
2018-10-11 00:48:35 -05:00
|
|
|
err = RemoveOrgUser(&remCmd)
|
|
|
|
So(err, ShouldBeNil)
|
2018-10-11 14:20:53 -05:00
|
|
|
So(remCmd.UserWasDeleted, ShouldBeTrue)
|
2018-10-11 00:48:35 -05:00
|
|
|
|
2020-02-29 06:35:15 -06:00
|
|
|
err = GetSignedInUser(&models.GetSignedInUserQuery{UserId: ac2.Id})
|
|
|
|
So(err, ShouldEqual, models.ErrUserNotFound)
|
2018-10-11 00:48:35 -05:00
|
|
|
})
|
|
|
|
|
2015-05-19 04:47:14 -05:00
|
|
|
Convey("Cannot delete last admin org user", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
cmd := models.RemoveOrgUserCommand{OrgId: ac1.OrgId, UserId: ac1.Id}
|
2015-02-23 13:48:43 -06:00
|
|
|
err := RemoveOrgUser(&cmd)
|
2020-02-29 06:35:15 -06:00
|
|
|
So(err, ShouldEqual, models.ErrLastOrgAdmin)
|
2015-01-20 08:48:19 -06:00
|
|
|
})
|
2015-05-19 04:47:14 -05:00
|
|
|
|
|
|
|
Convey("Cannot update role so no one is admin user", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
cmd := models.UpdateOrgUserCommand{OrgId: ac1.OrgId, UserId: ac1.Id, Role: models.ROLE_VIEWER}
|
2015-05-19 04:47:14 -05:00
|
|
|
err := UpdateOrgUser(&cmd)
|
2020-02-29 06:35:15 -06:00
|
|
|
So(err, ShouldEqual, models.ErrLastOrgAdmin)
|
2015-05-19 04:47:14 -05:00
|
|
|
})
|
|
|
|
|
2017-06-15 13:19:54 -05:00
|
|
|
Convey("Given an org user with dashboard permissions", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
ac3cmd := models.CreateUserCommand{Login: "ac3", Email: "ac3@test.com", Name: "ac3 name", IsAdmin: false}
|
2021-03-17 10:06:10 -05:00
|
|
|
ac3, err := sqlStore.CreateUser(context.Background(), ac3cmd)
|
2017-06-15 13:19:54 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2020-02-29 06:35:15 -06:00
|
|
|
orgUserCmd := models.AddOrgUserCommand{
|
2017-06-15 13:19:54 -05:00
|
|
|
OrgId: ac1.OrgId,
|
|
|
|
UserId: ac3.Id,
|
2020-02-29 06:35:15 -06:00
|
|
|
Role: models.ROLE_VIEWER,
|
2017-06-15 13:19:54 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
err = AddOrgUser(&orgUserCmd)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2020-02-29 06:35:15 -06:00
|
|
|
query := models.GetOrgUsersQuery{OrgId: ac1.OrgId}
|
2017-06-15 13:19:54 -05:00
|
|
|
err = GetOrgUsers(&query)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(len(query.Result), ShouldEqual, 3)
|
|
|
|
|
2021-03-17 10:06:10 -05:00
|
|
|
dash1 := insertTestDashboard(t, sqlStore, "1 test dash", ac1.OrgId, 0, false, "prod", "webapp")
|
|
|
|
dash2 := insertTestDashboard(t, sqlStore, "2 test dash", ac3.OrgId, 0, false, "prod", "webapp")
|
2018-02-14 08:04:26 -06:00
|
|
|
|
2021-03-17 10:06:10 -05:00
|
|
|
err = testHelperUpdateDashboardAcl(t, sqlStore, dash1.Id, models.DashboardAcl{
|
|
|
|
DashboardID: dash1.Id, OrgID: ac1.OrgId, UserID: ac3.Id, Permission: models.PERMISSION_EDIT,
|
|
|
|
})
|
2017-06-15 13:19:54 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2021-03-17 10:06:10 -05:00
|
|
|
err = testHelperUpdateDashboardAcl(t, sqlStore, dash2.Id, models.DashboardAcl{
|
|
|
|
DashboardID: dash2.Id, OrgID: ac3.OrgId, UserID: ac3.Id, Permission: models.PERMISSION_EDIT,
|
|
|
|
})
|
2017-06-15 13:19:54 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
Convey("When org user is deleted", func() {
|
2020-02-29 06:35:15 -06:00
|
|
|
cmdRemove := models.RemoveOrgUserCommand{OrgId: ac1.OrgId, UserId: ac3.Id}
|
2017-06-15 13:19:54 -05:00
|
|
|
err := RemoveOrgUser(&cmdRemove)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
Convey("Should remove dependent permissions for deleted org user", func() {
|
2020-11-17 10:09:14 -06:00
|
|
|
permQuery := &models.GetDashboardAclInfoListQuery{DashboardID: 1, OrgID: ac1.OrgId}
|
2017-06-19 16:30:54 -05:00
|
|
|
err = GetDashboardAclInfoList(permQuery)
|
2017-06-15 13:19:54 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
So(len(permQuery.Result), ShouldEqual, 0)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("Should not remove dashboard permissions for same user in another org", func() {
|
2020-11-17 10:09:14 -06:00
|
|
|
permQuery := &models.GetDashboardAclInfoListQuery{DashboardID: 2, OrgID: ac3.OrgId}
|
2017-06-19 16:30:54 -05:00
|
|
|
err = GetDashboardAclInfoList(permQuery)
|
2017-06-15 13:19:54 -05:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2017-06-22 16:10:43 -05:00
|
|
|
So(len(permQuery.Result), ShouldEqual, 1)
|
2017-06-15 13:19:54 -05:00
|
|
|
So(permQuery.Result[0].OrgId, ShouldEqual, ac3.OrgId)
|
|
|
|
So(permQuery.Result[0].UserId, ShouldEqual, ac3.Id)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2014-12-19 03:45:22 -06:00
|
|
|
})
|
2014-12-19 02:43:16 -06:00
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
2018-02-14 08:04:26 -06:00
|
|
|
|
2021-03-17 10:06:10 -05:00
|
|
|
func testHelperUpdateDashboardAcl(t *testing.T, sqlStore *SQLStore, dashboardID int64,
|
|
|
|
items ...models.DashboardAcl) error {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
var itemPtrs []*models.DashboardAcl
|
|
|
|
for _, it := range items {
|
|
|
|
item := it
|
2018-03-15 18:08:25 -05:00
|
|
|
item.Created = time.Now()
|
|
|
|
item.Updated = time.Now()
|
2021-03-17 10:06:10 -05:00
|
|
|
itemPtrs = append(itemPtrs, &item)
|
2018-02-14 08:04:26 -06:00
|
|
|
}
|
2021-03-17 10:06:10 -05:00
|
|
|
return sqlStore.UpdateDashboardACL(dashboardID, itemPtrs)
|
2018-02-14 08:04:26 -06:00
|
|
|
}
|