mirror of
https://github.com/grafana/grafana.git
synced 2024-12-01 13:09:22 -06:00
ea3d368e91
* Stats: add active user count query * License: add info in settings * Stats: Retrieve active users stats for different roles + Clean files and tests * Stats: add dialect.Quote in queries * Stats: improve tests (require instead of assert) * Stats: improve tests (require instead of assert)
131 lines
3.6 KiB
Go
131 lines
3.6 KiB
Go
package sqlstore
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/grafana/grafana/pkg/models"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestStatsDataAccess(t *testing.T) {
|
|
t.Run("Testing Stats Data Access", func(t *testing.T) {
|
|
InitTestDB(t)
|
|
|
|
t.Run("Get system stats should not results in error", func(t *testing.T) {
|
|
populateDB(t)
|
|
|
|
query := models.GetSystemStatsQuery{}
|
|
err := GetSystemStats(&query)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, int64(3), query.Result.Users)
|
|
assert.Equal(t, 1, query.Result.Editors)
|
|
assert.Equal(t, 1, query.Result.Viewers)
|
|
assert.Equal(t, 3, query.Result.Admins)
|
|
})
|
|
|
|
t.Run("Get system user count stats should not results in error", func(t *testing.T) {
|
|
query := models.GetSystemUserCountStatsQuery{}
|
|
err := GetSystemUserCountStats(context.Background(), &query)
|
|
assert.NoError(t, err)
|
|
})
|
|
|
|
t.Run("Get datasource stats should not results in error", func(t *testing.T) {
|
|
query := models.GetDataSourceStatsQuery{}
|
|
err := GetDataSourceStats(&query)
|
|
assert.NoError(t, err)
|
|
})
|
|
|
|
t.Run("Get datasource access stats should not results in error", func(t *testing.T) {
|
|
query := models.GetDataSourceAccessStatsQuery{}
|
|
err := GetDataSourceAccessStats(&query)
|
|
assert.NoError(t, err)
|
|
})
|
|
|
|
t.Run("Get alert notifier stats should not results in error", func(t *testing.T) {
|
|
query := models.GetAlertNotifierUsageStatsQuery{}
|
|
err := GetAlertNotifiersUsageStats(context.Background(), &query)
|
|
assert.NoError(t, err)
|
|
})
|
|
|
|
t.Run("Get admin stats should not result in error", func(t *testing.T) {
|
|
query := models.GetAdminStatsQuery{}
|
|
err := GetAdminStats(&query)
|
|
assert.NoError(t, err)
|
|
})
|
|
|
|
t.Run("Get active user count stats should not result in error", func(t *testing.T) {
|
|
query := models.GetActiveUserStatsQuery{}
|
|
err := GetActiveUserStats(&query)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, int64(1), query.Result.ActiveUsers)
|
|
assert.Equal(t, int64(1), query.Result.ActiveAdmins)
|
|
assert.Equal(t, int64(0), query.Result.ActiveEditors)
|
|
assert.Equal(t, int64(0), query.Result.ActiveViewers)
|
|
})
|
|
})
|
|
}
|
|
|
|
func populateDB(t *testing.T) {
|
|
users := make([]models.User, 3)
|
|
for i := range users {
|
|
cmd := &models.CreateUserCommand{
|
|
Email: fmt.Sprintf("usertest%v@test.com", i),
|
|
Name: fmt.Sprintf("user name %v", i),
|
|
Login: fmt.Sprintf("user_test_%v_login", i),
|
|
OrgName: fmt.Sprintf("Org #%v", i),
|
|
}
|
|
err := CreateUser(context.Background(), cmd)
|
|
require.NoError(t, err)
|
|
users[i] = cmd.Result
|
|
}
|
|
|
|
// get 1st user's organisation
|
|
getOrgByIdQuery := &models.GetOrgByIdQuery{Id: users[0].OrgId}
|
|
err := GetOrgById(getOrgByIdQuery)
|
|
require.NoError(t, err)
|
|
org := getOrgByIdQuery.Result
|
|
|
|
// add 2nd user as editor
|
|
cmd := &models.AddOrgUserCommand{
|
|
OrgId: org.Id,
|
|
UserId: users[1].Id,
|
|
Role: models.ROLE_EDITOR,
|
|
}
|
|
err = AddOrgUser(cmd)
|
|
require.NoError(t, err)
|
|
|
|
// add 3rd user as viewer
|
|
cmd = &models.AddOrgUserCommand{
|
|
OrgId: org.Id,
|
|
UserId: users[2].Id,
|
|
Role: models.ROLE_VIEWER,
|
|
}
|
|
err = AddOrgUser(cmd)
|
|
require.NoError(t, err)
|
|
|
|
// get 2nd user's organisation
|
|
getOrgByIdQuery = &models.GetOrgByIdQuery{Id: users[1].OrgId}
|
|
err = GetOrgById(getOrgByIdQuery)
|
|
require.NoError(t, err)
|
|
org = getOrgByIdQuery.Result
|
|
|
|
// add 1st user as admin
|
|
cmd = &models.AddOrgUserCommand{
|
|
OrgId: org.Id,
|
|
UserId: users[0].Id,
|
|
Role: models.ROLE_ADMIN,
|
|
}
|
|
err = AddOrgUser(cmd)
|
|
require.NoError(t, err)
|
|
|
|
// update 1st user last seen at
|
|
updateUserLastSeenAtCmd := &models.UpdateUserLastSeenAtCommand{
|
|
UserId: users[0].Id,
|
|
}
|
|
err = UpdateUserLastSeenAt(updateUserLastSeenAtCmd)
|
|
require.NoError(t, err)
|
|
}
|