| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- package sqlstore
- import (
- "fmt"
- "testing"
- . "github.com/smartystreets/goconvey/convey"
- m "github.com/grafana/grafana/pkg/models"
- )
- func TestUserDataAccess(t *testing.T) {
- Convey("Testing DB", t, func() {
- InitTestDB(t)
- Convey("Given 5 users", func() {
- var err error
- var cmd *m.CreateUserCommand
- users := []m.User{}
- for i := 0; i < 5; i++ {
- cmd = &m.CreateUserCommand{
- Email: fmt.Sprint("user", i, "@test.com"),
- Name: fmt.Sprint("user", i),
- Login: fmt.Sprint("loginuser", i),
- }
- err = CreateUser(cmd)
- So(err, ShouldBeNil)
- users = append(users, cmd.Result)
- }
- Convey("Can return the first page of users and a total count", func() {
- query := m.SearchUsersQuery{Query: "", Page: 1, Limit: 3}
- err = SearchUsers(&query)
- So(err, ShouldBeNil)
- So(len(query.Result.Users), ShouldEqual, 3)
- So(query.Result.TotalCount, ShouldEqual, 5)
- })
- Convey("Can return the second page of users and a total count", func() {
- query := m.SearchUsersQuery{Query: "", Page: 2, Limit: 3}
- err = SearchUsers(&query)
- So(err, ShouldBeNil)
- So(len(query.Result.Users), ShouldEqual, 2)
- So(query.Result.TotalCount, ShouldEqual, 5)
- })
- Convey("Can return list of users matching query on user name", func() {
- query := m.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}
- 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}
- 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}
- err = SearchUsers(&query)
- So(err, ShouldBeNil)
- So(len(query.Result.Users), ShouldEqual, 0)
- So(query.Result.TotalCount, ShouldEqual, 0)
- })
- Convey("Can return list of users matching query on email", func() {
- query := m.SearchUsersQuery{Query: "ser1@test.com", Page: 1, Limit: 3}
- err = SearchUsers(&query)
- So(err, ShouldBeNil)
- So(len(query.Result.Users), ShouldEqual, 1)
- So(query.Result.TotalCount, ShouldEqual, 1)
- })
- Convey("Can return list of users matching query on login name", func() {
- query := m.SearchUsersQuery{Query: "loginuser1", Page: 1, Limit: 3}
- err = SearchUsers(&query)
- So(err, ShouldBeNil)
- So(len(query.Result.Users), ShouldEqual, 1)
- So(query.Result.TotalCount, ShouldEqual, 1)
- })
- Convey("when a user is an org member and has been assigned permissions", func() {
- err = AddOrgUser(&m.AddOrgUserCommand{LoginOrEmail: users[0].Login, Role: m.ROLE_VIEWER, OrgId: users[0].OrgId})
- So(err, ShouldBeNil)
- err = SetDashboardAcl(&m.SetDashboardAclCommand{DashboardId: 1, OrgId: users[0].OrgId, UserId: users[0].Id, Permission: m.PERMISSION_EDIT})
- So(err, ShouldBeNil)
- err = SavePreferences(&m.SavePreferencesCommand{UserId: users[0].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[0].Id})
- So(err, ShouldBeNil)
- Convey("Should delete connected org users and permissions", func() {
- query := &m.GetOrgUsersQuery{OrgId: 1}
- err = GetOrgUsersForTest(query)
- So(err, ShouldBeNil)
- So(len(query.Result), ShouldEqual, 1)
- permQuery := &m.GetDashboardAclInfoListQuery{DashboardId: 1}
- err = GetDashboardAclInfoList(permQuery)
- So(err, ShouldBeNil)
- So(len(permQuery.Result), ShouldEqual, 0)
- prefsQuery := &m.GetPreferencesQuery{OrgId: users[0].OrgId, UserId: users[0].Id}
- err = GetPreferences(prefsQuery)
- So(err, ShouldBeNil)
- So(prefsQuery.Result.OrgId, ShouldEqual, 0)
- So(prefsQuery.Result.UserId, ShouldEqual, 0)
- })
- })
- })
- })
- })
- }
- func GetOrgUsersForTest(query *m.GetOrgUsersQuery) error {
- query.Result = make([]*m.OrgUserDTO, 0)
- sess := x.Table("org_user")
- sess.Join("LEFT ", "user", fmt.Sprintf("org_user.user_id=%s.id", x.Dialect().Quote("user")))
- sess.Where("org_user.org_id=?", query.OrgId)
- sess.Cols("org_user.org_id", "org_user.user_id", "user.email", "user.login", "org_user.role")
- err := sess.Find(&query.Result)
- return err
- }
|