Add block transform test that tests against older rotation code.

Also fixes the rotations for some blocks.
This commit is contained in:
sk89q 2014-07-18 01:01:47 -07:00
parent 9c205e0e00
commit 8508055ddc
3 changed files with 130 additions and 6 deletions

View File

@ -106,7 +106,7 @@ public class BlockTransformExtent extends AbstractDelegateExtent {
* @param registry the registry * @param registry the registry
* @return the same block * @return the same block
*/ */
private static BaseBlock transform(BaseBlock block, Transform transform, BlockRegistry registry) { public static BaseBlock transform(BaseBlock block, Transform transform, BlockRegistry registry) {
return transform(block, transform, registry, block); return transform(block, transform, registry, block);
} }

View File

@ -919,7 +919,7 @@
"facing": { "facing": {
"values": { "values": {
"north": { "data": 0, "direction": [0, 0, -1] }, "north": { "data": 0, "direction": [0, 0, -1] },
"south": { "data": 1, "direction": [0, 0, 1] }, "south": { "data": 0, "direction": [0, 0, 1] },
"east": { "data": 1, "direction": [1, 0, 0] }, "east": { "data": 1, "direction": [1, 0, 0] },
"west": { "data": 1, "direction": [-1, 0, 0] }, "west": { "data": 1, "direction": [-1, 0, 0] },
"east_ascending": { "data": 2, "direction": [1, 1, 0] }, "east_ascending": { "data": 2, "direction": [1, 1, 0] },
@ -929,6 +929,7 @@
"north_ascending": { "data": 4, "direction": [0, 1, -1] }, "north_ascending": { "data": 4, "direction": [0, 1, -1] },
"north_descending": { "data": 4, "direction": [0, -1, 1] }, "north_descending": { "data": 4, "direction": [0, -1, 1] },
"south_ascending": { "data": 5, "direction": [0, 1, 1] }, "south_ascending": { "data": 5, "direction": [0, 1, 1] },
"south_descending": { "data": 5, "direction": [0, -1, -1] },
"southeast": { "data": 6, "direction": [1, 0, 1] }, "southeast": { "data": 6, "direction": [1, 0, 1] },
"southwest": { "data": 7, "direction": [-1, 0, 1] }, "southwest": { "data": 7, "direction": [-1, 0, 1] },
"northwest": { "data": 8, "direction": [-1, 0, -1] }, "northwest": { "data": 8, "direction": [-1, 0, -1] },
@ -969,7 +970,7 @@
"facing": { "facing": {
"values": { "values": {
"north": { "data": 0, "direction": [0, 0, -1] }, "north": { "data": 0, "direction": [0, 0, -1] },
"south": { "data": 1, "direction": [0, 0, 1] }, "south": { "data": 0, "direction": [0, 0, 1] },
"east": { "data": 1, "direction": [1, 0, 0] }, "east": { "data": 1, "direction": [1, 0, 0] },
"west": { "data": 1, "direction": [-1, 0, 0] }, "west": { "data": 1, "direction": [-1, 0, 0] },
"east_ascending": { "data": 2, "direction": [1, 1, 0] }, "east_ascending": { "data": 2, "direction": [1, 1, 0] },
@ -979,6 +980,7 @@
"north_ascending": { "data": 4, "direction": [0, 1, -1] }, "north_ascending": { "data": 4, "direction": [0, 1, -1] },
"north_descending": { "data": 4, "direction": [0, -1, 1] }, "north_descending": { "data": 4, "direction": [0, -1, 1] },
"south_ascending": { "data": 5, "direction": [0, 1, 1] }, "south_ascending": { "data": 5, "direction": [0, 1, 1] },
"south_descending": { "data": 5, "direction": [0, -1, -1] },
"southeast": { "data": 6, "direction": [1, 0, 1] }, "southeast": { "data": 6, "direction": [1, 0, 1] },
"southwest": { "data": 7, "direction": [-1, 0, 1] }, "southwest": { "data": 7, "direction": [-1, 0, 1] },
"northwest": { "data": 8, "direction": [-1, 0, -1] }, "northwest": { "data": 8, "direction": [-1, 0, -1] },
@ -2320,7 +2322,7 @@
"facing": { "facing": {
"values": { "values": {
"north": { "data": 0, "direction": [0, 0, -1] }, "north": { "data": 0, "direction": [0, 0, -1] },
"south": { "data": 1, "direction": [0, 0, 1] }, "south": { "data": 0, "direction": [0, 0, 1] },
"east": { "data": 1, "direction": [1, 0, 0] }, "east": { "data": 1, "direction": [1, 0, 0] },
"west": { "data": 1, "direction": [-1, 0, 0] }, "west": { "data": 1, "direction": [-1, 0, 0] },
"east_ascending": { "data": 2, "direction": [1, 1, 0] }, "east_ascending": { "data": 2, "direction": [1, 1, 0] },
@ -2330,6 +2332,7 @@
"north_ascending": { "data": 4, "direction": [0, 1, -1] }, "north_ascending": { "data": 4, "direction": [0, 1, -1] },
"north_descending": { "data": 4, "direction": [0, -1, 1] }, "north_descending": { "data": 4, "direction": [0, -1, 1] },
"south_ascending": { "data": 5, "direction": [0, 1, 1] }, "south_ascending": { "data": 5, "direction": [0, 1, 1] },
"south_descending": { "data": 5, "direction": [0, -1, -1] },
"southeast": { "data": 6, "direction": [1, 0, 1] }, "southeast": { "data": 6, "direction": [1, 0, 1] },
"southwest": { "data": 7, "direction": [-1, 0, 1] }, "southwest": { "data": 7, "direction": [-1, 0, 1] },
"northwest": { "data": 8, "direction": [-1, 0, -1] }, "northwest": { "data": 8, "direction": [-1, 0, -1] },
@ -2457,7 +2460,15 @@
"east": { "data": 1, "direction": [1, 0, 0] }, "east": { "data": 1, "direction": [1, 0, 0] },
"south": { "data": 3, "direction": [0, 0, 1] }, "south": { "data": 3, "direction": [0, 0, 1] },
"west": { "data": 2, "direction": [-1, 0, 0] }, "west": { "data": 2, "direction": [-1, 0, 0] },
"north": { "data": 4, "direction": [0, 0, -1] } "north": { "data": 4, "direction": [0, 0, -1] },
"ground_south": { "data": 5, "direction": [0, 1, 1] },
"ground_north": { "data": 5, "direction": [0, 1, -1] },
"ground_east": { "data": 6, "direction": [1, 1, 0] },
"ground_west": { "data": 6, "direction": [-1, 1, 0] },
"ceiling_south": { "data": 7, "direction": [0, -1, -1] },
"ceiling_north": { "data": 7, "direction": [0, -1, 1] },
"ceiling_east": { "data": 0, "direction": [1, -1, 0] },
"ceiling_west": { "data": 0, "direction": [-1, -1, 0] }
} }
}, },
"powered": { "powered": {
@ -3286,6 +3297,17 @@
"legacyId": 94, "legacyId": 94,
"id": "minecraft:powered_repeater", "id": "minecraft:powered_repeater",
"unlocalizedName": "tile.diode", "unlocalizedName": "tile.diode",
"states": {
"facing": {
"dataMask": 3,
"values": {
"north": { "data": 0, "direction": [0, 0, -1] },
"east": { "data": 1, "direction": [1, 0, 0] },
"south": { "data": 2, "direction": [0, 0, 1] },
"west": { "data": 3, "direction": [-1, 0, 0] }
}
}
},
"material": { "material": {
"renderedAsNormalBlock": false, "renderedAsNormalBlock": false,
"fullCube": false, "fullCube": false,
@ -5006,6 +5028,17 @@
"legacyId": 145, "legacyId": 145,
"id": "minecraft:anvil", "id": "minecraft:anvil",
"unlocalizedName": "tile.anvil", "unlocalizedName": "tile.anvil",
"states": {
"facing": {
"dataMask": 3,
"values": {
"south": { "data": 0, "direction": [0, 0, 1] },
"north": { "data": 0, "direction": [0, 0, -1] },
"west": { "data": 1, "direction": [-1, 0, 0] },
"east": { "data": 1, "direction": [1, 0, 0] }
}
}
},
"material": { "material": {
"renderedAsNormalBlock": false, "renderedAsNormalBlock": false,
"fullCube": false, "fullCube": false,
@ -5191,6 +5224,17 @@
"legacyId": 150, "legacyId": 150,
"id": "minecraft:powered_comparator", "id": "minecraft:powered_comparator",
"unlocalizedName": "tile.comparator", "unlocalizedName": "tile.comparator",
"states": {
"facing": {
"dataMask": 3,
"values": {
"north": { "data": 0, "direction": [0, 0, -1] },
"east": { "data": 1, "direction": [1, 0, 0] },
"south": { "data": 2, "direction": [0, 0, 1] },
"west": { "data": 3, "direction": [-1, 0, 0] }
}
}
},
"material": { "material": {
"renderedAsNormalBlock": false, "renderedAsNormalBlock": false,
"fullCube": false, "fullCube": false,
@ -5433,7 +5477,7 @@
"facing": { "facing": {
"values": { "values": {
"north": { "data": 0, "direction": [0, 0, -1] }, "north": { "data": 0, "direction": [0, 0, -1] },
"south": { "data": 1, "direction": [0, 0, 1] }, "south": { "data": 0, "direction": [0, 0, 1] },
"east": { "data": 1, "direction": [1, 0, 0] }, "east": { "data": 1, "direction": [1, 0, 0] },
"west": { "data": 1, "direction": [-1, 0, 0] }, "west": { "data": 1, "direction": [-1, 0, 0] },
"east_ascending": { "data": 2, "direction": [1, 1, 0] }, "east_ascending": { "data": 2, "direction": [1, 1, 0] },
@ -5443,6 +5487,7 @@
"north_ascending": { "data": 4, "direction": [0, 1, -1] }, "north_ascending": { "data": 4, "direction": [0, 1, -1] },
"north_descending": { "data": 4, "direction": [0, -1, 1] }, "north_descending": { "data": 4, "direction": [0, -1, 1] },
"south_ascending": { "data": 5, "direction": [0, 1, 1] }, "south_ascending": { "data": 5, "direction": [0, 1, 1] },
"south_descending": { "data": 5, "direction": [0, -1, -1] },
"southeast": { "data": 6, "direction": [1, 0, 1] }, "southeast": { "data": 6, "direction": [1, 0, 1] },
"southwest": { "data": 7, "direction": [-1, 0, 1] }, "southwest": { "data": 7, "direction": [-1, 0, 1] },
"northwest": { "data": 8, "direction": [-1, 0, -1] }, "northwest": { "data": 8, "direction": [-1, 0, -1] },

View File

@ -0,0 +1,79 @@
/*
* WorldEdit, a Minecraft world manipulation toolkit
* Copyright (C) sk89q <http://www.sk89q.com>
* Copyright (C) WorldEdit team and contributors
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by the
* Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.sk89q.worldedit.extent.transform;
import com.sk89q.worldedit.blocks.BaseBlock;
import com.sk89q.worldedit.blocks.BlockData;
import com.sk89q.worldedit.blocks.BlockType;
import com.sk89q.worldedit.math.transform.AffineTransform;
import com.sk89q.worldedit.math.transform.Transform;
import com.sk89q.worldedit.world.registry.BlockRegistry;
import com.sk89q.worldedit.world.registry.LegacyBlockRegistry;
import org.junit.Before;
import org.junit.Test;
import java.util.HashSet;
import java.util.Set;
import static org.hamcrest.CoreMatchers.equalTo;
import static org.junit.Assert.assertThat;
public class BlockTransformExtentTest {
private final Transform ROTATE_90 = new AffineTransform().rotateY(-90);
private final Transform ROTATE_NEG_90 = new AffineTransform().rotateY(90);
private final Set<BlockType> ignored = new HashSet<BlockType>();
@Before
public void setUp() throws Exception {
ignored.add(BlockType.BED); // Broken in existing rotation code?
ignored.add(BlockType.WOODEN_DOOR); // Complicated
ignored.add(BlockType.IRON_DOOR); // Complicated
ignored.add(BlockType.STONE_BUTTON); // Existing rotation code doesn't handle down/up directions
ignored.add(BlockType.WOODEN_BUTTON); // Existing rotation code doesn't handle down/up directions
ignored.add(BlockType.END_PORTAL); // Not supported in existing rotation code
}
@Test
public void testTransform() throws Exception {
BlockRegistry blockRegistry = new LegacyBlockRegistry();
for (BlockType type : BlockType.values()) {
if (ignored.contains(type)) {
continue;
}
BaseBlock orig = new BaseBlock(type.getID());
for (int i = 1; i < 4; i++) {
BaseBlock rotated = BlockTransformExtent.transform(new BaseBlock(orig), ROTATE_90, blockRegistry);
BaseBlock reference = new BaseBlock(orig.getType(), BlockData.rotate90(orig.getType(), orig.getData()));
assertThat(type + "#" + type.getID() + " rotated " + (90 * i) + " degrees did not match BlockData.rotate90()'s expected result", rotated, equalTo(reference));
orig = rotated;
}
orig = new BaseBlock(type.getID());
for (int i = 0; i < 4; i++) {
BaseBlock rotated = BlockTransformExtent.transform(new BaseBlock(orig), ROTATE_NEG_90, blockRegistry);
BaseBlock reference = new BaseBlock(orig.getType(), BlockData.rotate90Reverse(orig.getType(), orig.getData()));
assertThat(type + "#" + type.getID() + " rotated " + (-90 * i) + " degrees did not match BlockData.rotate90Reverse()'s expected result", rotated, equalTo(reference));
orig = rotated;
}
}
}
}