Adding pellet test and renaming helpers.

This commit is contained in:
Ólafur Waage 2021-09-21 16:34:26 +02:00
parent 4b9f88013d
commit 125c55f176
2 changed files with 60 additions and 16 deletions

View file

@ -4,9 +4,8 @@
#include "Pinky.hpp" #include "Pinky.hpp"
#include <catch2/catch.hpp> #include <catch2/catch.hpp>
template<typename T> template<typename T>
static void ghostInitHelper(const T & ghost, double x, double y) { static void ghostInitTest(const T & ghost, double x, double y) {
const pacman::Position pos{ x, y }; const pacman::Position pos{ x, y };
REQUIRE(ghost.position() == pos); REQUIRE(ghost.position() == pos);
@ -19,20 +18,20 @@ static void ghostInitHelper(const T & ghost, double x, double y) {
TEST_CASE("Ghosts start in the correct position", "[ghosts]") { TEST_CASE("Ghosts start in the correct position", "[ghosts]") {
pacman::Blinky blinky; pacman::Blinky blinky;
ghostInitHelper(blinky, 13.5, 11); ghostInitTest(blinky, 13.5, 11);
pacman::Clyde clyde; pacman::Clyde clyde;
ghostInitHelper(clyde, 15.5, 14); ghostInitTest(clyde, 15.5, 14);
pacman::Inky inky; pacman::Inky inky;
ghostInitHelper(inky, 13.5, 14); ghostInitTest(inky, 13.5, 14);
pacman::Pinky pinky; pacman::Pinky pinky;
ghostInitHelper(pinky, 11.5, 14); ghostInitTest(pinky, 11.5, 14);
} }
template<typename T> template<typename T>
static void ghostFrightenHelper(T & ghost) { static void ghostFrightenTest(T & ghost) {
REQUIRE_FALSE(ghost.isFrightened()); REQUIRE_FALSE(ghost.isFrightened());
ghost.frighten(); ghost.frighten();
REQUIRE(ghost.isFrightened()); REQUIRE(ghost.isFrightened());
@ -42,20 +41,20 @@ static void ghostFrightenHelper(T & ghost) {
TEST_CASE("Ghosts are frighten", "[ghosts]") { TEST_CASE("Ghosts are frighten", "[ghosts]") {
pacman::Blinky blinky; pacman::Blinky blinky;
ghostFrightenHelper(blinky); ghostFrightenTest(blinky);
pacman::Clyde clyde; pacman::Clyde clyde;
ghostFrightenHelper(clyde); ghostFrightenTest(clyde);
pacman::Inky inky; pacman::Inky inky;
ghostFrightenHelper(inky); ghostFrightenTest(inky);
pacman::Pinky pinky; pacman::Pinky pinky;
ghostFrightenHelper(pinky); ghostFrightenTest(pinky);
} }
template<typename T> template<typename T>
static void ghostDeadHelper(T & ghost) { static void ghostDeadTest(T & ghost) {
REQUIRE_FALSE(ghost.isEyes()); REQUIRE_FALSE(ghost.isEyes());
ghost.die(); ghost.die();
REQUIRE(ghost.isEyes()); REQUIRE(ghost.isEyes());
@ -65,14 +64,14 @@ static void ghostDeadHelper(T & ghost) {
TEST_CASE("Ghosts can die", "[ghosts]") { TEST_CASE("Ghosts can die", "[ghosts]") {
pacman::Blinky blinky; pacman::Blinky blinky;
ghostDeadHelper(blinky); ghostDeadTest(blinky);
pacman::Clyde clyde; pacman::Clyde clyde;
ghostDeadHelper(clyde); ghostDeadTest(clyde);
pacman::Inky inky; pacman::Inky inky;
ghostDeadHelper(inky); ghostDeadTest(inky);
pacman::Pinky pinky; pacman::Pinky pinky;
ghostDeadHelper(pinky); ghostDeadTest(pinky);
} }

45
test/testPellets.cpp Normal file
View file

@ -0,0 +1,45 @@
#include "Pellets.hpp"
#include "SuperPellets.hpp"
#include <catch2/catch.hpp>
template<typename T>
static void pelletInitTest(const T & pellets, size_t size, size_t spriteX, size_t spriteY) {
REQUIRE(pellets.currentPositions().size() == size);
REQUIRE(pellets.currentSprite().x == spriteX);
REQUIRE(pellets.currentSprite().y == spriteY);
}
TEST_CASE("Pellet initialization", "[pellets]") {
pacman::Pellets pellets;
pelletInitTest(pellets, 240, 1, 9);
pacman::SuperPellets superPellets;
pelletInitTest(superPellets, 4, 0, 9);
}
template<typename T>
static void pelletEatingTest(T & pellets, size_t countBefore, size_t countAfter, size_t x, size_t y) {
REQUIRE(pellets.currentPositions().size() == countBefore);
if (countBefore != countAfter) {
REQUIRE(pellets.eatPelletAtPosition(pacman::GridPosition{ x, y }));
} else {
REQUIRE_FALSE(pellets.eatPelletAtPosition(pacman::GridPosition{ x, y }));
}
REQUIRE(pellets.currentPositions().size() == countAfter);
}
TEST_CASE("Eating pellets", "[pellets]") {
pacman::Pellets pellets;
pelletEatingTest(pellets, 240, 240, 0, 0); // wall
pelletEatingTest(pellets, 240, 239, 1, 1); // pellet
pelletEatingTest(pellets, 239, 239, 1, 1);
pelletEatingTest(pellets, 239, 238, 1, 2); // pellet
pelletEatingTest(pellets, 238, 238, 1, 2);
pelletEatingTest(pellets, 238, 238, 1, 3); // super pellet
pacman::SuperPellets superPellets;
pelletEatingTest(superPellets, 4, 4, 0, 0); // wall
pelletEatingTest(superPellets, 4, 3, 1, 3); // super pellet
pelletEatingTest(superPellets, 3, 3, 1, 3);
pelletEatingTest(superPellets, 3, 3, 2, 1); // pellet
}