Handle multiple simultaneous block editor layouts (#16184)
* Handle multiple simultaneous block editor layouts * Cleanup --------- Co-authored-by: Bjarke Berg <mail@bergmania.dk>
This commit is contained in:
@@ -29,6 +29,144 @@ public class BlockGridPropertyValueConverterTests : BlockPropertyValueConverterT
|
||||
Assert.AreEqual(typeof(BlockGridModel), valueType);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void Convert_Valid_Json()
|
||||
{
|
||||
var editor = CreateConverter();
|
||||
var config = ConfigForSingle(SettingKey1);
|
||||
var propertyType = GetPropertyType(config);
|
||||
var publishedElement = Mock.Of<IPublishedElement>();
|
||||
|
||||
var json = @"
|
||||
{
|
||||
""layout"": {
|
||||
""" + Constants.PropertyEditors.Aliases.BlockGrid + @""": [
|
||||
{
|
||||
""contentUdi"": ""umb://element/1304E1DDAC87439684FE8A399231CB3D"",
|
||||
""settingsUdi"": ""umb://element/2D3529EDB47B4B109F6D4B802DD5DFE2"",
|
||||
""rowSpan"": 1,
|
||||
""columnSpan"": 12,
|
||||
""areas"": []
|
||||
}
|
||||
]
|
||||
},
|
||||
""contentData"": [
|
||||
{
|
||||
""contentTypeKey"": """ + ContentKey1 + @""",
|
||||
""udi"": ""umb://element/1304E1DDAC87439684FE8A399231CB3D""
|
||||
}
|
||||
],
|
||||
""settingsData"": [
|
||||
{
|
||||
""contentTypeKey"": """ + SettingKey1 + @""",
|
||||
""udi"": ""umb://element/2D3529EDB47B4B109F6D4B802DD5DFE2""
|
||||
}
|
||||
]
|
||||
}";
|
||||
var converted =
|
||||
editor.ConvertIntermediateToObject(publishedElement, propertyType, PropertyCacheLevel.None, json, false) as
|
||||
BlockGridModel;
|
||||
|
||||
Assert.IsNotNull(converted);
|
||||
Assert.AreEqual(1, converted.Count);
|
||||
Assert.AreEqual(Guid.Parse("1304E1DD-AC87-4396-84FE-8A399231CB3D"), converted[0].Content.Key);
|
||||
Assert.AreEqual(UdiParser.Parse("umb://element/1304E1DDAC87439684FE8A399231CB3D"), converted[0].ContentUdi);
|
||||
Assert.AreEqual(ContentAlias1, converted[0].Content.ContentType.Alias);
|
||||
Assert.AreEqual(Guid.Parse("2D3529ED-B47B-4B10-9F6D-4B802DD5DFE2"), converted[0].Settings.Key);
|
||||
Assert.AreEqual(UdiParser.Parse("umb://element/2D3529EDB47B4B109F6D4B802DD5DFE2"), converted[0].SettingsUdi);
|
||||
Assert.AreEqual(SettingAlias1, converted[0].Settings.ContentType.Alias);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void Can_Convert_Without_Settings()
|
||||
{
|
||||
var editor = CreateConverter();
|
||||
var config = ConfigForSingle();
|
||||
var propertyType = GetPropertyType(config);
|
||||
var publishedElement = Mock.Of<IPublishedElement>();
|
||||
|
||||
var json = @"
|
||||
{
|
||||
""layout"": {
|
||||
""" + Constants.PropertyEditors.Aliases.BlockGrid + @""": [
|
||||
{
|
||||
""contentUdi"": ""umb://element/1304E1DDAC87439684FE8A399231CB3D"",
|
||||
""rowSpan"": 1,
|
||||
""columnSpan"": 12,
|
||||
""areas"": []
|
||||
}
|
||||
]
|
||||
},
|
||||
""contentData"": [
|
||||
{
|
||||
""contentTypeKey"": """ + ContentKey1 + @""",
|
||||
""udi"": ""umb://element/1304E1DDAC87439684FE8A399231CB3D""
|
||||
}
|
||||
]
|
||||
}";
|
||||
var converted =
|
||||
editor.ConvertIntermediateToObject(publishedElement, propertyType, PropertyCacheLevel.None, json, false) as
|
||||
BlockGridModel;
|
||||
|
||||
Assert.IsNotNull(converted);
|
||||
Assert.AreEqual(1, converted.Count);
|
||||
var item0 = converted[0].Content;
|
||||
Assert.AreEqual(Guid.Parse("1304E1DD-AC87-4396-84FE-8A399231CB3D"), item0.Key);
|
||||
Assert.AreEqual(UdiParser.Parse("umb://element/1304E1DDAC87439684FE8A399231CB3D"), converted[0].ContentUdi);
|
||||
Assert.AreEqual("Test1", item0.ContentType.Alias);
|
||||
Assert.IsNull(converted[0].Settings);
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void Ignores_Other_Layouts()
|
||||
{
|
||||
var editor = CreateConverter();
|
||||
var config = ConfigForSingle();
|
||||
var propertyType = GetPropertyType(config);
|
||||
var publishedElement = Mock.Of<IPublishedElement>();
|
||||
|
||||
var json = @"
|
||||
{
|
||||
""layout"": {
|
||||
""" + Constants.PropertyEditors.Aliases.BlockGrid + @""": [
|
||||
{
|
||||
""contentUdi"": ""umb://element/1304E1DDAC87439684FE8A399231CB3D"",
|
||||
""rowSpan"": 1,
|
||||
""columnSpan"": 12,
|
||||
""areas"": []
|
||||
}
|
||||
],
|
||||
""" + Constants.PropertyEditors.Aliases.BlockList + @""": [
|
||||
{
|
||||
""contentUdi"": ""umb://element/1304E1DDAC87439684FE8A399231CB3D""
|
||||
}
|
||||
],
|
||||
""Some.Custom.BlockEditor"": [
|
||||
{
|
||||
""contentUdi"": ""umb://element/1304E1DDAC87439684FE8A399231CB3D""
|
||||
}
|
||||
]
|
||||
},
|
||||
""contentData"": [
|
||||
{
|
||||
""contentTypeKey"": """ + ContentKey1 + @""",
|
||||
""udi"": ""umb://element/1304E1DDAC87439684FE8A399231CB3D""
|
||||
}
|
||||
]
|
||||
}";
|
||||
var converted =
|
||||
editor.ConvertIntermediateToObject(publishedElement, propertyType, PropertyCacheLevel.None, json, false) as
|
||||
BlockGridModel;
|
||||
|
||||
Assert.IsNotNull(converted);
|
||||
Assert.AreEqual(1, converted.Count);
|
||||
var item0 = converted[0].Content;
|
||||
Assert.AreEqual(Guid.Parse("1304E1DD-AC87-4396-84FE-8A399231CB3D"), item0.Key);
|
||||
Assert.AreEqual(UdiParser.Parse("umb://element/1304E1DDAC87439684FE8A399231CB3D"), converted[0].ContentUdi);
|
||||
Assert.AreEqual("Test1", item0.ContentType.Alias);
|
||||
Assert.IsNull(converted[0].Settings);
|
||||
}
|
||||
|
||||
private BlockGridPropertyValueConverter CreateConverter()
|
||||
{
|
||||
var publishedSnapshotAccessor = GetPublishedSnapshotAccessor();
|
||||
@@ -42,8 +180,8 @@ public class BlockGridPropertyValueConverterTests : BlockPropertyValueConverterT
|
||||
return editor;
|
||||
}
|
||||
|
||||
private BlockGridConfiguration ConfigForSingle() => new()
|
||||
private BlockGridConfiguration ConfigForSingle(Guid? settingsElementTypeKey = null) => new()
|
||||
{
|
||||
Blocks = new[] { new BlockGridConfiguration.BlockGridBlockConfiguration { ContentElementTypeKey = ContentKey1 } },
|
||||
Blocks = new[] { new BlockGridConfiguration.BlockGridBlockConfiguration { ContentElementTypeKey = ContentKey1, SettingsElementTypeKey = settingsElementTypeKey} },
|
||||
};
|
||||
}
|
||||
|
||||
@@ -0,0 +1,537 @@
|
||||
using NUnit.Framework;
|
||||
using Umbraco.Cms.Core;
|
||||
using Umbraco.Cms.Core.Models.Blocks;
|
||||
using Umbraco.Cms.Infrastructure.Serialization;
|
||||
|
||||
namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Serialization;
|
||||
|
||||
[TestFixture]
|
||||
public class JsonBlockValueConverterTests
|
||||
{
|
||||
[Test]
|
||||
public void Can_Serialize_BlockGrid_With_Blocks()
|
||||
{
|
||||
var contentElementUdi1 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var settingsElementUdi1 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var contentElementUdi2 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var settingsElementUdi2 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var contentElementUdi3 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var settingsElementUdi3 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var contentElementUdi4 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var settingsElementUdi4 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
|
||||
var elementType1Key = Guid.NewGuid();
|
||||
var elementType2Key = Guid.NewGuid();
|
||||
var elementType3Key = Guid.NewGuid();
|
||||
var elementType4Key = Guid.NewGuid();
|
||||
|
||||
var blockGridValue = new BlockGridValue
|
||||
{
|
||||
Layout = new Dictionary<string, IEnumerable<IBlockLayoutItem>>
|
||||
{
|
||||
{
|
||||
Constants.PropertyEditors.Aliases.BlockGrid,
|
||||
new IBlockLayoutItem[]
|
||||
{
|
||||
new BlockGridLayoutItem
|
||||
{
|
||||
ColumnSpan = 123,
|
||||
RowSpan = 456,
|
||||
ContentUdi = contentElementUdi1,
|
||||
SettingsUdi = settingsElementUdi1,
|
||||
Areas = new []
|
||||
{
|
||||
new BlockGridLayoutAreaItem
|
||||
{
|
||||
Key = Guid.NewGuid(),
|
||||
Items = new []
|
||||
{
|
||||
new BlockGridLayoutItem
|
||||
{
|
||||
ColumnSpan = 12,
|
||||
RowSpan = 34,
|
||||
ContentUdi = contentElementUdi3,
|
||||
SettingsUdi = settingsElementUdi3,
|
||||
Areas = new []
|
||||
{
|
||||
new BlockGridLayoutAreaItem
|
||||
{
|
||||
Key = Guid.NewGuid(),
|
||||
Items = new []
|
||||
{
|
||||
new BlockGridLayoutItem
|
||||
{
|
||||
ColumnSpan = 56,
|
||||
RowSpan = 78,
|
||||
ContentUdi = contentElementUdi4,
|
||||
SettingsUdi = settingsElementUdi4
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
new BlockGridLayoutItem
|
||||
{
|
||||
ColumnSpan = 789,
|
||||
RowSpan = 123,
|
||||
ContentUdi = contentElementUdi2,
|
||||
SettingsUdi = settingsElementUdi2
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
ContentData =
|
||||
[
|
||||
new() { Udi = contentElementUdi1, ContentTypeAlias = "elementType1", ContentTypeKey = elementType1Key },
|
||||
new() { Udi = contentElementUdi2, ContentTypeAlias = "elementType2", ContentTypeKey = elementType2Key },
|
||||
new() { Udi = contentElementUdi3, ContentTypeAlias = "elementType3", ContentTypeKey = elementType3Key },
|
||||
new() { Udi = contentElementUdi4, ContentTypeAlias = "elementType¤", ContentTypeKey = elementType4Key },
|
||||
],
|
||||
SettingsData =
|
||||
[
|
||||
new() { Udi = settingsElementUdi1, ContentTypeAlias = "elementType3", ContentTypeKey = elementType3Key },
|
||||
new() { Udi = settingsElementUdi2, ContentTypeAlias = "elementType4", ContentTypeKey = elementType4Key },
|
||||
new() { Udi = settingsElementUdi3, ContentTypeAlias = "elementType1", ContentTypeKey = elementType1Key },
|
||||
new() { Udi = settingsElementUdi4, ContentTypeAlias = "elementType2", ContentTypeKey = elementType2Key }
|
||||
]
|
||||
};
|
||||
|
||||
var serializer = new SystemTextJsonSerializer();
|
||||
var serialized = serializer.Serialize(blockGridValue);
|
||||
var deserialized = serializer.Deserialize<BlockGridValue>(serialized);
|
||||
|
||||
Assert.IsNotNull(deserialized);
|
||||
|
||||
Assert.AreEqual(1, deserialized.Layout.Count);
|
||||
Assert.IsTrue(deserialized.Layout.ContainsKey(Constants.PropertyEditors.Aliases.BlockGrid));
|
||||
var layoutItems = deserialized.Layout[Constants.PropertyEditors.Aliases.BlockGrid].OfType<BlockGridLayoutItem>().ToArray();
|
||||
Assert.AreEqual(2, layoutItems.Count());
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(123, layoutItems[0].ColumnSpan);
|
||||
Assert.AreEqual(456, layoutItems[0].RowSpan);
|
||||
Assert.AreEqual(contentElementUdi1, layoutItems[0].ContentUdi);
|
||||
Assert.AreEqual(settingsElementUdi1, layoutItems[0].SettingsUdi);
|
||||
|
||||
Assert.AreEqual(789, layoutItems[1].ColumnSpan);
|
||||
Assert.AreEqual(123, layoutItems[1].RowSpan);
|
||||
Assert.AreEqual(contentElementUdi2, layoutItems[1].ContentUdi);
|
||||
Assert.AreEqual(settingsElementUdi2, layoutItems[1].SettingsUdi);
|
||||
});
|
||||
|
||||
Assert.AreEqual(1, layoutItems[0].Areas.Length);
|
||||
Assert.AreEqual(1, layoutItems[0].Areas[0].Items.Length);
|
||||
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(12, layoutItems[0].Areas[0].Items[0].ColumnSpan);
|
||||
Assert.AreEqual(34, layoutItems[0].Areas[0].Items[0].RowSpan);
|
||||
Assert.AreEqual(contentElementUdi3, layoutItems[0].Areas[0].Items[0].ContentUdi);
|
||||
Assert.AreEqual(settingsElementUdi3, layoutItems[0].Areas[0].Items[0].SettingsUdi);
|
||||
});
|
||||
|
||||
Assert.AreEqual(1, layoutItems[0].Areas[0].Items[0].Areas.Length);
|
||||
Assert.AreEqual(1, layoutItems[0].Areas[0].Items[0].Areas[0].Items.Length);
|
||||
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(56, layoutItems[0].Areas[0].Items[0].Areas[0].Items[0].ColumnSpan);
|
||||
Assert.AreEqual(78, layoutItems[0].Areas[0].Items[0].Areas[0].Items[0].RowSpan);
|
||||
Assert.AreEqual(contentElementUdi4, layoutItems[0].Areas[0].Items[0].Areas[0].Items[0].ContentUdi);
|
||||
Assert.AreEqual(settingsElementUdi4, layoutItems[0].Areas[0].Items[0].Areas[0].Items[0].SettingsUdi);
|
||||
});
|
||||
|
||||
Assert.AreEqual(4, deserialized.ContentData.Count);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(contentElementUdi1, deserialized.ContentData[0].Udi);
|
||||
Assert.AreEqual(elementType1Key, deserialized.ContentData[0].ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.ContentData[0].ContentTypeAlias); // explicitly annotated to be ignored by the serializer
|
||||
|
||||
Assert.AreEqual(contentElementUdi2, deserialized.ContentData[1].Udi);
|
||||
Assert.AreEqual(elementType2Key, deserialized.ContentData[1].ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.ContentData[1].ContentTypeAlias);
|
||||
|
||||
Assert.AreEqual(contentElementUdi3, deserialized.ContentData[2].Udi);
|
||||
Assert.AreEqual(elementType3Key, deserialized.ContentData[2].ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.ContentData[2].ContentTypeAlias);
|
||||
|
||||
Assert.AreEqual(contentElementUdi3, deserialized.ContentData[2].Udi);
|
||||
Assert.AreEqual(elementType3Key, deserialized.ContentData[2].ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.ContentData[2].ContentTypeAlias);
|
||||
});
|
||||
|
||||
Assert.AreEqual(4, deserialized.SettingsData.Count);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(settingsElementUdi1, deserialized.SettingsData[0].Udi);
|
||||
Assert.AreEqual(elementType3Key, deserialized.SettingsData[0].ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.SettingsData[0].ContentTypeAlias);
|
||||
|
||||
Assert.AreEqual(settingsElementUdi2, deserialized.SettingsData[1].Udi);
|
||||
Assert.AreEqual(elementType4Key, deserialized.SettingsData[1].ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.SettingsData[1].ContentTypeAlias);
|
||||
|
||||
Assert.AreEqual(settingsElementUdi3, deserialized.SettingsData[2].Udi);
|
||||
Assert.AreEqual(elementType1Key, deserialized.SettingsData[2].ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.SettingsData[2].ContentTypeAlias);
|
||||
|
||||
Assert.AreEqual(settingsElementUdi4, deserialized.SettingsData[3].Udi);
|
||||
Assert.AreEqual(elementType2Key, deserialized.SettingsData[3].ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.SettingsData[3].ContentTypeAlias);
|
||||
});
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void Can_Serialize_BlockGrid_Without_Blocks()
|
||||
{
|
||||
var blockGridValue = new BlockGridValue
|
||||
{
|
||||
Layout = new Dictionary<string, IEnumerable<IBlockLayoutItem>>(),
|
||||
ContentData = [],
|
||||
SettingsData = []
|
||||
};
|
||||
|
||||
var serializer = new SystemTextJsonSerializer();
|
||||
var serialized = serializer.Serialize(blockGridValue);
|
||||
var deserialized = serializer.Deserialize<BlockGridValue>(serialized);
|
||||
|
||||
Assert.IsNotNull(deserialized);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.IsEmpty(deserialized.Layout);
|
||||
Assert.IsEmpty(deserialized.ContentData);
|
||||
Assert.IsEmpty(deserialized.SettingsData);
|
||||
});
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void Can_Serialize_BlockList_With_Blocks()
|
||||
{
|
||||
var contentElementUdi1 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var settingsElementUdi1 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var contentElementUdi2 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var settingsElementUdi2 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
|
||||
var elementType1Key = Guid.NewGuid();
|
||||
var elementType2Key = Guid.NewGuid();
|
||||
var elementType3Key = Guid.NewGuid();
|
||||
var elementType4Key = Guid.NewGuid();
|
||||
|
||||
var blockListValue = new BlockListValue
|
||||
{
|
||||
Layout = new Dictionary<string, IEnumerable<IBlockLayoutItem>>
|
||||
{
|
||||
{
|
||||
Constants.PropertyEditors.Aliases.BlockList,
|
||||
new IBlockLayoutItem[]
|
||||
{
|
||||
new BlockListLayoutItem()
|
||||
{
|
||||
ContentUdi = contentElementUdi1,
|
||||
SettingsUdi = settingsElementUdi1
|
||||
},
|
||||
new BlockListLayoutItem
|
||||
{
|
||||
ContentUdi = contentElementUdi2,
|
||||
SettingsUdi = settingsElementUdi2
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
ContentData =
|
||||
[
|
||||
new() { Udi = contentElementUdi1, ContentTypeAlias = "elementType1", ContentTypeKey = elementType1Key },
|
||||
new() { Udi = contentElementUdi2, ContentTypeAlias = "elementType2", ContentTypeKey = elementType2Key }
|
||||
],
|
||||
SettingsData =
|
||||
[
|
||||
new() { Udi = settingsElementUdi1, ContentTypeAlias = "elementType3", ContentTypeKey = elementType3Key },
|
||||
new() { Udi = settingsElementUdi2, ContentTypeAlias = "elementType4", ContentTypeKey = elementType4Key }
|
||||
]
|
||||
};
|
||||
|
||||
var serializer = new SystemTextJsonSerializer();
|
||||
var serialized = serializer.Serialize(blockListValue);
|
||||
var deserialized = serializer.Deserialize<BlockListValue>(serialized);
|
||||
|
||||
Assert.IsNotNull(deserialized);
|
||||
|
||||
Assert.AreEqual(1, deserialized.Layout.Count);
|
||||
Assert.IsTrue(deserialized.Layout.ContainsKey(Constants.PropertyEditors.Aliases.BlockList));
|
||||
var layoutItems = deserialized.Layout[Constants.PropertyEditors.Aliases.BlockList].OfType<BlockListLayoutItem>().ToArray();
|
||||
Assert.AreEqual(2, layoutItems.Count());
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(contentElementUdi1, layoutItems.First().ContentUdi);
|
||||
Assert.AreEqual(settingsElementUdi1, layoutItems.First().SettingsUdi);
|
||||
|
||||
Assert.AreEqual(contentElementUdi2, layoutItems.Last().ContentUdi);
|
||||
Assert.AreEqual(settingsElementUdi2, layoutItems.Last().SettingsUdi);
|
||||
});
|
||||
|
||||
Assert.AreEqual(2, deserialized.ContentData.Count);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(contentElementUdi1, deserialized.ContentData.First().Udi);
|
||||
Assert.AreEqual(elementType1Key, deserialized.ContentData.First().ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.ContentData.First().ContentTypeAlias); // explicitly annotated to be ignored by the serializer
|
||||
|
||||
Assert.AreEqual(contentElementUdi2, deserialized.ContentData.Last().Udi);
|
||||
Assert.AreEqual(elementType2Key, deserialized.ContentData.Last().ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.ContentData.Last().ContentTypeAlias);
|
||||
});
|
||||
|
||||
Assert.AreEqual(2, deserialized.SettingsData.Count);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(settingsElementUdi1, deserialized.SettingsData.First().Udi);
|
||||
Assert.AreEqual(elementType3Key, deserialized.SettingsData.First().ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.SettingsData.First().ContentTypeAlias);
|
||||
|
||||
Assert.AreEqual(settingsElementUdi2, deserialized.SettingsData.Last().Udi);
|
||||
Assert.AreEqual(elementType4Key, deserialized.SettingsData.Last().ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserialized.SettingsData.Last().ContentTypeAlias);
|
||||
});
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void Can_Serialize_BlockList_Without_Blocks()
|
||||
{
|
||||
var blockListValue = new BlockListValue
|
||||
{
|
||||
Layout = new Dictionary<string, IEnumerable<IBlockLayoutItem>>(),
|
||||
ContentData = [],
|
||||
SettingsData = []
|
||||
};
|
||||
|
||||
var serializer = new SystemTextJsonSerializer();
|
||||
var serialized = serializer.Serialize(blockListValue);
|
||||
var deserialized = serializer.Deserialize<BlockListValue>(serialized);
|
||||
|
||||
Assert.IsNotNull(deserialized);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.IsEmpty(deserialized.Layout);
|
||||
Assert.IsEmpty(deserialized.ContentData);
|
||||
Assert.IsEmpty(deserialized.SettingsData);
|
||||
});
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void Can_Serialize_Richtext_With_Blocks()
|
||||
{
|
||||
var contentElementUdi1 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var settingsElementUdi1 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var contentElementUdi2 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var settingsElementUdi2 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
|
||||
var elementType1Key = Guid.NewGuid();
|
||||
var elementType2Key = Guid.NewGuid();
|
||||
var elementType3Key = Guid.NewGuid();
|
||||
var elementType4Key = Guid.NewGuid();
|
||||
|
||||
var richTextBlockValue = new RichTextBlockValue
|
||||
{
|
||||
Layout = new Dictionary<string, IEnumerable<IBlockLayoutItem>>
|
||||
{
|
||||
{
|
||||
Constants.PropertyEditors.Aliases.TinyMce,
|
||||
new IBlockLayoutItem[]
|
||||
{
|
||||
new RichTextBlockLayoutItem
|
||||
{
|
||||
ContentUdi = contentElementUdi1,
|
||||
SettingsUdi = settingsElementUdi1
|
||||
},
|
||||
new RichTextBlockLayoutItem
|
||||
{
|
||||
ContentUdi = contentElementUdi2,
|
||||
SettingsUdi = settingsElementUdi2
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
ContentData =
|
||||
[
|
||||
new() { Udi = contentElementUdi1, ContentTypeAlias = "elementType1", ContentTypeKey = elementType1Key },
|
||||
new() { Udi = contentElementUdi2, ContentTypeAlias = "elementType2", ContentTypeKey = elementType2Key }
|
||||
],
|
||||
SettingsData =
|
||||
[
|
||||
new() { Udi = settingsElementUdi1, ContentTypeAlias = "elementType3", ContentTypeKey = elementType3Key },
|
||||
new() { Udi = settingsElementUdi2, ContentTypeAlias = "elementType4", ContentTypeKey = elementType4Key }
|
||||
]
|
||||
};
|
||||
|
||||
var richTextEditorValue = new RichTextEditorValue
|
||||
{
|
||||
Blocks = richTextBlockValue,
|
||||
Markup = "<p>This is some markup</p>"
|
||||
};
|
||||
|
||||
var serializer = new SystemTextJsonSerializer();
|
||||
var serialized = serializer.Serialize(richTextEditorValue);
|
||||
var deserialized = serializer.Deserialize<RichTextEditorValue>(serialized);
|
||||
|
||||
Assert.IsNotNull(deserialized);
|
||||
Assert.AreEqual("<p>This is some markup</p>", deserialized.Markup);
|
||||
|
||||
var deserializedBlocks = deserialized.Blocks;
|
||||
Assert.IsNotNull(deserializedBlocks);
|
||||
Assert.AreEqual(1, deserializedBlocks.Layout.Count);
|
||||
Assert.IsTrue(deserializedBlocks.Layout.ContainsKey(Constants.PropertyEditors.Aliases.TinyMce));
|
||||
var layoutItems = deserializedBlocks.Layout[Constants.PropertyEditors.Aliases.TinyMce].OfType<RichTextBlockLayoutItem>().ToArray();
|
||||
Assert.AreEqual(2, layoutItems.Count());
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(contentElementUdi1, layoutItems.First().ContentUdi);
|
||||
Assert.AreEqual(settingsElementUdi1, layoutItems.First().SettingsUdi);
|
||||
|
||||
Assert.AreEqual(contentElementUdi2, layoutItems.Last().ContentUdi);
|
||||
Assert.AreEqual(settingsElementUdi2, layoutItems.Last().SettingsUdi);
|
||||
});
|
||||
|
||||
Assert.AreEqual(2, deserializedBlocks.ContentData.Count);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(contentElementUdi1, deserializedBlocks.ContentData.First().Udi);
|
||||
Assert.AreEqual(elementType1Key, deserializedBlocks.ContentData.First().ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserializedBlocks.ContentData.First().ContentTypeAlias); // explicitly annotated to be ignored by the serializer
|
||||
|
||||
Assert.AreEqual(contentElementUdi2, deserializedBlocks.ContentData.Last().Udi);
|
||||
Assert.AreEqual(elementType2Key, deserializedBlocks.ContentData.Last().ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserializedBlocks.ContentData.Last().ContentTypeAlias);
|
||||
});
|
||||
|
||||
Assert.AreEqual(2, deserializedBlocks.SettingsData.Count);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(settingsElementUdi1, deserializedBlocks.SettingsData.First().Udi);
|
||||
Assert.AreEqual(elementType3Key, deserializedBlocks.SettingsData.First().ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserializedBlocks.SettingsData.First().ContentTypeAlias);
|
||||
|
||||
Assert.AreEqual(settingsElementUdi2, deserializedBlocks.SettingsData.Last().Udi);
|
||||
Assert.AreEqual(elementType4Key, deserializedBlocks.SettingsData.Last().ContentTypeKey);
|
||||
Assert.AreEqual(string.Empty, deserializedBlocks.SettingsData.Last().ContentTypeAlias);
|
||||
});
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void Can_Serialize_Richtext_Without_Blocks()
|
||||
{
|
||||
var richTextEditorValue = new RichTextEditorValue
|
||||
{
|
||||
Blocks = new RichTextBlockValue
|
||||
{
|
||||
Layout = new Dictionary<string, IEnumerable<IBlockLayoutItem>>(),
|
||||
ContentData = new List<BlockItemData>(),
|
||||
SettingsData = new List<BlockItemData>()
|
||||
},
|
||||
Markup = "<p>This is some markup</p>"
|
||||
};
|
||||
|
||||
var serializer = new SystemTextJsonSerializer();
|
||||
var serialized = serializer.Serialize(richTextEditorValue);
|
||||
var deserialized = serializer.Deserialize<RichTextEditorValue>(serialized);
|
||||
|
||||
Assert.IsNotNull(deserialized);
|
||||
Assert.AreEqual("<p>This is some markup</p>", deserialized.Markup);
|
||||
Assert.IsNotNull(deserialized.Blocks);
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.IsEmpty(deserialized.Blocks.Layout);
|
||||
Assert.IsEmpty(deserialized.Blocks.ContentData);
|
||||
Assert.IsEmpty(deserialized.Blocks.SettingsData);
|
||||
});
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void Ignores_Other_Layouts()
|
||||
{
|
||||
var contentElementUdi1 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
var settingsElementUdi1 = Udi.Create(Constants.UdiEntityType.Element, Guid.NewGuid());
|
||||
|
||||
var elementType1Key = Guid.NewGuid();
|
||||
var elementType2Key = Guid.NewGuid();
|
||||
|
||||
var blockListValue = new BlockListValue
|
||||
{
|
||||
Layout = new Dictionary<string, IEnumerable<IBlockLayoutItem>>
|
||||
{
|
||||
{
|
||||
Constants.PropertyEditors.Aliases.TinyMce,
|
||||
new IBlockLayoutItem[]
|
||||
{
|
||||
new RichTextBlockLayoutItem
|
||||
{
|
||||
ContentUdi = contentElementUdi1,
|
||||
SettingsUdi = settingsElementUdi1
|
||||
}
|
||||
}
|
||||
},
|
||||
{
|
||||
Constants.PropertyEditors.Aliases.BlockList,
|
||||
new IBlockLayoutItem[]
|
||||
{
|
||||
new BlockListLayoutItem
|
||||
{
|
||||
ContentUdi = contentElementUdi1,
|
||||
SettingsUdi = settingsElementUdi1
|
||||
}
|
||||
}
|
||||
},
|
||||
{
|
||||
Constants.PropertyEditors.Aliases.BlockGrid,
|
||||
new IBlockLayoutItem[]
|
||||
{
|
||||
new BlockGridLayoutItem
|
||||
{
|
||||
ContentUdi = contentElementUdi1,
|
||||
SettingsUdi = settingsElementUdi1
|
||||
}
|
||||
}
|
||||
},
|
||||
{
|
||||
"Some.Custom.Block.Editor",
|
||||
new IBlockLayoutItem[]
|
||||
{
|
||||
new BlockListLayoutItem
|
||||
{
|
||||
ContentUdi = contentElementUdi1,
|
||||
SettingsUdi = settingsElementUdi1
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
ContentData =
|
||||
[
|
||||
new() { Udi = contentElementUdi1, ContentTypeAlias = "elementType1", ContentTypeKey = elementType1Key },
|
||||
],
|
||||
SettingsData =
|
||||
[
|
||||
new() { Udi = settingsElementUdi1, ContentTypeAlias = "elementType2", ContentTypeKey = elementType2Key },
|
||||
]
|
||||
};
|
||||
|
||||
var serializer = new SystemTextJsonSerializer();
|
||||
var serialized = serializer.Serialize(blockListValue);
|
||||
var deserialized = serializer.Deserialize<BlockListValue>(serialized);
|
||||
|
||||
Assert.IsNotNull(deserialized);
|
||||
|
||||
Assert.AreEqual(1, deserialized.Layout.Count);
|
||||
Assert.IsTrue(deserialized.Layout.ContainsKey(Constants.PropertyEditors.Aliases.BlockList));
|
||||
var layoutItems = deserialized.Layout[Constants.PropertyEditors.Aliases.BlockList].OfType<BlockListLayoutItem>().ToArray();
|
||||
Assert.AreEqual(1, layoutItems.Count());
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.AreEqual(contentElementUdi1, layoutItems.First().ContentUdi);
|
||||
Assert.AreEqual(settingsElementUdi1, layoutItems.First().SettingsUdi);
|
||||
});
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user