summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/Jamfile.jam26
-rw-r--r--test/test-lib.cpp4
-rw-r--r--test/test-text.cpp14
-rw-r--r--test/test-ui.cpp20
4 files changed, 38 insertions, 26 deletions
diff --git a/test/Jamfile.jam b/test/Jamfile.jam
index bedc2ad..bdaaa45 100644
--- a/test/Jamfile.jam
+++ b/test/Jamfile.jam
@@ -43,6 +43,16 @@ project : requirements
<toolset>tidy:<librarydef>boost
;
lib test : [ glob *.cpp : test-*.cpp perf-*.cpp ] ;
+rule perfrun ( main + : extra-requirements * : runtime-dependency * : command-args * ) {
+ local name = $(main[0]:S=) ;
+ local benchmark = $(main[0]:S=.benchmark) ;
+ explicit $(name) ;
+ exe $(benchmark) : $(main) :
+ <library>benchmark
+ <library>test
+ $(extra-requirements) ;
+ run $(benchmark) : $(command-args) : : <dependency>$(runtime-dependency) : $(name) ;
+}
run test-collection.cpp ;
run test-maths.cpp ;
@@ -55,22 +65,18 @@ run test-enumDetails.cpp ;
run test-render.cpp : -- : test-assetFactory : <library>test ;
run test-glContextBhvr.cpp ;
run test-assetFactory.cpp : -- : [ sequence.insertion-sort [ glob-tree $(res) : *.* ] fixtures/rgb.txt test-instancing ] : <library>test ;
-run perf-assetFactory.cpp : \< : test-assetFactory : <library>benchmark <library>test ;
-run perf-geoData.cpp : \< : test-geoData : <library>test <library>benchmark ;
-run perf-terrain.cpp : \< : test-geoData : <library>test <library>benchmark ;
-run perf-persistence.cpp : \< : test-persistence : <library>benchmark <library>test ;
+perfrun perf-assetFactory.cpp : : test-assetFactory ;
+perfrun perf-geoData.cpp : : test-geoData ;
+perfrun perf-terrain.cpp : : test-geoData ;
+perfrun perf-persistence.cpp : : test-persistence ;
run test-worker.cpp ;
run test-instancing.cpp : -- : test-glContainer : <library>test ;
-run perf-instancing.cpp : \< : test-instancing : <library>benchmark <library>test ;
+perfrun perf-instancing.cpp : : test-instancing ;
run test-glContainer.cpp : : : <library>test ;
run test-pack.cpp : : : <library>test ;
run test-environment.cpp : : : <library>test ;
+run test-ui.cpp : : : <library>test ;
compile test-static-enumDetails.cpp ;
compile test-static-stream_support.cpp ;
-explicit perf-assetFactory ;
-explicit perf-persistence ;
-explicit perf-geoData ;
-explicit perf-instancing ;
-explicit perf-terrain ;
alias perf : perf-assetFactory perf-persistence perf-geoData perf-instancing perf-terrain ;
explicit perf ;
diff --git a/test/test-lib.cpp b/test/test-lib.cpp
index ec91f6e..a1a8c80 100644
--- a/test/test-lib.cpp
+++ b/test/test-lib.cpp
@@ -46,9 +46,9 @@ BOOST_AUTO_TEST_CASE(generate_move_and_delete)
{
{
TestArray a;
- BOOST_CHECK_EQUAL(TestArray::size, active.size());
+ BOOST_CHECK_EQUAL(TestArray::size(), active.size());
const TestArray b {std::move(a)};
- BOOST_CHECK_EQUAL(TestArray::size, active.size());
+ BOOST_CHECK_EQUAL(TestArray::size(), active.size());
}
BOOST_CHECK(active.empty());
}
diff --git a/test/test-text.cpp b/test/test-text.cpp
index b0a9503..0729ce8 100644
--- a/test/test-text.cpp
+++ b/test/test-text.cpp
@@ -7,7 +7,6 @@
#include "testMainWindow.h"
#include "testRenderOutput.h"
-#include "ui/text.h"
#include <array>
#include <gfx/models/texture.h>
#include <glm/glm.hpp>
@@ -112,19 +111,6 @@ BOOST_AUTO_TEST_CASE(render_font)
}
}
-BOOST_AUTO_TEST_CASE(render_text)
-{
- TestRenderOutput output;
- glBindFramebuffer(GL_FRAMEBUFFER, output.output);
- glViewport(0, 0, 640, 480);
- glEnable(GL_BLEND);
- glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
- Text t {"I Like Trains", *this, {{10, 10}, {200, 40}}, {1, 1, 1}};
- UIShader s {640, 480};
- t.render(s, {});
- Texture::save(output.outImage, "/tmp/text.tga");
-}
-
BOOST_AUTO_TEST_SUITE_END()
BOOST_AUTO_TEST_CASE(stream_vec)
diff --git a/test/test-ui.cpp b/test/test-ui.cpp
new file mode 100644
index 0000000..2810cda
--- /dev/null
+++ b/test/test-ui.cpp
@@ -0,0 +1,20 @@
+#define BOOST_TEST_MODULE UI
+#include <boost/test/unit_test.hpp>
+#include <stream_support.h>
+
+#include "testMainWindow.h"
+#include <gfx/models/texture.h>
+#include <resource.h>
+#include <ui/svgIcon.h>
+
+constexpr GLsizei RENDER_SIZE = 64;
+
+BOOST_GLOBAL_FIXTURE(TestMainWindowAppBase);
+
+BOOST_AUTO_TEST_CASE(LoadFromFile)
+{
+ SvgIcon svg(ImageDimensions {RENDER_SIZE}, Resource::mapPath("ui/icon/rails.svg"));
+ const auto size = Texture::getSize(svg.texture);
+ BOOST_CHECK_EQUAL(size, TextureDimensions(RENDER_SIZE, RENDER_SIZE, 1));
+ Texture::save(svg.texture, "/tmp/rails.tga");
+}