summaryrefslogtreecommitdiff
path: root/Plugins/MonoGame.Extended/tests/MonoGame.Extended.Content.Pipeline.Tests.Tiled/TiledMapImporterProcessorTests.cs
diff options
context:
space:
mode:
authorchai <215380520@qq.com>2024-06-03 10:15:45 +0800
committerchai <215380520@qq.com>2024-06-03 10:15:45 +0800
commitacea7b2e728787a0d83bbf83c8c1f042d2c32e7e (patch)
tree0bfec05c1ca2d71be2c337bcd110a0421f19318b /Plugins/MonoGame.Extended/tests/MonoGame.Extended.Content.Pipeline.Tests.Tiled/TiledMapImporterProcessorTests.cs
parent88febcb02bf127d961c6471d9e846c0e1315f5c3 (diff)
+ plugins project
Diffstat (limited to 'Plugins/MonoGame.Extended/tests/MonoGame.Extended.Content.Pipeline.Tests.Tiled/TiledMapImporterProcessorTests.cs')
-rw-r--r--Plugins/MonoGame.Extended/tests/MonoGame.Extended.Content.Pipeline.Tests.Tiled/TiledMapImporterProcessorTests.cs205
1 files changed, 205 insertions, 0 deletions
diff --git a/Plugins/MonoGame.Extended/tests/MonoGame.Extended.Content.Pipeline.Tests.Tiled/TiledMapImporterProcessorTests.cs b/Plugins/MonoGame.Extended/tests/MonoGame.Extended.Content.Pipeline.Tests.Tiled/TiledMapImporterProcessorTests.cs
new file mode 100644
index 0000000..352457a
--- /dev/null
+++ b/Plugins/MonoGame.Extended/tests/MonoGame.Extended.Content.Pipeline.Tests.Tiled/TiledMapImporterProcessorTests.cs
@@ -0,0 +1,205 @@
+using System.IO;
+using System.Linq;
+using Microsoft.Xna.Framework.Content.Pipeline;
+using MonoGame.Extended.Content.Pipeline.Tiled;
+using MonoGame.Extended.Tiled.Serialization;
+using NSubstitute;
+using Xunit;
+
+namespace MonoGame.Extended.Content.Pipeline.Tests.Tiled
+{
+
+ public class TiledMapImporterProcessorTests
+ {
+ [Fact]
+ public void TiledMapImporter_Import_Test()
+ {
+ var filePath = PathExtensions.GetApplicationFullPath("TestData", "level01.tmx");
+
+ var logger = Substitute.For<ContentBuildLogger>();
+ var importer = new TiledMapImporter();
+ var importerContext = Substitute.For<ContentImporterContext>();
+ importerContext.Logger.Returns(logger);
+
+ var contentItem = importer.Import(filePath, importerContext);
+ var map = contentItem.Data;
+
+ Assert.Equal("1.0", map.Version);
+ Assert.Equal(TiledMapOrientationContent.Orthogonal, map.Orientation);
+ Assert.Equal(TiledMapTileDrawOrderContent.RightDown, map.RenderOrder);
+ Assert.Equal(20, map.Width);
+ Assert.Equal(10, map.Height);
+ Assert.Equal(128, map.TileWidth);
+ Assert.Equal(128, map.TileHeight);
+ Assert.Equal("#7d7d7d", map.BackgroundColor);
+ Assert.Equal("awesome", map.Properties[0].Name);
+ Assert.Equal("42", map.Properties[0].Value);
+ Assert.Single(map.Tilesets);
+ Assert.Equal(3, map.Layers.Count);
+ Assert.Equal(TiledMapOrientationContent.Orthogonal, map.Orientation);
+
+ var tileset = map.Tilesets.First();
+ Assert.Equal(1, tileset.FirstGlobalIdentifier);
+ Assert.Equal("free-tileset.png", Path.GetFileName(tileset.Image.Source));
+ Assert.Equal(652, tileset.Image.Width);
+ Assert.Equal(783, tileset.Image.Height);
+ Assert.Equal(2, tileset.Margin);
+ Assert.Equal(30, tileset.TileCount);
+ Assert.Equal("free-tileset", tileset.Name);
+ Assert.Null(tileset.Source);
+ Assert.Equal(2, tileset.Spacing);
+ //Assert.Equal(0, tileset.TerrainTypes.Count);
+ Assert.Empty(tileset.Properties);
+ Assert.Equal(128, tileset.TileHeight);
+ Assert.Equal(128, tileset.TileWidth);
+ Assert.Equal(0, tileset.TileOffset.X);
+ Assert.Equal(0, tileset.TileOffset.Y);
+
+ var tileLayer2 = (TiledMapTileLayerContent)map.Layers[0];
+ Assert.Equal("Tile Layer 2", tileLayer2.Name);
+ Assert.Equal(1, tileLayer2.Opacity);
+ Assert.Empty(tileLayer2.Properties);
+ Assert.True(tileLayer2.Visible);
+ Assert.Equal(200, tileLayer2.Data.Tiles.Count);
+ Assert.Equal(0, tileLayer2.X);
+ Assert.Equal(0, tileLayer2.Y);
+
+ var imageLayer = (TiledMapImageLayerContent)map.Layers[1];
+ Assert.Equal("Image Layer 1", imageLayer.Name);
+ Assert.Equal(1, imageLayer.Opacity);
+ Assert.Empty(imageLayer.Properties);
+ Assert.True(imageLayer.Visible);
+ Assert.Equal("hills.png", Path.GetFileName(imageLayer.Image.Source));
+ Assert.Equal(100, imageLayer.X);
+ Assert.Equal(100, imageLayer.Y);
+
+ var tileLayer1 = (TiledMapTileLayerContent)map.Layers[2];
+ Assert.Equal("Tile Layer 1", tileLayer1.Name);
+ Assert.Equal(2, tileLayer1.Properties.Count);
+
+ Assert.Equal("customlayerprop", tileLayer1.Properties[0].Name);
+ Assert.Equal("1", tileLayer1.Properties[0].Value);
+
+ Assert.Equal("customlayerprop2", tileLayer1.Properties[1].Name);
+ Assert.Equal("2", tileLayer1.Properties[1].Value);
+ }
+
+ [Fact]
+ public void TiledMapImporter_Xml_Test()
+ {
+ var filePath = PathExtensions.GetApplicationFullPath("TestData", "test-tileset-xml.tmx");
+ var map = ImportAndProcessMap(filePath);
+ var layer = map.Layers.OfType<TiledMapTileLayerContent>().First();
+ var actualData = layer.Data.Tiles.Select(i => i.GlobalIdentifier).ToArray();
+
+ Assert.Null(layer.Data.Encoding);
+ Assert.Null(layer.Data.Compression);
+ Assert.True(new uint[] { 1, 2, 3, 4, 5, 6, 7, 8, 9 }.SequenceEqual(actualData));
+ }
+
+ [Fact]
+ public void TiledMapImporter_Csv_Test()
+ {
+ var filePath = PathExtensions.GetApplicationFullPath("TestData", "test-tileset-csv.tmx");
+ var map = ImportAndProcessMap(filePath);
+ var layer = map.Layers.OfType<TiledMapTileLayerContent>().First();
+ var data = layer.Data.Tiles.Select(i => i.GlobalIdentifier).ToArray();
+
+ Assert.Equal("csv", layer.Data.Encoding);
+ Assert.Null(layer.Data.Compression);
+ //Assert.True(new uint[] { 1, 2, 3, 4, 5, 6, 7, 8, 9 }.SequenceEqual(data));
+ }
+
+ [Fact]
+ public void TiledMapImporter_Base64_Test()
+ {
+ var filePath = PathExtensions.GetApplicationFullPath("TestData", "test-tileset-base64.tmx");
+ var map = ImportAndProcessMap(filePath);
+ var layer = map.Layers.OfType<TiledMapTileLayerContent>().First();
+ var data = layer.Data.Tiles.Select(i => i.GlobalIdentifier).ToArray();
+
+ Assert.Equal("base64", layer.Data.Encoding);
+ Assert.Null(layer.Data.Compression);
+ //Assert.True(new uint[] { 1, 2, 3, 4, 5, 6, 7, 8, 9 }.SequenceEqual(data));
+ }
+
+ [Fact]
+ public void TiledMapImporter_Gzip_Test()
+ {
+ var filePath = PathExtensions.GetApplicationFullPath("TestData", "test-tileset-gzip.tmx");
+ var map = ImportAndProcessMap(filePath);
+ var layer = map.Layers.OfType<TiledMapTileLayerContent>().First();
+ var data = layer.Data.Tiles.Select(i => i.GlobalIdentifier).ToArray();
+
+ Assert.Equal("base64", layer.Data.Encoding);
+ Assert.Equal("gzip", layer.Data.Compression);
+ //Assert.True(new uint[] { 1, 2, 3, 4, 5, 6, 7, 8, 9 }.SequenceEqual(data));
+ }
+
+
+ [Fact]
+ public void TiledMapImporter_Zlib_Test()
+ {
+ var filePath = PathExtensions.GetApplicationFullPath("TestData", "test-tileset-zlib.tmx");
+ var map = ImportAndProcessMap(filePath);
+ var layer = map.Layers.OfType<TiledMapTileLayerContent>().First();
+ var data = layer.Data.Tiles.Select(i => i.GlobalIdentifier).ToArray();
+
+ Assert.Equal("base64", layer.Data.Encoding);
+ Assert.Equal("zlib", layer.Data.Compression);
+ //Assert.True(new uint[] { 1, 2, 3, 4, 5, 6, 7, 8, 9 }.SequenceEqual(data));
+ }
+
+ [Fact]
+ public void TiledMapImporter_ObjectLayer_Test()
+ {
+ var filePath = PathExtensions.GetApplicationFullPath("TestData", "test-object-layer.tmx");
+ var map = ImportAndProcessMap(filePath);
+
+ Assert.Single(map.Layers);
+ Assert.IsType<TiledMapObjectLayerContent>(map.Layers[0]);
+ var tmxObjectGroup = map.Layers[0] as TiledMapObjectLayerContent;
+ var tmxObject = tmxObjectGroup.Objects[0];
+ var tmxPolygon = tmxObjectGroup.Objects[3].Polygon;
+ var tmxPolyline = tmxObjectGroup.Objects[4].Polyline;
+
+ Assert.Equal("Object Layer 1", tmxObjectGroup.Name);
+ Assert.Equal(1, tmxObject.Identifier);
+ Assert.Equal(131.345f, tmxObject.X);
+ Assert.Equal(65.234f, tmxObject.Y);
+ Assert.Equal(311.111f, tmxObject.Width);
+ Assert.Equal(311.232f, tmxObject.Height);
+ Assert.Single(tmxObject.Properties);
+ Assert.Equal("shape", tmxObject.Properties[0].Name);
+ Assert.Equal("circle", tmxObject.Properties[0].Value);
+ Assert.NotNull(tmxObject.Ellipse);
+ Assert.False(tmxObjectGroup.Objects[1].Visible);
+ Assert.Equal((uint)0, tmxObjectGroup.Objects[1].GlobalIdentifier);
+ Assert.Equal((uint)23, tmxObjectGroup.Objects[5].GlobalIdentifier);
+ Assert.Equal("rectangle", tmxObjectGroup.Objects[2].Type);
+ Assert.Equal("sprite", tmxObjectGroup.Objects[1].Class);
+ Assert.NotNull(tmxPolygon);
+ Assert.Equal("0,0 180,90 -8,275 -45,81 38,77", tmxPolygon.Points);
+ Assert.NotNull(tmxPolyline);
+ Assert.Equal("0,0 28,299 326,413 461,308", tmxPolyline.Points);
+ }
+
+
+ private static TiledMapContent ImportAndProcessMap(string filename)
+ {
+ var logger = Substitute.For<ContentBuildLogger>();
+ var importer = new TiledMapImporter();
+ var importerContext = Substitute.For<ContentImporterContext>();
+ importerContext.Logger.Returns(logger);
+
+ var processor = new TiledMapProcessor();
+ var processorContext = Substitute.For<ContentProcessorContext>();
+ processorContext.Logger.Returns(logger);
+
+ var import = importer.Import(filename, importerContext);
+ var result = processor.Process(import, processorContext);
+
+ return result.Data;
+ }
+ }
+}