squall/test/Region.cpp

112 lines
3.4 KiB
C++
Raw Normal View History

#include "RegionTest.hpp"
2023-03-30 14:37:05 -05:00
TEST_CASE("SRgnCreate", "[region]") {
SECTION("sets handle pointer to new region handle") {
HSRGN region = nullptr;
2023-03-30 14:37:05 -05:00
SRgnCreate(&region, 0);
REQUIRE(region != nullptr);
SRgnDelete(region);
}
}
TEST_CASE("SRgnCombineRectf", "[region]") {
RgnDataTest region;
2023-03-30 14:37:05 -05:00
SECTION("combines the region with a single given rect 1") {
2023-03-30 14:37:05 -05:00
RECTF baseRect = { 0.0f, 0.0f, 1.0f, 1.0f };
2025-04-20 13:06:12 -07:00
SRgnCombineRectf(region, &baseRect, nullptr, SRGN_OR);
2023-03-30 14:37:05 -05:00
RECTF boundingRect = { 0.0f, 0.0f, 0.0f, 0.0f };
SRgnGetBoundingRectf(region, &boundingRect);
CHECK_THAT(boundingRect, MatchesRect({ 0.0f, 0.0f, 1.0f, 1.0f }));
2023-03-30 14:37:05 -05:00
}
2023-03-31 22:29:49 -05:00
SECTION("combines the region with multiple given rects 1") {
2023-03-30 14:37:05 -05:00
RECTF baseRect = { 0.0f, 0.0f, 1.0f, 1.0f };
2025-04-20 13:06:12 -07:00
SRgnCombineRectf(region, &baseRect, nullptr, SRGN_OR);
2023-03-30 14:37:05 -05:00
RECTF newRect = { 0.0f, 0.0f, 0.0f, 0.0f };
2025-04-20 13:06:12 -07:00
SRgnCombineRectf(region, &newRect, nullptr, SRGN_DIFF);
2023-03-30 14:37:05 -05:00
RECTF boundingRect = { 0.0f, 0.0f, 0.0f, 0.0f };
SRgnGetBoundingRectf(region, &boundingRect);
CHECK_THAT(boundingRect, MatchesRect({ 0.0f, 0.0f, 1.0f, 1.0f }));
2023-03-30 14:37:05 -05:00
}
2023-03-31 22:29:49 -05:00
SECTION("combines the region with multiple given rects 2") {
RECTF baseRect = { 0.0f, 0.0f, 1.0f, 1.0f };
2025-04-20 13:06:12 -07:00
SRgnCombineRectf(region, &baseRect, nullptr, SRGN_OR);
2023-03-31 22:29:49 -05:00
RECTF newRect = { 0.0f, 0.0f, 1.0f, 1.0f };
2025-04-20 13:06:12 -07:00
SRgnCombineRectf(region, &newRect, nullptr, SRGN_DIFF);
2023-03-31 22:29:49 -05:00
RECTF boundingRect = { 0.0f, 0.0f, 0.0f, 0.0f };
SRgnGetBoundingRectf(region, &boundingRect);
CHECK_THAT(boundingRect, MatchesRect({ 0.0f, 0.0f, 0.0f, 0.0f }));
2023-03-31 22:29:49 -05:00
}
SECTION("combines the region with multiple given rects 3") {
RECTF baseRect = { 0.0f, 0.0f, 1.0f, 1.0f };
2025-04-20 13:06:12 -07:00
SRgnCombineRectf(region, &baseRect, nullptr, SRGN_OR);
2023-03-31 22:29:49 -05:00
RECTF newRect = { 0.0f, 1.0f, 1.0f, 1.0f };
2025-04-20 13:06:12 -07:00
SRgnCombineRectf(region, &newRect, nullptr, SRGN_DIFF);
2023-03-31 22:29:49 -05:00
RECTF boundingRect = { 0.0f, 0.0f, 0.0f, 0.0f };
SRgnGetBoundingRectf(region, &boundingRect);
CHECK_THAT(boundingRect, MatchesRect({ 0.0f, 0.0f, 1.0f, 1.0f }));
2023-03-31 22:29:49 -05:00
}
2023-03-30 14:37:05 -05:00
}
2025-04-20 19:56:40 -07:00
TEST_CASE("SRgnGetRectsf", "[region]") {
RgnDataTest region;
2025-04-20 19:56:40 -07:00
SECTION("retrieves empty list if nothing put in") {
2025-04-20 19:56:40 -07:00
uint32_t numrects = 1;
RECTF buffer[1];
SRgnGetRectsf(region, &numrects, buffer);
2025-04-20 19:56:40 -07:00
CHECK(numrects == 0);
}
SECTION("retrieves all rects that were put in") {
RECTF rct1 = { 5, 5, 10, 10 };
RECTF rct2 = { 0, 0, 1, 1 };
SRgnCombineRectf(region, &rct1, nullptr, SRGN_OR);
SRgnCombineRectf(region, &rct2, nullptr, SRGN_OR);
2025-04-20 19:56:40 -07:00
uint32_t numrects = 0;
RECTF buffer[2];
SRgnGetRectsf(region, &numrects, nullptr);
2025-04-20 19:56:40 -07:00
REQUIRE(numrects == 2);
SRgnGetRectsf(region, &numrects, buffer);
2025-04-20 19:56:40 -07:00
CHECK_THAT(buffer[0], MatchesRect(rct2));
CHECK_THAT(buffer[1], MatchesRect(rct1));
2025-04-20 19:56:40 -07:00
}
SECTION("automatically merges overlapping rects") {
RECTF rct1 = { -10, -10, 10, 10 };
RECTF rct2 = { 0, 0, 1, 1 };
SRgnCombineRectf(region, &rct1, nullptr, SRGN_OR);
SRgnCombineRectf(region, &rct2, nullptr, SRGN_OR);
2025-04-20 19:56:40 -07:00
uint32_t numrects = 0;
RECTF buffer[1];
SRgnGetRectsf(region, &numrects, nullptr);
2025-04-20 19:56:40 -07:00
REQUIRE(numrects == 1);
SRgnGetRectsf(region, &numrects, buffer);
2025-04-20 19:56:40 -07:00
CHECK_THAT(buffer[0], MatchesRect(rct1));
2025-04-20 19:56:40 -07:00
}
}