mirror of
https://github.com/grafana/grafana.git
synced 2025-07-31 15:22:26 +08:00

* Revert "chore: add replDB to team service (#91799)" This reverts commit c6ae2d7999aa6fc797db39e9d66c6fea70278f83. * Revert "experiment: use read replica for Get and Find Dashboards (#91706)" This reverts commit 54177ca619dbb5ded2dcb158405802d8dbdbc982. * Revert "QuotaService: refactor to use ReplDB for Get queries (#91333)" This reverts commit 299c142f6a6e8c5673cfdea9f87b56ac304f9834. * Revert "refactor replCfg to look more like plugins/plugin config (#91142)" This reverts commit ac0b4bb34d495914cbe8daad85b7c75c31e8070d. * Revert "chore (replstore): fix registration with multiple sql drivers, again (#90990)" This reverts commit daedb358dded00d349d9fac6106aaaa6bf18322e. * Revert "Chore (sqlstore): add validation and testing for repl config (#90683)" This reverts commit af19f039b62d9945377292a8e679ee258fd56b3d. * Revert "ReplStore: Add support for round robin load balancing between multiple read replicas (#90530)" This reverts commit 27b52b1507f5218a7b38046b4d96bc004d949d46. * Revert "DashboardStore: Use ReplDB and get dashboard quotas from the ReadReplica (#90235)" This reverts commit 8a6107cd35f6444c0674ee4230d3d6bcfbbd4a58. * Revert "accesscontrol service read replica (#89963)" This reverts commit 77a4869fcadf13827d76d5767d4de74812d6dd6d. * Revert "Fix: add mapping for the new mysqlRepl driver (#89551)" This reverts commit ab5a079bcc5b0f0a6929f0a3742eb2859d4a3498. * Revert "fix: sql instrumentation dual registration error (#89508)" This reverts commit d988f5c3b064fade6e96511e0024190c22d48e50. * Revert "Experimental Feature Toggle: databaseReadReplica (#89232)" This reverts commit 50244ed4a1435cbf3e3c87d4af34fd7937f7c259.
229 lines
7.1 KiB
Go
229 lines
7.1 KiB
Go
package folders
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"net/http"
|
|
"testing"
|
|
|
|
"github.com/go-openapi/runtime"
|
|
"github.com/grafana/grafana-openapi-client-go/client/folders"
|
|
"github.com/grafana/grafana-openapi-client-go/models"
|
|
"github.com/grafana/grafana/pkg/infra/db"
|
|
"github.com/grafana/grafana/pkg/infra/tracing"
|
|
"github.com/grafana/grafana/pkg/services/featuremgmt"
|
|
"github.com/grafana/grafana/pkg/services/org"
|
|
"github.com/grafana/grafana/pkg/services/org/orgimpl"
|
|
"github.com/grafana/grafana/pkg/services/quota/quotaimpl"
|
|
"github.com/grafana/grafana/pkg/services/supportbundles/supportbundlestest"
|
|
"github.com/grafana/grafana/pkg/services/user"
|
|
"github.com/grafana/grafana/pkg/services/user/userimpl"
|
|
"github.com/grafana/grafana/pkg/setting"
|
|
"github.com/grafana/grafana/pkg/tests"
|
|
"github.com/grafana/grafana/pkg/tests/testinfra"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
const orgID = 1
|
|
|
|
func TestIntegrationUpdateFolder(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skipping integration test")
|
|
}
|
|
|
|
dir, path := testinfra.CreateGrafDir(t, testinfra.GrafanaOpts{
|
|
DisableAnonymous: true,
|
|
EnableQuota: true,
|
|
})
|
|
|
|
grafanaListedAddr, env := testinfra.StartGrafanaEnv(t, dir, path)
|
|
store, cfg := env.SQLStore, env.Cfg
|
|
// Create user
|
|
createUser(t, store, cfg, user.CreateUserCommand{
|
|
DefaultOrgRole: string(org.RoleAdmin),
|
|
Password: "admin",
|
|
Login: "admin",
|
|
})
|
|
|
|
adminClient := tests.GetClient(grafanaListedAddr, "admin", "admin")
|
|
resp, err := adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "folder",
|
|
})
|
|
require.NoError(t, err)
|
|
require.Equal(t, http.StatusOK, resp.Code())
|
|
|
|
t.Run("update folder should succeed", func(t *testing.T) {
|
|
resp, err := adminClient.Folders.UpdateFolder(resp.Payload.UID, &models.UpdateFolderCommand{
|
|
Title: "new title",
|
|
Version: resp.Payload.Version,
|
|
})
|
|
require.NoError(t, err)
|
|
require.Equal(t, http.StatusOK, resp.Code())
|
|
require.Equal(t, "new title", resp.Payload.Title)
|
|
})
|
|
}
|
|
|
|
func TestIntegrationCreateFolder(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skipping integration test")
|
|
}
|
|
|
|
dir, path := testinfra.CreateGrafDir(t, testinfra.GrafanaOpts{
|
|
DisableAnonymous: true,
|
|
EnableQuota: true,
|
|
})
|
|
|
|
grafanaListedAddr, env := testinfra.StartGrafanaEnv(t, dir, path)
|
|
store, cfg := env.SQLStore, env.Cfg
|
|
// Create user
|
|
createUser(t, store, cfg, user.CreateUserCommand{
|
|
DefaultOrgRole: string(org.RoleAdmin),
|
|
Password: "admin",
|
|
Login: "admin",
|
|
})
|
|
|
|
adminClient := tests.GetClient(grafanaListedAddr, "admin", "admin")
|
|
|
|
t.Run("create folder under root should succeed", func(t *testing.T) {
|
|
resp, err := adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "folder",
|
|
})
|
|
require.NoError(t, err)
|
|
require.Equal(t, http.StatusOK, resp.Code())
|
|
|
|
t.Run("create folder with same name under root should fail", func(t *testing.T) {
|
|
_, err := adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "folder",
|
|
})
|
|
require.Error(t, err)
|
|
var conflict *folders.CreateFolderConflict
|
|
assert.True(t, errors.As(err, &conflict))
|
|
assert.Equal(t, http.StatusConflict, conflict.Code())
|
|
})
|
|
})
|
|
}
|
|
|
|
func TestIntegrationNestedFoldersOn(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skipping integration test")
|
|
}
|
|
|
|
dir, path := testinfra.CreateGrafDir(t, testinfra.GrafanaOpts{
|
|
DisableAnonymous: true,
|
|
EnableQuota: true,
|
|
EnableFeatureToggles: []string{featuremgmt.FlagNestedFolders},
|
|
})
|
|
|
|
grafanaListedAddr, env := testinfra.StartGrafanaEnv(t, dir, path)
|
|
store, cfg := env.SQLStore, env.Cfg
|
|
// Create user
|
|
createUser(t, store, cfg, user.CreateUserCommand{
|
|
DefaultOrgRole: string(org.RoleAdmin),
|
|
Password: "admin",
|
|
Login: "admin",
|
|
})
|
|
|
|
adminClient := tests.GetClient(grafanaListedAddr, "admin", "admin")
|
|
|
|
t.Run("create folder under root should succeed", func(t *testing.T) {
|
|
resp, err := adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "folder",
|
|
})
|
|
require.NoError(t, err)
|
|
require.Equal(t, http.StatusOK, resp.Code())
|
|
|
|
t.Run("create folder with same name under root should fail", func(t *testing.T) {
|
|
_, err := adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "folder",
|
|
})
|
|
require.Error(t, err)
|
|
var conflict *folders.CreateFolderConflict
|
|
assert.True(t, errors.As(err, &conflict))
|
|
assert.Equal(t, http.StatusConflict, conflict.Code())
|
|
})
|
|
})
|
|
|
|
t.Run("create subfolder should succeed", func(t *testing.T) {
|
|
resp, err := adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "parent",
|
|
})
|
|
require.NoError(t, err)
|
|
require.Equal(t, http.StatusOK, resp.Code())
|
|
parentUID := resp.Payload.UID
|
|
|
|
resp, err = adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "subfolder",
|
|
ParentUID: parentUID,
|
|
})
|
|
require.NoError(t, err)
|
|
require.Equal(t, http.StatusOK, resp.Code())
|
|
|
|
t.Run("create subfolder with same name should fail", func(t *testing.T) {
|
|
resp, err = adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "subfolder",
|
|
ParentUID: parentUID,
|
|
})
|
|
require.Error(t, err)
|
|
var conflict *folders.CreateFolderConflict
|
|
assert.True(t, errors.As(err, &conflict))
|
|
assert.Equal(t, http.StatusConflict, conflict.Code())
|
|
})
|
|
|
|
t.Run("create subfolder with same name under other folder should succeed", func(t *testing.T) {
|
|
resp, err := adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "other",
|
|
})
|
|
require.NoError(t, err)
|
|
require.Equal(t, http.StatusOK, resp.Code())
|
|
other := resp.Payload.UID
|
|
|
|
resp, err = adminClient.Folders.CreateFolder(&models.CreateFolderCommand{
|
|
Title: "subfolder",
|
|
ParentUID: other,
|
|
})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, http.StatusOK, resp.Code())
|
|
assert.Equal(t, other, resp.Payload.ParentUID)
|
|
subfolderUnderOther := resp.Payload.UID
|
|
|
|
t.Run("move subfolder to other folder containing folder with that name should fail", func(t *testing.T) {
|
|
_, err := adminClient.Folders.MoveFolder(subfolderUnderOther, &models.MoveFolderCommand{
|
|
ParentUID: parentUID,
|
|
})
|
|
require.Error(t, err)
|
|
var apiError *runtime.APIError
|
|
assert.True(t, errors.As(err, &apiError))
|
|
assert.Equal(t, http.StatusConflict, apiError.Code)
|
|
})
|
|
|
|
t.Run("move subfolder to root should succeed", func(t *testing.T) {
|
|
resp, err := adminClient.Folders.MoveFolder(subfolderUnderOther, &models.MoveFolderCommand{})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, http.StatusOK, resp.Code())
|
|
assert.Equal(t, "", resp.Payload.ParentUID)
|
|
})
|
|
})
|
|
})
|
|
}
|
|
|
|
func createUser(t *testing.T, db db.DB, cfg *setting.Cfg, cmd user.CreateUserCommand) int64 {
|
|
t.Helper()
|
|
|
|
cfg.AutoAssignOrg = true
|
|
cfg.AutoAssignOrgId = orgID
|
|
|
|
quotaService := quotaimpl.ProvideService(db, cfg)
|
|
orgService, err := orgimpl.ProvideService(db, cfg, quotaService)
|
|
require.NoError(t, err)
|
|
usrSvc, err := userimpl.ProvideService(
|
|
db, orgService, cfg, nil, nil, tracing.InitializeTracerForTest(),
|
|
quotaService, supportbundlestest.NewFakeBundleService(),
|
|
)
|
|
require.NoError(t, err)
|
|
|
|
u, err := usrSvc.Create(context.Background(), &cmd)
|
|
require.NoError(t, err)
|
|
return u.ID
|
|
}
|