-
Notifications
You must be signed in to change notification settings - Fork 810
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
1. Load assets from the bundle on Mac. 2. In timedemo_test, load MPQs before overriding pref path, so that they can also be loaded from the user/system location. 3. Fix various double directory separators ("build//assets" etc).
- Loading branch information
Showing
5 changed files
with
110 additions
and
105 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,95 +1,94 @@ | ||
/** | ||
* @file drlg_test.hpp | ||
* | ||
* Helpers for dungeon related tests. | ||
*/ | ||
#pragma once | ||
|
||
#include "engine/load_file.hpp" | ||
#include "levels/themes.h" | ||
#include "multi.h" | ||
#include "player.h" | ||
#include "quests.h" | ||
#include "utils/paths.h" | ||
|
||
using namespace devilution; | ||
|
||
int GetTileCount(dungeon_type levelType) | ||
{ | ||
switch (levelType) { | ||
case DTYPE_TOWN: | ||
return 376; | ||
case DTYPE_CATHEDRAL: | ||
return 206; | ||
case DTYPE_CATACOMBS: | ||
return 160; | ||
case DTYPE_CAVES: | ||
return 206; | ||
case DTYPE_HELL: | ||
return 137; | ||
case DTYPE_NEST: | ||
return 166; | ||
case DTYPE_CRYPT: | ||
return 217; | ||
default: | ||
app_fatal("Invalid level type"); | ||
} | ||
} | ||
|
||
std::unique_ptr<uint16_t[]> DunData; | ||
|
||
void LoadExpectedLevelData(const char *fixture) | ||
{ | ||
std::string dunPath = "test/fixtures/"; | ||
|
||
paths::SetPrefPath(paths::BasePath()); | ||
paths::SetAssetsPath(paths::BasePath() + "/" + dunPath); | ||
|
||
dunPath.append(fixture); | ||
DunData = LoadFileInMem<uint16_t>(dunPath.c_str()); | ||
ASSERT_NE(DunData, nullptr) << "Unable to load test fixture " << dunPath; | ||
ASSERT_EQ(WorldTileSize(DMAXX, DMAXY), GetDunSize(DunData.get())); | ||
} | ||
|
||
void TestInitGame(bool fullQuests = true, bool originalCathedral = true) | ||
{ | ||
Players.resize(1); | ||
MyPlayer = &Players[0]; | ||
MyPlayer->pOriginalCathedral = originalCathedral; | ||
|
||
sgGameInitInfo.fullQuests = fullQuests ? 1 : 0; | ||
gbIsMultiplayer = !fullQuests; | ||
|
||
InitQuests(); | ||
} | ||
|
||
void TestCreateDungeon(int level, uint32_t seed, lvl_entry entry) | ||
{ | ||
currlevel = level; | ||
leveltype = GetLevelType(level); | ||
|
||
pMegaTiles = std::make_unique<MegaTile[]>(GetTileCount(leveltype)); | ||
|
||
CreateDungeon(seed, entry); | ||
CreateThemeRooms(); | ||
|
||
const uint16_t *tileLayer = &DunData[2]; | ||
|
||
for (int y = 0; y < DMAXY; y++) { | ||
for (int x = 0; x < DMAXX; x++) { | ||
auto tileId = static_cast<uint8_t>(SDL_SwapLE16(*tileLayer)); | ||
tileLayer++; | ||
ASSERT_EQ(dungeon[x][y], tileId) << "Tiles don't match at " << x << "x" << y; | ||
} | ||
} | ||
|
||
const uint16_t *transparentLayer = &DunData[2 + DMAXX * DMAXY * 13]; | ||
|
||
for (int y = 16; y < 16 + DMAXY * 2; y++) { | ||
for (int x = 16; x < 16 + DMAXX * 2; x++) { | ||
auto sectorId = static_cast<uint8_t>(SDL_SwapLE16(*transparentLayer)); | ||
transparentLayer++; | ||
ASSERT_EQ(dTransVal[x][y], sectorId) << "Room/region indexes don't match at " << x << "x" << y; | ||
} | ||
} | ||
} | ||
/** | ||
* @file drlg_test.hpp | ||
* | ||
* Helpers for dungeon related tests. | ||
*/ | ||
#pragma once | ||
|
||
#include <gtest/gtest.h> | ||
|
||
#include "engine/load_file.hpp" | ||
#include "levels/themes.h" | ||
#include "multi.h" | ||
#include "player.h" | ||
#include "quests.h" | ||
#include "utils/paths.h" | ||
|
||
using namespace devilution; | ||
|
||
int GetTileCount(dungeon_type levelType) | ||
{ | ||
switch (levelType) { | ||
case DTYPE_TOWN: | ||
return 376; | ||
case DTYPE_CATHEDRAL: | ||
return 206; | ||
case DTYPE_CATACOMBS: | ||
return 160; | ||
case DTYPE_CAVES: | ||
return 206; | ||
case DTYPE_HELL: | ||
return 137; | ||
case DTYPE_NEST: | ||
return 166; | ||
case DTYPE_CRYPT: | ||
return 217; | ||
default: | ||
app_fatal("Invalid level type"); | ||
} | ||
} | ||
|
||
std::unique_ptr<uint16_t[]> DunData; | ||
|
||
void LoadExpectedLevelData(const char *fixture) | ||
{ | ||
// Set look up path to the location to load set pieces from later: | ||
paths::SetPrefPath(paths::BasePath() + "test/fixtures/"); | ||
DunData = LoadFileInMem<uint16_t>(fixture); | ||
ASSERT_NE(DunData, nullptr) << "Unable to load test fixture " << fixture; | ||
ASSERT_EQ(WorldTileSize(DMAXX, DMAXY), GetDunSize(DunData.get())); | ||
} | ||
|
||
void TestInitGame(bool fullQuests = true, bool originalCathedral = true) | ||
{ | ||
Players.resize(1); | ||
MyPlayer = &Players[0]; | ||
MyPlayer->pOriginalCathedral = originalCathedral; | ||
|
||
sgGameInitInfo.fullQuests = fullQuests ? 1 : 0; | ||
gbIsMultiplayer = !fullQuests; | ||
|
||
InitQuests(); | ||
} | ||
|
||
void TestCreateDungeon(int level, uint32_t seed, lvl_entry entry) | ||
{ | ||
LevelSeeds[level] = std::nullopt; | ||
currlevel = level; | ||
leveltype = GetLevelType(level); | ||
|
||
pMegaTiles = std::make_unique<MegaTile[]>(GetTileCount(leveltype)); | ||
|
||
CreateDungeon(seed, entry); | ||
CreateThemeRooms(); | ||
|
||
const uint16_t *tileLayer = &DunData[2]; | ||
|
||
for (int y = 0; y < DMAXY; y++) { | ||
for (int x = 0; x < DMAXX; x++) { | ||
auto tileId = static_cast<uint8_t>(SDL_SwapLE16(*tileLayer)); | ||
tileLayer++; | ||
ASSERT_EQ(dungeon[x][y], tileId) << "Tiles don't match at " << x << "x" << y; | ||
} | ||
} | ||
|
||
const uint16_t *transparentLayer = &DunData[2 + DMAXX * DMAXY * 13]; | ||
|
||
for (int y = 16; y < 16 + DMAXY * 2; y++) { | ||
for (int x = 16; x < 16 + DMAXX * 2; x++) { | ||
auto sectorId = static_cast<uint8_t>(SDL_SwapLE16(*transparentLayer)); | ||
transparentLayer++; | ||
ASSERT_EQ(dTransVal[x][y], sectorId) << "Room/region indexes don't match at " << x << "x" << y; | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters