focalboard/server/services/store/storetests/data_retention.go

140 lines
3.5 KiB
Go

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
package storetests
import (
"database/sql"
"testing"
"time"
"github.com/mattermost/focalboard/server/model"
"github.com/mattermost/focalboard/server/services/store"
"github.com/mattermost/focalboard/server/utils"
"github.com/stretchr/testify/require"
)
const (
boardID = "board-id-test"
categoryID = "category-id-test"
)
func StoreTestDataRetention(t *testing.T, setup func(t *testing.T) (store.Store, func())) {
t.Run("RunDataRetention", func(t *testing.T) {
store, tearDown := setup(t)
defer tearDown()
category := model.Category{
ID: categoryID,
Name: "TestCategory",
UserID: testUserID,
TeamID: testTeamID,
}
err := store.CreateCategory(category)
require.NoError(t, err)
testRunDataRetention(t, store, 0)
testRunDataRetention(t, store, 2)
testRunDataRetention(t, store, 10)
})
}
func LoadData(t *testing.T, store store.Store) {
validBoard := model.Board{
ID: boardID,
IsTemplate: false,
ModifiedBy: testUserID,
TeamID: testTeamID,
}
board, err := store.InsertBoard(&validBoard, testUserID)
require.NoError(t, err)
validBlock := model.Block{
ID: "id-test",
BoardID: board.ID,
ModifiedBy: testUserID,
}
validBlock2 := model.Block{
ID: "id-test2",
BoardID: board.ID,
ModifiedBy: testUserID,
}
validBlock3 := model.Block{
ID: "id-test3",
BoardID: board.ID,
ModifiedBy: testUserID,
}
validBlock4 := model.Block{
ID: "id-test4",
BoardID: board.ID,
ModifiedBy: testUserID,
}
newBlocks := []model.Block{validBlock, validBlock2, validBlock3, validBlock4}
err = store.InsertBlocks(newBlocks, testUserID)
require.NoError(t, err)
member := &model.BoardMember{
UserID: testUserID,
BoardID: boardID,
SchemeAdmin: true,
}
_, err = store.SaveMember(member)
require.NoError(t, err)
sharing := model.Sharing{
ID: boardID,
Enabled: true,
Token: "testToken",
}
err = store.UpsertSharing(sharing)
require.NoError(t, err)
err = store.AddUpdateCategoryBoard(testUserID, categoryID, boardID)
require.NoError(t, err)
}
func testRunDataRetention(t *testing.T, store store.Store, batchSize int) {
LoadData(t, store)
blocks, err := store.GetBlocksForBoard(boardID)
require.NoError(t, err)
require.Len(t, blocks, 4)
initialCount := len(blocks)
t.Run("test no deletions", func(t *testing.T) {
deletions, err := store.RunDataRetention(utils.GetMillisForTime(time.Now().Add(-time.Hour*1)), int64(batchSize))
require.NoError(t, err)
require.Equal(t, int64(0), deletions)
})
t.Run("test all deletions", func(t *testing.T) {
deletions, err := store.RunDataRetention(utils.GetMillisForTime(time.Now().Add(time.Hour*1)), int64(batchSize))
require.NoError(t, err)
require.True(t, deletions > int64(initialCount))
// expect all blocks to be deleted.
blocks, errBlocks := store.GetBlocksForBoard(boardID)
require.NoError(t, errBlocks)
require.Equal(t, 0, len(blocks))
// GetMemberForBoard throws error on now rows found
member, err := store.GetMemberForBoard(boardID, testUserID)
require.Error(t, err)
require.Equal(t, sql.ErrNoRows, err)
require.Nil(t, member)
// GetSharing throws error on now rows found
sharing, err := store.GetSharing(boardID)
require.Error(t, err)
require.Equal(t, sql.ErrNoRows, err)
require.Nil(t, sharing)
category, err := store.GetUserCategoryBoards(boardID, testTeamID)
require.NoError(t, err)
require.Empty(t, category)
})
}