mirror of
https://github.com/mattermost/focalboard.git
synced 2025-01-26 18:48:15 +02:00
03f4717e96
* WIP * Added migrations * Updating store method * WIP * WIP * Updated DND * WIP * WIP * WIP * WIP * WIP * wip * WIP * Adding new DB tool * Used migration functions in new migrations * Unique constraint migration * Unique constraint migration * Added SQLITE migrations * Added SQLITE support in few more migrations * Added SQLITE support in few more migrations * WIP * Used old-fashioned way to add unique constraint * Using oldsqlite method * Using oldsqlite method * Fixed all store and app layer tests * fixed integration tests * test and lint fix * Updated migration for MySQL and Postgres on personal server * Types fix * sqlite fix * fix typo * misc cleanup * added new tests * added new tests * de-duping input for postgres * integration tests, rmeoved uneeded migration * Added some migration tests * Added some migration tests * Fixed a test * completed migration tests * completed migration tests * Removed leftover debug statements Co-authored-by: Mattermost Build <build@mattermost.com>
140 lines
3.5 KiB
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 (
|
|
"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, []string{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.True(t, model.IsErrNotFound(err), err)
|
|
require.Nil(t, member)
|
|
|
|
// GetSharing throws error on now rows found
|
|
sharing, err := store.GetSharing(boardID)
|
|
require.Error(t, err)
|
|
require.True(t, model.IsErrNotFound(err), err)
|
|
require.Nil(t, sharing)
|
|
|
|
category, err := store.GetUserCategoryBoards(boardID, testTeamID)
|
|
require.NoError(t, err)
|
|
require.Empty(t, category)
|
|
})
|
|
}
|