[Orxonox-commit 4354] r9025 - in code/branches/testing/test: . util

landauf at orxonox.net landauf at orxonox.net
Sun Mar 11 20:26:31 CET 2012


Author: landauf
Date: 2012-03-11 20:26:30 +0100 (Sun, 11 Mar 2012)
New Revision: 9025

Added:
   code/branches/testing/test/CTestCustom.cmake
   code/branches/testing/test/util/
   code/branches/testing/test/util/CMakeLists.txt
   code/branches/testing/test/util/MathTest.cc
Modified:
   code/branches/testing/test/CMakeLists.txt
Log:
 - added CTestCustom.cmake to add dependencies to $PATH when executing tests with ctest
 - added ARGS parameter for "test" target in make to pass command line options to ctest (make test ARGS="--some-ctest-option")
 - added unit tests for math functions in util library

Modified: code/branches/testing/test/CMakeLists.txt
===================================================================
--- code/branches/testing/test/CMakeLists.txt	2012-02-26 21:36:04 UTC (rev 9024)
+++ code/branches/testing/test/CMakeLists.txt	2012-03-11 19:26:30 UTC (rev 9025)
@@ -1,6 +1,6 @@
 ENABLE_TESTING()
 
-ADD_CUSTOM_TARGET(test COMMAND ${CMAKE_CTEST_COMMAND})
+ADD_CUSTOM_TARGET(test COMMAND ${CMAKE_CTEST_COMMAND} "$(ARGS)" COMMENT "Running tests")
 
 ADD_EXECUTABLE(sample_test EXCLUDE_FROM_ALL SampleTest.cc)
 ADD_DEPENDENCIES(test sample_test)
@@ -40,3 +40,18 @@
 ADD_DEPENDENCIES(test gtest_sample)
 
 ADD_TEST(gtest_sample ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/gtest_sample)
+
+#-----------------
+
+CONFIGURE_FILE("CTestCustom.cmake" "CTestCustom.cmake" @ONLY)
+
+INCLUDE_DIRECTORIES(
+  ../src/libraries
+  ../src/orxonox
+  ../src/modules
+  ${CMAKE_BINARY_DIR}/src
+  ${OGRE_INCLUDE_DIR}
+  ${POCO_INCLUDE_DIR}
+)
+
+ADD_SUBDIRECTORY(util)

Added: code/branches/testing/test/CTestCustom.cmake
===================================================================
--- code/branches/testing/test/CTestCustom.cmake	                        (rev 0)
+++ code/branches/testing/test/CTestCustom.cmake	2012-03-11 19:26:30 UTC (rev 9025)
@@ -0,0 +1 @@
+SET(ENV{PATH} "@CMAKE_LIBRARY_PATH@;$ENV{PATH}")

Added: code/branches/testing/test/util/CMakeLists.txt
===================================================================
--- code/branches/testing/test/util/CMakeLists.txt	                        (rev 0)
+++ code/branches/testing/test/util/CMakeLists.txt	2012-03-11 19:26:30 UTC (rev 9025)
@@ -0,0 +1,10 @@
+ADD_EXECUTABLE(
+    util_test
+    EXCLUDE_FROM_ALL
+    ${GMOCK_MAIN}
+    MathTest.cc
+)
+TARGET_LINK_LIBRARIES(util_test util gmock_orxonox)
+ADD_DEPENDENCIES(test util_test)
+
+ADD_TEST(util_test ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/util_test)

Added: code/branches/testing/test/util/MathTest.cc
===================================================================
--- code/branches/testing/test/util/MathTest.cc	                        (rev 0)
+++ code/branches/testing/test/util/MathTest.cc	2012-03-11 19:26:30 UTC (rev 9025)
@@ -0,0 +1,380 @@
+#include <gtest/gtest.h>
+#include "util/Math.h"
+#include <cmath>
+
+namespace orxonox
+{
+    ///////////
+    // sgn() //
+    ///////////
+    TEST(sgn, PositiveInt)
+    {
+        EXPECT_EQ(1, sgn( 1));
+        EXPECT_EQ(1, sgn(10));
+    }
+
+    TEST(sgn, PositiveDouble)
+    {
+        EXPECT_DOUBLE_EQ(1.0, sgn( 0.1));
+        EXPECT_DOUBLE_EQ(1.0, sgn( 1.0));
+        EXPECT_DOUBLE_EQ(1.0, sgn(10.0));
+    }
+
+    TEST(sgn, NegativeInt)
+    {
+        EXPECT_EQ(-1, sgn( -1));
+        EXPECT_EQ(-1, sgn(-10));
+    }
+
+    TEST(sgn, NegativeDouble)
+    {
+        EXPECT_DOUBLE_EQ(-1.0, sgn( -0.1));
+        EXPECT_DOUBLE_EQ(-1.0, sgn( -1.0));
+        EXPECT_DOUBLE_EQ(-1.0, sgn(-10.0));
+    }
+
+    TEST(sgn, ZeroInt)
+    {
+        EXPECT_EQ(1, sgn(0));
+    }
+
+    TEST(sgn, ZeroDouble)
+    {
+        EXPECT_DOUBLE_EQ(1.0, sgn(0.0));
+    }
+
+    /////////////
+    // clamp() //
+    /////////////
+    TEST(clamp, InRange)
+    {
+        // positive
+        EXPECT_EQ(10, clamp(10, 10, 20));
+        EXPECT_EQ(15, clamp(15, 10, 20));
+        EXPECT_EQ(20, clamp(20, 10, 20));
+
+        // netagive
+        EXPECT_EQ(-10, clamp(-10, -20, -10));
+        EXPECT_EQ(-15, clamp(-15, -20, -10));
+        EXPECT_EQ(-20, clamp(-20, -20, -10));
+
+        // mixed
+        EXPECT_EQ(-10, clamp(-10, -10, 10));
+        EXPECT_EQ(  0, clamp(  0, -10, 10));
+        EXPECT_EQ( 10, clamp( 10, -10, 10));
+    }
+
+    TEST(clamp, OutOfRange)
+    {
+        // positive
+        EXPECT_EQ(10, clamp( 5, 10, 20));
+        EXPECT_EQ(20, clamp(25, 10, 20));
+
+        // netagive
+        EXPECT_EQ(-10, clamp( -5, -20, -10));
+        EXPECT_EQ(-20, clamp(-25, -20, -10));
+
+        // mixed
+        EXPECT_EQ(-10, clamp(-15, -10, 10));
+        EXPECT_EQ( 10, clamp( 15, -10, 10));
+    }
+
+    //////////////
+    // square() //
+    //////////////
+    TEST(square, Int)
+    {
+        // zero
+        EXPECT_EQ( 0, square(0));
+
+        // positive
+        EXPECT_EQ(1, square(1));
+        EXPECT_EQ(4, square(2));
+        EXPECT_EQ(9, square(3));
+
+        // negative
+        EXPECT_EQ(1, square(-1));
+        EXPECT_EQ(4, square(-2));
+        EXPECT_EQ(9, square(-3));
+    }
+
+    TEST(square, Double)
+    {
+        // zero
+        EXPECT_DOUBLE_EQ( 0.0, square(0.0));
+
+        // positive
+        EXPECT_DOUBLE_EQ( 1.00, square(1.0));
+        EXPECT_DOUBLE_EQ( 2.25, square(1.5));
+        EXPECT_DOUBLE_EQ( 4.00, square(2.0));
+
+        // negative
+        EXPECT_DOUBLE_EQ( 1.00, square(-1.0));
+        EXPECT_DOUBLE_EQ( 2.25, square(-1.5));
+        EXPECT_DOUBLE_EQ( 4.00, square(-2.0));
+    }
+
+    ////////////
+    // cube() //
+    ////////////
+    TEST(cube, Int)
+    {
+        // zero
+        EXPECT_EQ( 0, cube(0));
+
+        // positive
+        EXPECT_EQ( 1, cube(1));
+        EXPECT_EQ( 8, cube(2));
+        EXPECT_EQ(27, cube(3));
+
+        // negative
+        EXPECT_EQ( -1, cube(-1));
+        EXPECT_EQ( -8, cube(-2));
+        EXPECT_EQ(-27, cube(-3));
+    }
+
+    TEST(cube, Double)
+    {
+        // zero
+        EXPECT_DOUBLE_EQ( 0.0, cube(0.0));
+
+        // positive
+        EXPECT_DOUBLE_EQ( 1.000, cube(1.0));
+        EXPECT_DOUBLE_EQ( 3.375, cube(1.5));
+        EXPECT_DOUBLE_EQ( 8.000, cube(2.0));
+
+        // negative
+        EXPECT_DOUBLE_EQ( -1.000, cube(-1.0));
+        EXPECT_DOUBLE_EQ( -3.375, cube(-1.5));
+        EXPECT_DOUBLE_EQ( -8.000, cube(-2.0));
+    }
+
+    /////////////
+    // round() //
+    /////////////
+    TEST(round, Positive)
+    {
+        // int
+        EXPECT_EQ( 5, round(5));
+        EXPECT_EQ(10, round(10));
+
+        // double
+        EXPECT_EQ(4, round(4.499));
+        EXPECT_EQ(5, round(4.500));
+        EXPECT_EQ(5, round(4.999));
+        EXPECT_EQ(5, round(5.000));
+        EXPECT_EQ(5, round(5.001));
+        EXPECT_EQ(5, round(5.499));
+        EXPECT_EQ(6, round(5.500));
+    }
+
+    /////////////
+    // round() //
+    /////////////
+    TEST(round, Negative)
+    {
+        // int
+        EXPECT_EQ( -5, round(-5));
+        EXPECT_EQ(-10, round(-10));
+
+        // double
+        EXPECT_EQ(-4, round(-4.499));
+        EXPECT_EQ(-5, round(-4.500));
+        EXPECT_EQ(-5, round(-4.999));
+        EXPECT_EQ(-5, round(-5.000));
+        EXPECT_EQ(-5, round(-5.001));
+        EXPECT_EQ(-5, round(-5.499));
+        EXPECT_EQ(-6, round(-5.500));
+    }
+
+    ///////////
+    // mod() //
+    ///////////
+    TEST(mod, ModOperator)
+    {
+        // zero
+        EXPECT_EQ(0,  0 % 10);
+
+        // positive
+        EXPECT_EQ(1,  1 % 10);
+        EXPECT_EQ(5,  5 % 10);
+        EXPECT_EQ(9,  9 % 10);
+        EXPECT_EQ(0, 10 % 10);
+        EXPECT_EQ(5, 15 % 10);
+
+        // negative
+        EXPECT_EQ(-1,  -1 % 10);
+        EXPECT_EQ(-5,  -5 % 10);
+        EXPECT_EQ(-9,  -9 % 10);
+        EXPECT_EQ( 0, -10 % 10);
+        EXPECT_EQ(-5, -15 % 10);
+    }
+
+    TEST(mod, ModFunction)
+    {
+        // zero
+        EXPECT_EQ(0,  mod(0, 10));
+
+        // positive
+        EXPECT_EQ(1, mod( 1, 10));
+        EXPECT_EQ(5, mod( 5, 10));
+        EXPECT_EQ(9, mod( 9, 10));
+        EXPECT_EQ(0, mod(10, 10));
+        EXPECT_EQ(5, mod(15, 10));
+
+        // negative
+        EXPECT_EQ(9, mod( -1, 10));
+        EXPECT_EQ(5, mod( -5, 10));
+        EXPECT_EQ(1, mod( -9, 10));
+        EXPECT_EQ(0, mod(-10, 10));
+        EXPECT_EQ(5, mod(-15, 10));
+    }
+
+    ///////////////
+    // zeroise() //
+    ///////////////
+    TEST(zeroise, Test)
+    {
+        EXPECT_EQ(0, zeroise<int>());
+        EXPECT_EQ((unsigned int)0, zeroise<unsigned int>());
+        EXPECT_DOUBLE_EQ(0.0, zeroise<double>());
+        EXPECT_EQ("", zeroise<std::string>());
+//        EXPECT_EQ(Vector3::ZERO, zeroise<Vector3>());
+    }
+
+    ///////////////////
+    // interpolate() //
+    ///////////////////
+    TEST(interpolate, Linear)
+    {
+        EXPECT_EQ( 0, interpolate(0.00f, 0, 20));
+        EXPECT_EQ( 5, interpolate(0.25f, 0, 20));
+        EXPECT_EQ(10, interpolate(0.50f, 0, 20));
+        EXPECT_EQ(15, interpolate(0.75f, 0, 20));
+        EXPECT_EQ(20, interpolate(1.00f, 0, 20));
+    }
+
+    TEST(interpolate, Smooth)
+    {
+        EXPECT_EQ( 0, interpolateSmooth(0.00f, 0, 20));
+        EXPECT_GT( 5, interpolateSmooth(0.25f, 0, 20));
+        EXPECT_EQ(10, interpolateSmooth(0.50f, 0, 20));
+        EXPECT_LT(15, interpolateSmooth(0.75f, 0, 20));
+        EXPECT_EQ(20, interpolateSmooth(1.00f, 0, 20));
+    }
+
+    ///////////
+    // rnd() //
+    ///////////
+    TEST(rnd, Default)
+    {
+        // how to test randomness?
+        std::set<float> numbers;
+
+        const float max = 1.0;
+        const float min = 0.0;
+        const size_t iterations = 1000;
+
+        for (size_t i = 0; i < iterations; ++i)
+            numbers.insert(rnd());
+
+        // must have at most <iterations> numbers in the set
+        EXPECT_GE(iterations, numbers.size());
+
+        // all numbers must satisfy 0 <= <number> < 1
+        for (std::set<float>::iterator it = numbers.begin(); it != numbers.end(); ++it)
+        {
+            EXPECT_LE(min, *it);
+            EXPECT_GT(max, *it);
+        }
+    }
+
+    TEST(rnd, Max)
+    {
+        // how to test randomness?
+        std::set<float> numbers;
+
+        const float max = 10.0;
+        const float min = 0.0;
+        const size_t iterations = 1000;
+
+        for (size_t i = 0; i < iterations; ++i)
+            numbers.insert(rnd(max));
+
+        // must have at most <iterations> numbers in the set
+        EXPECT_GE(iterations, numbers.size());
+
+        // all numbers must satisfy 0 <= <number> < <max>
+        for (std::set<float>::iterator it = numbers.begin(); it != numbers.end(); ++it)
+        {
+            EXPECT_LE(min, *it);
+            EXPECT_GT(max, *it);
+        }
+    }
+
+    TEST(rnd, MinMax)
+    {
+        // how to test randomness?
+        std::set<float> numbers;
+
+        const float max = 10.0;
+        const float min = 5.0;
+        const size_t iterations = 1000;
+
+        for (size_t i = 0; i < iterations; ++i)
+            numbers.insert(rnd(min, max));
+
+        // must have at most <iterations> numbers in the set
+        EXPECT_GE(iterations, numbers.size());
+
+        // all numbers must satisfy <min> <= <number> < <max>
+        for (std::set<float>::iterator it = numbers.begin(); it != numbers.end(); ++it)
+        {
+            EXPECT_LE(min, *it);
+            EXPECT_GT(max, *it);
+        }
+    }
+
+    //////////////
+    // rndsgn() //
+    //////////////
+    TEST(rndsgn, Test)
+    {
+        // how to test randomness?
+        std::set<float> numbers;
+
+        const size_t iterations = 100;
+
+        for (size_t i = 0; i < iterations; ++i)
+            numbers.insert(rndsgn());
+
+        // must have at most 2 numbers in the set
+        EXPECT_GE((size_t)2, numbers.size());
+
+        // all numbers must be either 1 oder -1
+        for (std::set<float>::iterator it = numbers.begin(); it != numbers.end(); ++it)
+            EXPECT_TRUE(*it == 1 || *it == -1);
+    }
+
+    ///////////////////////
+    // getUniqueNumber() //
+    ///////////////////////
+    TEST(getUniqueNumber, Test)
+    {
+        std::set<float> numbers;
+
+        const size_t iterations = 1000;
+
+        for (size_t i = 0; i < iterations; ++i)
+            numbers.insert(getUniqueNumber());
+
+        // must have exactly <iterations> numbers in the set, since all numbers should be unique
+        EXPECT_EQ(iterations, numbers.size());
+    }
+/*
+    getAngle
+    get2DViewdirection
+    get2DViewcoordinates
+    getPredictedPosition
+*/
+}




More information about the Orxonox-commit mailing list