summaryrefslogtreecommitdiff
path: root/src/tests/util/test_procedural.cc
diff options
context:
space:
mode:
authorskal <pascal.massimino@gmail.com>2026-02-09 20:27:04 +0100
committerskal <pascal.massimino@gmail.com>2026-02-09 20:27:04 +0100
commiteff8d43479e7704df65fae2a80eefa787213f502 (patch)
tree76f2fb8fe8d3db2c15179449df2cf12f7f54e0bf /src/tests/util/test_procedural.cc
parent12378b1b7e9091ba59895b4360b2fa959180a56a (diff)
refactor: Reorganize tests into subsystem subdirectories
Restructured test suite for better organization and targeted testing: **Structure:** - src/tests/audio/ - 15 audio system tests - src/tests/gpu/ - 12 GPU/shader tests - src/tests/3d/ - 6 3D rendering tests - src/tests/assets/ - 2 asset system tests - src/tests/util/ - 3 utility tests - src/tests/common/ - 3 shared test helpers - src/tests/scripts/ - 2 bash test scripts (moved conceptually, not physically) **CMake changes:** - Updated add_demo_test macro to accept LABEL parameter - Applied CTest labels to all 36 tests for subsystem filtering - Updated all test file paths in CMakeLists.txt - Fixed common helper paths (webgpu_test_fixture, etc.) - Added custom targets for subsystem testing: - run_audio_tests, run_gpu_tests, run_3d_tests - run_assets_tests, run_util_tests, run_all_tests **Include path updates:** - Fixed relative includes in GPU tests to reference ../common/ **Documentation:** - Updated doc/HOWTO.md with subsystem test commands - Updated doc/CONTRIBUTING.md with new test organization - Updated scripts/check_all.sh to reflect new structure **Verification:** - All 36 tests passing (100%) - ctest -L <subsystem> filters work correctly - make run_<subsystem>_tests targets functional - scripts/check_all.sh passes Backward compatible: make test and ctest continue to work unchanged. handoff(Gemini): Test reorganization complete. 36/36 tests passing.
Diffstat (limited to 'src/tests/util/test_procedural.cc')
-rw-r--r--src/tests/util/test_procedural.cc137
1 files changed, 137 insertions, 0 deletions
diff --git a/src/tests/util/test_procedural.cc b/src/tests/util/test_procedural.cc
new file mode 100644
index 0000000..e9f9a02
--- /dev/null
+++ b/src/tests/util/test_procedural.cc
@@ -0,0 +1,137 @@
+// This file is part of the 64k demo project.
+// It tests the procedural generation system.
+
+#include "procedural/generator.h"
+#include <cassert>
+#include <cmath>
+#include <iostream>
+#include <vector>
+
+void test_noise() {
+ std::cout << "Testing Noise Generator..." << std::endl;
+ int w = 64, h = 64;
+ std::vector<uint8_t> buffer(w * h * 4);
+ float params[] = {12345, 1.0f}; // Seed, Intensity
+
+ // Test with explicit params
+ bool res = procedural::gen_noise(buffer.data(), w, h, params, 2);
+ assert(res);
+ assert(buffer[3] == 255);
+
+ // Check that not all pixels are black
+ bool nonzero = false;
+ for (size_t i = 0; i < buffer.size(); i += 4) {
+ if (buffer[i] > 0) {
+ nonzero = true;
+ break;
+ }
+ }
+ assert(nonzero);
+
+ // Test with default params
+ std::fill(buffer.begin(), buffer.end(), 0);
+ res = procedural::gen_noise(buffer.data(), w, h, nullptr, 0);
+ assert(res);
+ assert(buffer[3] == 255); // Alpha should still be set
+}
+
+void test_perlin() {
+ std::cout << "Testing Perlin Generator..." << std::endl;
+ int w = 64, h = 64;
+ std::vector<uint8_t> buffer(w * h * 4);
+
+ // Test with explicit params
+ // Params: Seed, Freq, Amp, Decay, Octaves
+ float params[] = {12345, 4.0f, 1.0f, 0.5f, 4.0f};
+ bool res = procedural::gen_perlin(buffer.data(), w, h, params, 5);
+ assert(res);
+ assert(buffer[3] == 255);
+
+ bool nonzero = false;
+ for (size_t i = 0; i < buffer.size(); i += 4) {
+ if (buffer[i] > 0) {
+ nonzero = true;
+ break;
+ }
+ }
+ assert(nonzero);
+
+ // Test with default params
+ std::fill(buffer.begin(), buffer.end(), 0);
+ res = procedural::gen_perlin(buffer.data(), w, h, nullptr, 0);
+ assert(res);
+ assert(buffer[3] == 255);
+
+ // Test memory allocation failure simulation (large dimensions)
+ // This is hard to robustly test without mocking, but we can try an
+ // excessively large allocation if desired. For now, we trust the logic path.
+}
+
+void test_grid() {
+ std::cout << "Testing Grid Generator..." << std::endl;
+ int w = 100, h = 100;
+ std::vector<uint8_t> buffer(w * h * 4);
+ float params[] = {10, 1}; // Size 10, Thickness 1
+
+ // Test with explicit params
+ bool res = procedural::gen_grid(buffer.data(), w, h, params, 2);
+ assert(res);
+
+ // Pixel (0,0) should be white (on line)
+ assert(buffer[0] == 255);
+ // Pixel (5,5) should be black (off line, since size=10)
+ assert(buffer[(5 * w + 5) * 4] == 0);
+ // Pixel (10,0) should be white (on vertical line)
+ assert(buffer[(0 * w + 10) * 4] == 255);
+
+ // Test with default params
+ res = procedural::gen_grid(buffer.data(), w, h, nullptr, 0);
+ assert(res);
+ // Default size is 32, thickness 2
+ assert(buffer[0] == 255);
+ assert(buffer[(0 * w + 32) * 4] == 255);
+}
+
+void test_periodic() {
+ std::cout << "Testing Periodic Blending..." << std::endl;
+ int w = 64, h = 64;
+ std::vector<uint8_t> buffer(w * h * 4);
+
+ // Fill with horizontal gradient: left=0, right=255
+ for (int y = 0; y < h; ++y) {
+ for (int x = 0; x < w; ++x) {
+ int idx = (y * w + x) * 4;
+ buffer[idx] = (uint8_t)(x * 255 / (w - 1));
+ buffer[idx + 1] = 0;
+ buffer[idx + 2] = 0;
+ buffer[idx + 3] = 255;
+ }
+ }
+
+ // Pre-check: edges are different
+ assert(buffer[0] == 0);
+ assert(buffer[(w - 1) * 4] == 255);
+
+ float params[] = {0.1f}; // Blend ratio 10%
+ bool res = procedural::make_periodic(buffer.data(), w, h, params, 1);
+ assert(res);
+
+ // Post-check: Left edge (x=0) should now be blended with right edge.
+ // Logic: blend right edge INTO left edge. At x=0, we copy from right side.
+ // So buffer[0] should be close to 255 (value from right).
+ assert(buffer[0] > 200);
+
+ // Check invalid ratio
+ float invalid_params[] = {-1.0f};
+ res = procedural::make_periodic(buffer.data(), w, h, invalid_params, 1);
+ assert(res); // Should return true but do nothing
+}
+
+int main() {
+ test_noise();
+ test_perlin();
+ test_grid();
+ test_periodic();
+ std::cout << "--- PROCEDURAL TESTS PASSED ---" << std::endl;
+ return 0;
+} \ No newline at end of file