Files
grafana/pkg/services/queryhistory/queryhistory_delete_stale_test.go
T
Peter Štibraný 7fd9ab9481 Replace check for integration tests. (#110707)
* Replace check for integration tests.
* Revert changes in pkg/tsdb/mysql packages.
* Fix formatting of few tests.
2025-09-08 15:49:49 +02:00

72 lines
2.5 KiB
Go

package queryhistory
import (
"context"
"testing"
"github.com/stretchr/testify/require"
"github.com/grafana/grafana/pkg/infra/db"
"github.com/grafana/grafana/pkg/util/testutil"
"github.com/grafana/grafana/pkg/web"
)
func TestIntegrationDeleteStaleQueryFromQueryHistory(t *testing.T) {
testutil.SkipIntegrationTestInShortMode(t)
testScenarioWithQueryInQueryHistory(t, "Stale query history can be deleted",
func(t *testing.T, sc scenarioContext) {
olderThan := sc.service.now().Unix() + 60
rowsDeleted, err := sc.service.DeleteStaleQueriesInQueryHistory(context.Background(), olderThan)
require.NoError(t, err)
require.Equal(t, 1, rowsDeleted)
})
testScenarioWithQueryInQueryHistory(t, "Stale single starred query history can not be deleted",
func(t *testing.T, sc scenarioContext) {
sc.ctx.Req = web.SetURLParams(sc.ctx.Req, map[string]string{":uid": sc.initialResult.Result.UID})
resp := sc.service.starHandler(sc.reqContext)
require.Equal(t, 200, resp.Status())
olderThan := sc.service.now().Unix() + 60
rowsDeleted, err := sc.service.DeleteStaleQueriesInQueryHistory(context.Background(), olderThan)
require.NoError(t, err)
require.Equal(t, 0, rowsDeleted)
})
testScenarioWithQueryInQueryHistory(t, "Not stale query history is not deleted",
func(t *testing.T, sc scenarioContext) {
olderThan := sc.service.now().Unix() - 60
rowsDeleted, err := sc.service.DeleteStaleQueriesInQueryHistory(context.Background(), olderThan)
require.NoError(t, err)
require.Equal(t, 0, rowsDeleted)
})
// In this scenario we have 2 starred queries and 1 not starred query
testScenarioWithMultipleQueriesInQueryHistory(t, "Stale starred query history can not be deleted",
func(t *testing.T, sc scenarioContext) {
// all indices are added
err := sc.sqlStore.WithDbSession(context.Background(), func(dbSession *db.Session) error {
count, err := dbSession.Table("query_history_details").Count()
require.NoError(t, err)
require.Equal(t, int64(3), count)
return err
})
require.NoError(t, err)
olderThan := sc.service.now().Unix() + 60
rowsDeleted, err := sc.service.DeleteStaleQueriesInQueryHistory(context.Background(), olderThan)
require.NoError(t, err)
require.Equal(t, 1, rowsDeleted)
// only one details row is removed
err = sc.sqlStore.WithDbSession(context.Background(), func(dbSession *db.Session) error {
count, err := dbSession.Table("query_history_details").Count()
require.NoError(t, err)
require.Equal(t, int64(2), count)
return err
})
require.NoError(t, err)
})
}