2017-07-04 13:29:50 +02:00
|
|
|
/*
|
|
|
|
* BattleHexTest.cpp, part of VCMI engine
|
|
|
|
*
|
|
|
|
* Authors: listed in file AUTHORS in main folder
|
|
|
|
*
|
|
|
|
* License: GNU General Public License v2.0 or later
|
|
|
|
* Full text of license available in license.txt file, in main folder
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "StdInc.h"
|
|
|
|
#include "../lib/battle/BattleHex.h"
|
|
|
|
|
2017-07-20 07:08:49 +03:00
|
|
|
TEST(BattleHexTest, getNeighbouringTiles)
|
|
|
|
{
|
2017-07-04 13:29:50 +02:00
|
|
|
BattleHex mainHex;
|
|
|
|
std::vector<BattleHex> neighbouringTiles;
|
|
|
|
mainHex.setXY(16,0);
|
|
|
|
neighbouringTiles = mainHex.neighbouringTiles();
|
|
|
|
EXPECT_EQ(neighbouringTiles.size(), 1);
|
|
|
|
mainHex.setXY(0,0);
|
|
|
|
neighbouringTiles = mainHex.neighbouringTiles();
|
|
|
|
EXPECT_EQ(neighbouringTiles.size(), 2);
|
|
|
|
mainHex.setXY(15,2);
|
|
|
|
neighbouringTiles = mainHex.neighbouringTiles();
|
|
|
|
EXPECT_EQ(neighbouringTiles.size(), 3);
|
|
|
|
mainHex.setXY(2,0);
|
|
|
|
neighbouringTiles = mainHex.neighbouringTiles();
|
|
|
|
EXPECT_EQ(neighbouringTiles.size(), 4);
|
|
|
|
mainHex.setXY(1,2);
|
|
|
|
neighbouringTiles = mainHex.neighbouringTiles();
|
|
|
|
EXPECT_EQ(neighbouringTiles.size(), 5);
|
|
|
|
mainHex.setXY(8,5);
|
|
|
|
neighbouringTiles = mainHex.neighbouringTiles();
|
|
|
|
EXPECT_EQ(neighbouringTiles.size(), 6);
|
|
|
|
|
|
|
|
ASSERT_TRUE(neighbouringTiles.size()==6 && mainHex==93);
|
|
|
|
EXPECT_EQ(neighbouringTiles.at(0), 75);
|
|
|
|
EXPECT_EQ(neighbouringTiles.at(1), 76);
|
|
|
|
EXPECT_EQ(neighbouringTiles.at(2), 94);
|
|
|
|
EXPECT_EQ(neighbouringTiles.at(3), 110);
|
|
|
|
EXPECT_EQ(neighbouringTiles.at(4), 109);
|
|
|
|
EXPECT_EQ(neighbouringTiles.at(5), 92);
|
|
|
|
}
|
|
|
|
|
2017-07-20 07:08:49 +03:00
|
|
|
TEST(BattleHexTest, getDistance)
|
|
|
|
{
|
2024-01-09 22:38:54 +00:00
|
|
|
BattleHex firstHex(0,0);
|
|
|
|
BattleHex secondHex(16,0);
|
2017-07-04 13:29:50 +02:00
|
|
|
EXPECT_EQ((int)firstHex.getDistance(firstHex,secondHex), 16);
|
|
|
|
firstHex=0, secondHex=170;
|
|
|
|
EXPECT_EQ((int)firstHex.getDistance(firstHex,secondHex), 10);
|
|
|
|
firstHex=16, secondHex=181;
|
|
|
|
EXPECT_EQ((int)firstHex.getDistance(firstHex,secondHex), 10);
|
|
|
|
firstHex=186, secondHex=70;
|
|
|
|
EXPECT_EQ((int)firstHex.getDistance(firstHex,secondHex), 17);
|
|
|
|
firstHex=166, secondHex=39;
|
|
|
|
EXPECT_EQ((int)firstHex.getDistance(firstHex,secondHex), 11);
|
|
|
|
firstHex=25, secondHex=103;
|
|
|
|
EXPECT_EQ((int)firstHex.getDistance(firstHex,secondHex), 9);
|
|
|
|
firstHex=18, secondHex=71;
|
|
|
|
EXPECT_EQ((int)firstHex.getDistance(firstHex,secondHex), 4);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(BattleHexTest, mutualPositions)
|
|
|
|
{
|
2024-01-09 22:38:54 +00:00
|
|
|
BattleHex firstHex(0,0);
|
|
|
|
BattleHex secondHex(16,0);
|
2017-07-04 13:29:50 +02:00
|
|
|
firstHex=86, secondHex=68;
|
|
|
|
EXPECT_EQ((int)firstHex.mutualPosition(firstHex,secondHex), BattleHex::EDir::TOP_LEFT);
|
|
|
|
secondHex=69;
|
|
|
|
EXPECT_EQ((int)firstHex.mutualPosition(firstHex,secondHex), BattleHex::EDir::TOP_RIGHT);
|
|
|
|
secondHex=87;
|
|
|
|
EXPECT_EQ((int)firstHex.mutualPosition(firstHex,secondHex), BattleHex::EDir::RIGHT);
|
|
|
|
secondHex=103;
|
|
|
|
EXPECT_EQ((int)firstHex.mutualPosition(firstHex,secondHex), BattleHex::EDir::BOTTOM_RIGHT);
|
|
|
|
secondHex=102;
|
|
|
|
EXPECT_EQ((int)firstHex.mutualPosition(firstHex,secondHex), BattleHex::EDir::BOTTOM_LEFT);
|
|
|
|
secondHex=85;
|
|
|
|
EXPECT_EQ((int)firstHex.mutualPosition(firstHex,secondHex), BattleHex::EDir::LEFT);
|
|
|
|
secondHex=46;
|
|
|
|
EXPECT_EQ((int)firstHex.mutualPosition(firstHex,secondHex), -1);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(BattleHexTest, getClosestTile)
|
|
|
|
{
|
|
|
|
BattleHex mainHex(0);
|
|
|
|
std::set<BattleHex> possibilities;
|
|
|
|
possibilities.insert(3);
|
|
|
|
possibilities.insert(170);
|
|
|
|
possibilities.insert(100);
|
|
|
|
possibilities.insert(119);
|
|
|
|
possibilities.insert(186);
|
|
|
|
|
2024-08-11 20:22:35 +00:00
|
|
|
EXPECT_EQ(mainHex.getClosestTile(BattleSide::ATTACKER,mainHex,possibilities), 3);
|
2017-07-04 13:29:50 +02:00
|
|
|
mainHex = 139;
|
2024-08-11 20:22:35 +00:00
|
|
|
EXPECT_EQ(mainHex.getClosestTile(BattleSide::DEFENDER,mainHex,possibilities), 119);
|
2017-07-04 13:29:50 +02:00
|
|
|
mainHex = 16;
|
2024-08-11 20:22:35 +00:00
|
|
|
EXPECT_EQ(mainHex.getClosestTile(BattleSide::DEFENDER,mainHex,possibilities), 100);
|
2017-07-04 13:29:50 +02:00
|
|
|
mainHex = 166;
|
2024-08-11 20:22:35 +00:00
|
|
|
EXPECT_EQ(mainHex.getClosestTile(BattleSide::ATTACKER,mainHex,possibilities), 186);
|
2017-07-04 13:29:50 +02:00
|
|
|
mainHex = 76;
|
2024-08-11 20:22:35 +00:00
|
|
|
EXPECT_EQ(mainHex.getClosestTile(BattleSide::DEFENDER,mainHex,possibilities), 3);
|
|
|
|
EXPECT_EQ(mainHex.getClosestTile(BattleSide::ATTACKER,mainHex,possibilities), 100);
|
2017-07-04 13:29:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(BattleHexTest, moveEDir)
|
|
|
|
{
|
|
|
|
BattleHex mainHex(20);
|
|
|
|
mainHex.moveInDirection(BattleHex::EDir::BOTTOM_RIGHT);
|
|
|
|
EXPECT_EQ(mainHex, 37);
|
|
|
|
mainHex.moveInDirection(BattleHex::EDir::RIGHT);
|
|
|
|
EXPECT_EQ(mainHex, 38);
|
|
|
|
mainHex.moveInDirection(BattleHex::EDir::TOP_RIGHT);
|
|
|
|
EXPECT_EQ(mainHex, 22);
|
|
|
|
mainHex.moveInDirection(BattleHex::EDir::TOP_LEFT);
|
|
|
|
EXPECT_EQ(mainHex, 4);
|
|
|
|
mainHex.moveInDirection(BattleHex::EDir::LEFT);
|
|
|
|
EXPECT_EQ(mainHex, 3);
|
|
|
|
mainHex.moveInDirection(BattleHex::EDir::BOTTOM_LEFT);
|
|
|
|
EXPECT_EQ(mainHex, 20);
|
|
|
|
}
|