|
|
@@ -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)
|