diff --git a/CMakeLists.txt b/CMakeLists.txt index c80f1d6f13..96655a3af7 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -333,8 +333,9 @@ endif() include(FindGTest OPTIONAL) if(GTEST_FOUND) + enable_testing() include_directories(${GTEST_INCLUDE_DIRS}) - message("GTest found, unit tests can be compiled and ran with 'ctest'") + message("GTest found, unit tests can be compiled and ran with 'make unittests'") else() message("GTest NOT found, disabling unit tests") endif(GTEST_FOUND) diff --git a/Source/CMakeLists.txt b/Source/CMakeLists.txt index 458487257d..825f88fc5d 100644 --- a/Source/CMakeLists.txt +++ b/Source/CMakeLists.txt @@ -52,6 +52,9 @@ if (DSPTOOL) add_subdirectory(DSPTool) endif() +if (GTEST_FOUND) + add_subdirectory(UnitTests) +endif() diff --git a/Source/UnitTests/CMakeLists.txt b/Source/UnitTests/CMakeLists.txt new file mode 100644 index 0000000000..9b7338532c --- /dev/null +++ b/Source/UnitTests/CMakeLists.txt @@ -0,0 +1,11 @@ +add_custom_target(unittests) +add_custom_command(TARGET unittests POST_BUILD COMMAND ${CMAKE_CTEST_COMMAND}) + +macro(add_dolphin_test target srcs libs) + add_executable(Tests/${target} EXCLUDE_FROM_ALL ${srcs}) + target_link_libraries(Tests/${target} ${libs} ${GTEST_BOTH_LIBRARIES}) + add_dependencies(unittests Tests/${target}) + add_test(NAME ${target} COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/Tests/${target}) +endmacro(add_dolphin_test) + +add_subdirectory(Core) diff --git a/Source/UnitTests/Core/CMakeLists.txt b/Source/UnitTests/Core/CMakeLists.txt new file mode 100644 index 0000000000..e52290e387 --- /dev/null +++ b/Source/UnitTests/Core/CMakeLists.txt @@ -0,0 +1 @@ +add_dolphin_test(MMIOTest MMIOTest.cpp core) diff --git a/Source/UnitTests/Core/MMIOTest.cpp b/Source/UnitTests/Core/MMIOTest.cpp new file mode 100644 index 0000000000..97cabda658 --- /dev/null +++ b/Source/UnitTests/Core/MMIOTest.cpp @@ -0,0 +1,24 @@ +#include +#include + +#include "Common/CommonTypes.h" +#include "Core/HW/MMIO.h" + +// Tests that the UniqueID function returns a "unique enough" identifier +// number: that is, it is unique in the address ranges we care about. +TEST(UniqueID, UniqueEnough) +{ + std::unordered_set ids; + for (u32 i = 0xCC000000; i < 0xCC010000; ++i) + { + u32 unique_id = MMIO::UniqueID(i); + EXPECT_EQ(ids.end(), ids.find(unique_id)); + ids.insert(unique_id); + } + for (u32 i = 0xCD000000; i < 0xCD010000; ++i) + { + u32 unique_id = MMIO::UniqueID(i); + EXPECT_EQ(ids.end(), ids.find(unique_id)); + ids.insert(unique_id); + } +}