mirror of
https://github.com/mattermost/focalboard.git
synced 2025-01-11 18:13:52 +02:00
106a8e5b2e
* Fixing unique ID problems on content order with multiple colums * Fixing duplication * Fix linter errors
255 lines
7.9 KiB
Go
255 lines
7.9 KiB
Go
package model
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/mattermost/mattermost-server/v6/shared/mlog"
|
|
|
|
"github.com/mattermost/focalboard/server/utils"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestGenerateBlockIDs(t *testing.T) {
|
|
t.Run("Should generate a new ID for a single block with no references", func(t *testing.T) {
|
|
blockID := utils.NewID(utils.IDTypeBlock)
|
|
blocks := []Block{{ID: blockID}}
|
|
|
|
blocks = GenerateBlockIDs(blocks, &mlog.Logger{})
|
|
|
|
require.NotEqual(t, blockID, blocks[0].ID)
|
|
require.Zero(t, blocks[0].RootID)
|
|
require.Zero(t, blocks[0].ParentID)
|
|
})
|
|
|
|
t.Run("Should generate a new ID for a single block with references", func(t *testing.T) {
|
|
blockID := utils.NewID(utils.IDTypeBlock)
|
|
rootID := utils.NewID(utils.IDTypeBlock)
|
|
parentID := utils.NewID(utils.IDTypeBlock)
|
|
blocks := []Block{{ID: blockID, RootID: rootID, ParentID: parentID}}
|
|
|
|
blocks = GenerateBlockIDs(blocks, &mlog.Logger{})
|
|
|
|
require.NotEqual(t, blockID, blocks[0].ID)
|
|
require.Equal(t, rootID, blocks[0].RootID)
|
|
require.Equal(t, parentID, blocks[0].ParentID)
|
|
})
|
|
|
|
t.Run("Should generate IDs and link multiple blocks with existing references", func(t *testing.T) {
|
|
blockID1 := utils.NewID(utils.IDTypeBlock)
|
|
rootID1 := utils.NewID(utils.IDTypeBlock)
|
|
parentID1 := utils.NewID(utils.IDTypeBlock)
|
|
block1 := Block{ID: blockID1, RootID: rootID1, ParentID: parentID1}
|
|
|
|
blockID2 := utils.NewID(utils.IDTypeBlock)
|
|
rootID2 := blockID1
|
|
parentID2 := utils.NewID(utils.IDTypeBlock)
|
|
block2 := Block{ID: blockID2, RootID: rootID2, ParentID: parentID2}
|
|
|
|
blocks := []Block{block1, block2}
|
|
|
|
blocks = GenerateBlockIDs(blocks, &mlog.Logger{})
|
|
|
|
require.NotEqual(t, blockID1, blocks[0].ID)
|
|
require.Equal(t, rootID1, blocks[0].RootID)
|
|
require.Equal(t, parentID1, blocks[0].ParentID)
|
|
|
|
require.NotEqual(t, blockID2, blocks[1].ID)
|
|
require.NotEqual(t, rootID2, blocks[1].RootID)
|
|
require.Equal(t, parentID2, blocks[1].ParentID)
|
|
|
|
// blockID1 was referenced, so it should still be after the ID
|
|
// changes
|
|
require.Equal(t, blocks[0].ID, blocks[1].RootID)
|
|
})
|
|
|
|
t.Run("Should generate new IDs but not modify nonexisting references", func(t *testing.T) {
|
|
blockID1 := utils.NewID(utils.IDTypeBlock)
|
|
rootID1 := ""
|
|
parentID1 := utils.NewID(utils.IDTypeBlock)
|
|
block1 := Block{ID: blockID1, RootID: rootID1, ParentID: parentID1}
|
|
|
|
blockID2 := utils.NewID(utils.IDTypeBlock)
|
|
rootID2 := utils.NewID(utils.IDTypeBlock)
|
|
parentID2 := ""
|
|
block2 := Block{ID: blockID2, RootID: rootID2, ParentID: parentID2}
|
|
|
|
blocks := []Block{block1, block2}
|
|
|
|
blocks = GenerateBlockIDs(blocks, &mlog.Logger{})
|
|
|
|
// only the IDs should have changed
|
|
require.NotEqual(t, blockID1, blocks[0].ID)
|
|
require.Zero(t, blocks[0].RootID)
|
|
require.Equal(t, parentID1, blocks[0].ParentID)
|
|
|
|
require.NotEqual(t, blockID2, blocks[1].ID)
|
|
require.Equal(t, rootID2, blocks[1].RootID)
|
|
require.Zero(t, blocks[1].ParentID)
|
|
})
|
|
|
|
t.Run("Should modify correctly multiple blocks with existing and nonexisting references", func(t *testing.T) {
|
|
blockID1 := utils.NewID(utils.IDTypeBlock)
|
|
rootID1 := utils.NewID(utils.IDTypeBlock)
|
|
parentID1 := utils.NewID(utils.IDTypeBlock)
|
|
block1 := Block{ID: blockID1, RootID: rootID1, ParentID: parentID1}
|
|
|
|
// linked to 1
|
|
blockID2 := utils.NewID(utils.IDTypeBlock)
|
|
rootID2 := blockID1
|
|
parentID2 := utils.NewID(utils.IDTypeBlock)
|
|
block2 := Block{ID: blockID2, RootID: rootID2, ParentID: parentID2}
|
|
|
|
// linked to 2
|
|
blockID3 := utils.NewID(utils.IDTypeBlock)
|
|
rootID3 := blockID2
|
|
parentID3 := utils.NewID(utils.IDTypeBlock)
|
|
block3 := Block{ID: blockID3, RootID: rootID3, ParentID: parentID3}
|
|
|
|
// linked to 1
|
|
blockID4 := utils.NewID(utils.IDTypeBlock)
|
|
rootID4 := blockID1
|
|
parentID4 := utils.NewID(utils.IDTypeBlock)
|
|
block4 := Block{ID: blockID4, RootID: rootID4, ParentID: parentID4}
|
|
|
|
// blocks are shuffled
|
|
blocks := []Block{block4, block2, block1, block3}
|
|
|
|
blocks = GenerateBlockIDs(blocks, &mlog.Logger{})
|
|
|
|
// block 1
|
|
require.NotEqual(t, blockID1, blocks[2].ID)
|
|
require.Equal(t, rootID1, blocks[2].RootID)
|
|
require.Equal(t, parentID1, blocks[2].ParentID)
|
|
|
|
// block 2
|
|
require.NotEqual(t, blockID2, blocks[1].ID)
|
|
require.NotEqual(t, rootID2, blocks[1].RootID)
|
|
require.Equal(t, blocks[2].ID, blocks[1].RootID) // link to 1
|
|
require.Equal(t, parentID2, blocks[1].ParentID)
|
|
|
|
// block 3
|
|
require.NotEqual(t, blockID3, blocks[3].ID)
|
|
require.NotEqual(t, rootID3, blocks[3].RootID)
|
|
require.Equal(t, blocks[1].ID, blocks[3].RootID) // link to 2
|
|
require.Equal(t, parentID3, blocks[3].ParentID)
|
|
|
|
// block 4
|
|
require.NotEqual(t, blockID4, blocks[0].ID)
|
|
require.NotEqual(t, rootID4, blocks[0].RootID)
|
|
require.Equal(t, blocks[2].ID, blocks[0].RootID) // link to 1
|
|
require.Equal(t, parentID4, blocks[0].ParentID)
|
|
})
|
|
|
|
t.Run("Should update content order", func(t *testing.T) {
|
|
blockID1 := utils.NewID(utils.IDTypeBlock)
|
|
rootID1 := utils.NewID(utils.IDTypeBlock)
|
|
parentID1 := utils.NewID(utils.IDTypeBlock)
|
|
block1 := Block{
|
|
ID: blockID1,
|
|
RootID: rootID1,
|
|
ParentID: parentID1,
|
|
}
|
|
|
|
blockID2 := utils.NewID(utils.IDTypeBlock)
|
|
rootID2 := utils.NewID(utils.IDTypeBlock)
|
|
parentID2 := utils.NewID(utils.IDTypeBlock)
|
|
block2 := Block{
|
|
ID: blockID2,
|
|
RootID: rootID2,
|
|
ParentID: parentID2,
|
|
Fields: map[string]interface{}{
|
|
"contentOrder": []interface{}{
|
|
blockID1,
|
|
},
|
|
},
|
|
}
|
|
|
|
blocks := []Block{block1, block2}
|
|
|
|
blocks = GenerateBlockIDs(blocks, &mlog.Logger{})
|
|
|
|
require.NotEqual(t, blockID1, blocks[0].ID)
|
|
require.Equal(t, rootID1, blocks[0].RootID)
|
|
require.Equal(t, parentID1, blocks[0].ParentID)
|
|
|
|
require.NotEqual(t, blockID2, blocks[1].ID)
|
|
require.Equal(t, rootID2, blocks[1].RootID)
|
|
require.Equal(t, parentID2, blocks[1].ParentID)
|
|
|
|
// since block 1 was referenced in block 2,
|
|
// the ID should have been changed in content order
|
|
block2ContentOrder, ok := block2.Fields["contentOrder"].([]interface{})
|
|
require.True(t, ok)
|
|
require.NotEqual(t, blockID1, block2ContentOrder[0].(string))
|
|
require.Equal(t, blocks[0].ID, block2ContentOrder[0].(string))
|
|
})
|
|
|
|
t.Run("Should update content order when it contain slices", func(t *testing.T) {
|
|
blockID1 := utils.NewID(utils.IDTypeBlock)
|
|
rootID1 := utils.NewID(utils.IDTypeBlock)
|
|
parentID1 := utils.NewID(utils.IDTypeBlock)
|
|
block1 := Block{
|
|
ID: blockID1,
|
|
RootID: rootID1,
|
|
ParentID: parentID1,
|
|
}
|
|
|
|
blockID2 := utils.NewID(utils.IDTypeBlock)
|
|
block2 := Block{
|
|
ID: blockID2,
|
|
RootID: rootID1,
|
|
ParentID: parentID1,
|
|
}
|
|
|
|
blockID3 := utils.NewID(utils.IDTypeBlock)
|
|
block3 := Block{
|
|
ID: blockID3,
|
|
RootID: rootID1,
|
|
ParentID: parentID1,
|
|
}
|
|
|
|
blockID4 := utils.NewID(utils.IDTypeBlock)
|
|
rootID2 := utils.NewID(utils.IDTypeBlock)
|
|
parentID2 := utils.NewID(utils.IDTypeBlock)
|
|
|
|
block4 := Block{
|
|
ID: blockID4,
|
|
RootID: rootID2,
|
|
ParentID: parentID2,
|
|
Fields: map[string]interface{}{
|
|
"contentOrder": []interface{}{
|
|
blockID1,
|
|
[]interface{}{
|
|
blockID2,
|
|
blockID3,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
blocks := []Block{block1, block2, block3, block4}
|
|
|
|
blocks = GenerateBlockIDs(blocks, &mlog.Logger{})
|
|
|
|
require.NotEqual(t, blockID1, blocks[0].ID)
|
|
require.Equal(t, rootID1, blocks[0].RootID)
|
|
require.Equal(t, parentID1, blocks[0].ParentID)
|
|
|
|
require.NotEqual(t, blockID4, blocks[3].ID)
|
|
require.Equal(t, rootID2, blocks[3].RootID)
|
|
require.Equal(t, parentID2, blocks[3].ParentID)
|
|
|
|
// since block 1 was referenced in block 2,
|
|
// the ID should have been changed in content order
|
|
block4ContentOrder, ok := block4.Fields["contentOrder"].([]interface{})
|
|
require.True(t, ok)
|
|
require.NotEqual(t, blockID1, block4ContentOrder[0].(string))
|
|
require.NotEqual(t, blockID2, block4ContentOrder[1].([]interface{})[0])
|
|
require.NotEqual(t, blockID3, block4ContentOrder[1].([]interface{})[1])
|
|
require.Equal(t, blocks[0].ID, block4ContentOrder[0].(string))
|
|
require.Equal(t, blocks[1].ID, block4ContentOrder[1].([]interface{})[0])
|
|
require.Equal(t, blocks[2].ID, block4ContentOrder[1].([]interface{})[1])
|
|
})
|
|
}
|