|
|
|
@ -7,7 +7,7 @@ import ( |
|
|
|
|
|
|
|
|
|
. "github.com/smartystreets/goconvey/convey" |
|
|
|
|
|
|
|
|
|
m "github.com/grafana/grafana/pkg/models" |
|
|
|
|
"github.com/grafana/grafana/pkg/models" |
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
func TestUserDataAccess(t *testing.T) { |
|
|
|
@ -16,7 +16,7 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
ss := InitTestDB(t) |
|
|
|
|
|
|
|
|
|
Convey("Creating a user", func() { |
|
|
|
|
cmd := &m.CreateUserCommand{ |
|
|
|
|
cmd := &models.CreateUserCommand{ |
|
|
|
|
Email: "usertest@test.com", |
|
|
|
|
Name: "user name", |
|
|
|
|
Login: "user_test_login", |
|
|
|
@ -26,7 +26,7 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
Convey("Loading a user", func() { |
|
|
|
|
query := m.GetUserByIdQuery{Id: cmd.Result.Id} |
|
|
|
|
query := models.GetUserByIdQuery{Id: cmd.Result.Id} |
|
|
|
|
err := GetUserById(&query) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
@ -39,10 +39,10 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
|
|
|
|
|
Convey("Given 5 users", func() { |
|
|
|
|
var err error |
|
|
|
|
var cmd *m.CreateUserCommand |
|
|
|
|
users := []m.User{} |
|
|
|
|
var cmd *models.CreateUserCommand |
|
|
|
|
users := []models.User{} |
|
|
|
|
for i := 0; i < 5; i++ { |
|
|
|
|
cmd = &m.CreateUserCommand{ |
|
|
|
|
cmd = &models.CreateUserCommand{ |
|
|
|
|
Email: fmt.Sprint("user", i, "@test.com"), |
|
|
|
|
Name: fmt.Sprint("user", i), |
|
|
|
|
Login: fmt.Sprint("loginuser", i), |
|
|
|
@ -53,7 +53,7 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
Convey("Can return the first page of users and a total count", func() { |
|
|
|
|
query := m.SearchUsersQuery{Query: "", Page: 1, Limit: 3} |
|
|
|
|
query := models.SearchUsersQuery{Query: "", Page: 1, Limit: 3} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
|
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
@ -62,7 +62,7 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
Convey("Can return the second page of users and a total count", func() { |
|
|
|
|
query := m.SearchUsersQuery{Query: "", Page: 2, Limit: 3} |
|
|
|
|
query := models.SearchUsersQuery{Query: "", Page: 2, Limit: 3} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
|
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
@ -71,28 +71,28 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
Convey("Can return list of users matching query on user name", func() { |
|
|
|
|
query := m.SearchUsersQuery{Query: "use", Page: 1, Limit: 3} |
|
|
|
|
query := models.SearchUsersQuery{Query: "use", Page: 1, Limit: 3} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
|
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
So(len(query.Result.Users), ShouldEqual, 3) |
|
|
|
|
So(query.Result.TotalCount, ShouldEqual, 5) |
|
|
|
|
|
|
|
|
|
query = m.SearchUsersQuery{Query: "ser1", Page: 1, Limit: 3} |
|
|
|
|
query = models.SearchUsersQuery{Query: "ser1", Page: 1, Limit: 3} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
|
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
So(len(query.Result.Users), ShouldEqual, 1) |
|
|
|
|
So(query.Result.TotalCount, ShouldEqual, 1) |
|
|
|
|
|
|
|
|
|
query = m.SearchUsersQuery{Query: "USER1", Page: 1, Limit: 3} |
|
|
|
|
query = models.SearchUsersQuery{Query: "USER1", Page: 1, Limit: 3} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
|
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
So(len(query.Result.Users), ShouldEqual, 1) |
|
|
|
|
So(query.Result.TotalCount, ShouldEqual, 1) |
|
|
|
|
|
|
|
|
|
query = m.SearchUsersQuery{Query: "idontexist", Page: 1, Limit: 3} |
|
|
|
|
query = models.SearchUsersQuery{Query: "idontexist", Page: 1, Limit: 3} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
|
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
@ -101,7 +101,7 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
Convey("Can return list of users matching query on email", func() { |
|
|
|
|
query := m.SearchUsersQuery{Query: "ser1@test.com", Page: 1, Limit: 3} |
|
|
|
|
query := models.SearchUsersQuery{Query: "ser1@test.com", Page: 1, Limit: 3} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
|
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
@ -110,7 +110,7 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
Convey("Can return list of users matching query on login name", func() { |
|
|
|
|
query := m.SearchUsersQuery{Query: "loginuser1", Page: 1, Limit: 3} |
|
|
|
|
query := models.SearchUsersQuery{Query: "loginuser1", Page: 1, Limit: 3} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
|
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
@ -118,34 +118,78 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
So(query.Result.TotalCount, ShouldEqual, 1) |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
Convey("can return list users based on their auth type", func() { |
|
|
|
|
// add users to auth table
|
|
|
|
|
for index, user := range users { |
|
|
|
|
authModule := "killa" |
|
|
|
|
|
|
|
|
|
// define every second user as ldap
|
|
|
|
|
if index%2 == 0 { |
|
|
|
|
authModule = "ldap" |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
cmd2 := &models.SetAuthInfoCommand{ |
|
|
|
|
UserId: user.Id, |
|
|
|
|
AuthModule: authModule, |
|
|
|
|
AuthId: "gorilla", |
|
|
|
|
} |
|
|
|
|
err = SetAuthInfo(cmd2) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
} |
|
|
|
|
query := models.SearchUsersQuery{AuthModule: "ldap"} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
So(query.Result.Users, ShouldHaveLength, 3) |
|
|
|
|
|
|
|
|
|
zero, second, fourth := false, false, false |
|
|
|
|
for _, user := range query.Result.Users { |
|
|
|
|
if user.Name == "user0" { |
|
|
|
|
zero = true |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if user.Name == "user2" { |
|
|
|
|
second = true |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if user.Name == "user4" { |
|
|
|
|
fourth = true |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
So(zero, ShouldBeTrue) |
|
|
|
|
So(second, ShouldBeTrue) |
|
|
|
|
So(fourth, ShouldBeTrue) |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
Convey("when a user is an org member and has been assigned permissions", func() { |
|
|
|
|
err = AddOrgUser(&m.AddOrgUserCommand{LoginOrEmail: users[1].Login, Role: m.ROLE_VIEWER, OrgId: users[0].OrgId, UserId: users[1].Id}) |
|
|
|
|
err = AddOrgUser(&models.AddOrgUserCommand{LoginOrEmail: users[1].Login, Role: models.ROLE_VIEWER, OrgId: users[0].OrgId, UserId: users[1].Id}) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
testHelperUpdateDashboardAcl(1, m.DashboardAcl{DashboardId: 1, OrgId: users[0].OrgId, UserId: users[1].Id, Permission: m.PERMISSION_EDIT}) |
|
|
|
|
testHelperUpdateDashboardAcl(1, models.DashboardAcl{DashboardId: 1, OrgId: users[0].OrgId, UserId: users[1].Id, Permission: models.PERMISSION_EDIT}) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
err = SavePreferences(&m.SavePreferencesCommand{UserId: users[1].Id, OrgId: users[0].OrgId, HomeDashboardId: 1, Theme: "dark"}) |
|
|
|
|
err = SavePreferences(&models.SavePreferencesCommand{UserId: users[1].Id, OrgId: users[0].OrgId, HomeDashboardId: 1, Theme: "dark"}) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
Convey("when the user is deleted", func() { |
|
|
|
|
err = DeleteUser(&m.DeleteUserCommand{UserId: users[1].Id}) |
|
|
|
|
err = DeleteUser(&models.DeleteUserCommand{UserId: users[1].Id}) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
Convey("Should delete connected org users and permissions", func() { |
|
|
|
|
query := &m.GetOrgUsersQuery{OrgId: users[0].OrgId} |
|
|
|
|
query := &models.GetOrgUsersQuery{OrgId: users[0].OrgId} |
|
|
|
|
err = GetOrgUsersForTest(query) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
So(len(query.Result), ShouldEqual, 1) |
|
|
|
|
|
|
|
|
|
permQuery := &m.GetDashboardAclInfoListQuery{DashboardId: 1, OrgId: users[0].OrgId} |
|
|
|
|
permQuery := &models.GetDashboardAclInfoListQuery{DashboardId: 1, OrgId: users[0].OrgId} |
|
|
|
|
err = GetDashboardAclInfoList(permQuery) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
So(len(permQuery.Result), ShouldEqual, 0) |
|
|
|
|
|
|
|
|
|
prefsQuery := &m.GetPreferencesQuery{OrgId: users[0].OrgId, UserId: users[1].Id} |
|
|
|
|
prefsQuery := &models.GetPreferencesQuery{OrgId: users[0].OrgId, UserId: users[1].Id} |
|
|
|
|
err = GetPreferences(prefsQuery) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
@ -157,14 +201,14 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
Convey("when retreiving signed in user for orgId=0 result should return active org id", func() { |
|
|
|
|
ss.CacheService.Flush() |
|
|
|
|
|
|
|
|
|
query := &m.GetSignedInUserQuery{OrgId: users[1].OrgId, UserId: users[1].Id} |
|
|
|
|
query := &models.GetSignedInUserQuery{OrgId: users[1].OrgId, UserId: users[1].Id} |
|
|
|
|
err := ss.GetSignedInUserWithCache(query) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
So(query.Result, ShouldNotBeNil) |
|
|
|
|
So(query.OrgId, ShouldEqual, users[1].OrgId) |
|
|
|
|
err = SetUsingOrg(&m.SetUsingOrgCommand{UserId: users[1].Id, OrgId: users[0].OrgId}) |
|
|
|
|
err = SetUsingOrg(&models.SetUsingOrgCommand{UserId: users[1].Id, OrgId: users[0].OrgId}) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
query = &m.GetSignedInUserQuery{OrgId: 0, UserId: users[1].Id} |
|
|
|
|
query = &models.GetSignedInUserQuery{OrgId: 0, UserId: users[1].Id} |
|
|
|
|
err = ss.GetSignedInUserWithCache(query) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
So(query.Result, ShouldNotBeNil) |
|
|
|
@ -181,13 +225,13 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
for i := 0; i < 3; i++ { |
|
|
|
|
userIdsToDisable = append(userIdsToDisable, users[i].Id) |
|
|
|
|
} |
|
|
|
|
disableCmd := m.BatchDisableUsersCommand{UserIds: userIdsToDisable, IsDisabled: true} |
|
|
|
|
disableCmd := models.BatchDisableUsersCommand{UserIds: userIdsToDisable, IsDisabled: true} |
|
|
|
|
|
|
|
|
|
err = BatchDisableUsers(&disableCmd) |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
Convey("Should disable all provided users", func() { |
|
|
|
|
query := m.SearchUsersQuery{} |
|
|
|
|
query := models.SearchUsersQuery{} |
|
|
|
|
err = SearchUsers(&query) |
|
|
|
|
|
|
|
|
|
So(query.Result.TotalCount, ShouldEqual, 5) |
|
|
|
@ -213,7 +257,7 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
|
|
|
|
|
Convey("Given one grafana admin user", func() { |
|
|
|
|
var err error |
|
|
|
|
createUserCmd := &m.CreateUserCommand{ |
|
|
|
|
createUserCmd := &models.CreateUserCommand{ |
|
|
|
|
Email: fmt.Sprint("admin", "@test.com"), |
|
|
|
|
Name: fmt.Sprint("admin"), |
|
|
|
|
Login: fmt.Sprint("admin"), |
|
|
|
@ -223,12 +267,12 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
So(err, ShouldBeNil) |
|
|
|
|
|
|
|
|
|
Convey("Cannot make themselves a non-admin", func() { |
|
|
|
|
updateUserPermsCmd := m.UpdateUserPermissionsCommand{IsGrafanaAdmin: false, UserId: 1} |
|
|
|
|
updateUserPermsCmd := models.UpdateUserPermissionsCommand{IsGrafanaAdmin: false, UserId: 1} |
|
|
|
|
updatePermsError := UpdateUserPermissions(&updateUserPermsCmd) |
|
|
|
|
|
|
|
|
|
So(updatePermsError, ShouldEqual, m.ErrLastGrafanaAdmin) |
|
|
|
|
So(updatePermsError, ShouldEqual, models.ErrLastGrafanaAdmin) |
|
|
|
|
|
|
|
|
|
query := m.GetUserByIdQuery{Id: createUserCmd.Result.Id} |
|
|
|
|
query := models.GetUserByIdQuery{Id: createUserCmd.Result.Id} |
|
|
|
|
getUserError := GetUserById(&query) |
|
|
|
|
|
|
|
|
|
So(getUserError, ShouldBeNil) |
|
|
|
@ -239,8 +283,8 @@ func TestUserDataAccess(t *testing.T) { |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
func GetOrgUsersForTest(query *m.GetOrgUsersQuery) error { |
|
|
|
|
query.Result = make([]*m.OrgUserDTO, 0) |
|
|
|
|
func GetOrgUsersForTest(query *models.GetOrgUsersQuery) error { |
|
|
|
|
query.Result = make([]*models.OrgUserDTO, 0) |
|
|
|
|
sess := x.Table("org_user") |
|
|
|
|
sess.Join("LEFT ", x.Dialect().Quote("user"), fmt.Sprintf("org_user.user_id=%s.id", x.Dialect().Quote("user"))) |
|
|
|
|
sess.Where("org_user.org_id=?", query.OrgId) |
|
|
|
|