ab3bf6312c
* Persistent user config (#2133) * Added user config API * Add unit tests * lint fix * Fixed webapp tests * Fixed webapp tests * Updated props in store after updating * Minor fixes * Removed redundent data from audit logs * Onboarding Tour (#2287) * Created private board * Roughly displayed tour * Synced with Dhama's changes * WIP * Trying to add GIF * Added 3 tour steps * WIP * WIP * WIP * checked in missed file * Synced with feature branch * WIp * Adde skip tour option * Fixed image loading for on-prem * Made tour work on presonal server: * Adde missed file * Adding telemetry * Adding telemetry * Added tour tip telemetry * Fixed pulsating dot styling for personal server * reverted personal config * Added reset tour button * Displayed share tour tip of feature is enabled * Lint fixes * Fixed webapp tests * Fixed webapp tests * Completed webapp tests * Completed webapp tests * Webapp lint fixes * Added server tests * Testing cypress skip tour fix * Fixed Cypress tests * Added share board tour step * Added share board tour step * webapp lint fixes * Updated logic to pick welcome board * Updated tests: * lint fixes * Updating UI changes * Fixed a bug causing card tour to re-appear * FIxed minor issue * FIxed bug where card tour didn't start in clickingh on card * Fixed tests * Make update user props use string instead of interface * Fixed a value type * Updating gif size * Updating resolution breakpoint * Updating tutorial tip * Updating view selector * Refactored tour components * Misc fixes * minor refactoring * GH-2258: allow date range to overflow (#2268) * allow date range to overflow * Fixed issue with date overflowing into neighbouring column Co-authored-by: Harshil Sharma <harshilsharma63@gmail.com> Co-authored-by: Mattermod <mattermod@users.noreply.github.com> * Update readme with accurate Linux standalone app build instructions (#2351) * Bump follow-redirects from 1.14.7 to 1.14.8 in /experiments/webext (#2339) Bumps [follow-redirects](https://github.com/follow-redirects/follow-redirects) from 1.14.7 to 1.14.8. - [Release notes](https://github.com/follow-redirects/follow-redirects/releases) - [Commits](https://github.com/follow-redirects/follow-redirects/compare/v1.14.7...v1.14.8) --- updated-dependencies: - dependency-name: follow-redirects dependency-type: indirect ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Switch component style fixed: selector specificity increased by adding additional class. (#2179) * Adding sever side undelete endpoint (#2222) * Adding sever side undelete endpoint * Removing long lines golangci-lint errors * Fixing linter errors * Fixing a test problem * Fixing tests Co-authored-by: Mattermod <mattermod@users.noreply.github.com> * Removing transactions from sqlite backend (#2361) * Removing transactions from sqlite backend * Skipping tests in sqlite because the lack of transactions * Generating the mocks * Fixing golangci-lint * Fixing problem opening the tour tooltip on card open * Fixing texts missmatch * Adding the Product Tour entry in the user settings menu * Fixing some tests * Fixing tests Co-authored-by: Asaad Mahmood <asaadmahmood@users.noreply.github.com> Co-authored-by: Scott Bishel <scott.bishel@mattermost.com> Co-authored-by: Mattermod <mattermod@users.noreply.github.com> Co-authored-by: Doug Lauder <wiggin77@warpmail.net> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: kamre <eremchenko@gmail.com> Co-authored-by: Jesús Espino <jespinog@gmail.com> * Restored package json * Restored package json Co-authored-by: Asaad Mahmood <asaadmahmood@users.noreply.github.com> Co-authored-by: Scott Bishel <scott.bishel@mattermost.com> Co-authored-by: Mattermod <mattermod@users.noreply.github.com> Co-authored-by: Doug Lauder <wiggin77@warpmail.net> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: kamre <eremchenko@gmail.com> Co-authored-by: Jesús Espino <jespinog@gmail.com>
270 lines
8.3 KiB
Go
270 lines
8.3 KiB
Go
package model
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"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])
|
|
})
|
|
}
|
|
|
|
func TestStampModificationMetadata(t *testing.T) {
|
|
t.Run("base case", func(t *testing.T) {
|
|
block := Block{}
|
|
blocks := []Block{block}
|
|
assert.Empty(t, block.ModifiedBy)
|
|
assert.Empty(t, block.UpdateAt)
|
|
|
|
StampModificationMetadata("user_id_1", blocks, nil)
|
|
assert.Equal(t, "user_id_1", blocks[0].ModifiedBy)
|
|
assert.NotEmpty(t, blocks[0].UpdateAt)
|
|
})
|
|
}
|