add test to ensure the json converter do not mess with the extensions list

This commit is contained in:
Jacob Overgaard
2024-02-22 10:47:04 +01:00
parent 1a8797e694
commit 9c7949d46f

View File

@@ -47,8 +47,7 @@ public class PackageManifestReaderTests
var first = result.First();
Assert.AreEqual("My Package", first.Name);
Assert.AreEqual("1.2.3", first.Version);
Assert.AreEqual(2, first.Extensions.Count());
Assert.IsTrue(first.Extensions.All(e => e is JsonElement));
Assert.AreEqual(2, first.Extensions.Length);
Assert.NotNull(first.Importmap);
var importmap = first.Importmap;
@@ -66,6 +65,45 @@ public class PackageManifestReaderTests
Assert.AreEqual("https://example.com/modules/shapes/square.js", firstScope.Value);
}
[Test]
public async Task Can_Deserialize_Extensions()
{
const string content = @"{
""name"": ""My Package"",
""version"": ""1.2.3"",
""allowTelemetry"": true,
""extensions"": [{
""type"": ""tree"",
""meta"": {
""label"": ""My Tree"",
""someArray"": [1, 2, 3]
}
}, {
""type"": ""headerApp""
}
]
}";
_rootDirectoryContentsMock
.Setup(f => f.GetEnumerator())
.Returns(new List<IFileInfo> { CreatePackageManifestFile(content) }.GetEnumerator());
var result = await _reader.ReadPackageManifestsAsync();
Assert.AreEqual(1, result.Count());
var first = result.First();
// Ensure that the extensions are deserialized as JsonElement
Assert.IsTrue(first.Extensions.All(e => e is JsonElement));
// Test the deserialization of the first extension to make sure we don't break the JSON parsing
JsonElement firstExtension = (JsonElement)first.Extensions.First();
Assert.AreEqual("tree", firstExtension.GetProperty("type").GetString());
var meta = firstExtension.GetProperty("meta");
Assert.AreEqual("My Tree", meta.GetProperty("label").GetString());
var someArray = meta.GetProperty("someArray");
Assert.AreEqual(1, someArray[0].GetInt32());
}
[Test]
public async Task Can_Read_PackageManifest_In_Root_Directories()
{