Nuke gridtilelookup (#6030)
This commit is contained in:
@@ -1,70 +0,0 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Threading.Tasks;
|
||||
using NUnit.Framework;
|
||||
using Robust.Server.GameObjects;
|
||||
using Robust.Shared.GameObjects;
|
||||
using Robust.Shared.Map;
|
||||
using Robust.Shared.Maths;
|
||||
|
||||
namespace Content.IntegrationTests.Tests
|
||||
{
|
||||
[TestFixture]
|
||||
public class GridTileLookupTest : ContentIntegrationTest
|
||||
{
|
||||
private const string Prototypes = @"
|
||||
- type: entity
|
||||
name: Dummy
|
||||
id: Dummy
|
||||
";
|
||||
|
||||
[Test]
|
||||
public async Task Test()
|
||||
{
|
||||
var options = new ServerIntegrationOptions{ExtraPrototypes = Prototypes};
|
||||
var server = StartServer(options);
|
||||
await server.WaitIdleAsync();
|
||||
|
||||
var entityManager = server.ResolveDependency<IEntityManager>();
|
||||
var tileLookup = server.ResolveDependency<IEntitySystemManager>().GetEntitySystem<GridTileLookupSystem>();
|
||||
var mapManager = server.ResolveDependency<IMapManager>();
|
||||
var tileDefinitionManager = server.ResolveDependency<ITileDefinitionManager>();
|
||||
|
||||
server.Assert(() =>
|
||||
{
|
||||
List<EntityUid> entities;
|
||||
var mapOne = mapManager.CreateMap();
|
||||
var gridOne = mapManager.CreateGrid(mapOne);
|
||||
|
||||
var tileDefinition = tileDefinitionManager["underplating"];
|
||||
var underplating = new Tile(tileDefinition.TileId);
|
||||
gridOne.SetTile(new Vector2i(0, 0), underplating);
|
||||
gridOne.SetTile(new Vector2i(-1, -1), underplating);
|
||||
|
||||
entities = tileLookup.GetEntitiesIntersecting(gridOne.Index, new Vector2i(0, 0)).ToList();
|
||||
Assert.That(entities.Count, Is.EqualTo(0));
|
||||
|
||||
// Space entity, check that nothing intersects it and that also it doesn't throw.
|
||||
entityManager.SpawnEntity("Dummy", new MapCoordinates(Vector2.One * 1000, mapOne));
|
||||
entities = tileLookup.GetEntitiesIntersecting(gridOne.Index, new Vector2i(1000, 1000)).ToList();
|
||||
Assert.That(entities.Count, Is.EqualTo(0));
|
||||
|
||||
var entityOne = entityManager.SpawnEntity("Dummy", new EntityCoordinates(gridOne.GridEntityId, Vector2.Zero));
|
||||
entityManager.SpawnEntity("Dummy", new EntityCoordinates(gridOne.GridEntityId, Vector2.One));
|
||||
|
||||
var entityTiles = tileLookup.GetIndices(entityOne);
|
||||
Assert.That(entityTiles.Count, Is.EqualTo(1));
|
||||
|
||||
entities = tileLookup.GetEntitiesIntersecting(entityOne).ToList();
|
||||
Assert.That(entities.Count, Is.EqualTo(1));
|
||||
|
||||
entityManager.SpawnEntity("Dummy", new EntityCoordinates(gridOne.GridEntityId, Vector2.Zero));
|
||||
|
||||
entities = tileLookup.GetEntitiesIntersecting(gridOne.Index, new Vector2i(0, 0)).ToList();
|
||||
Assert.That(entities.Count, Is.EqualTo(2));
|
||||
});
|
||||
|
||||
await server.WaitIdleAsync();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user