You can clone with HTTPS or Subversion.
Merge pull request #146 from delroth/tests
Add more tests for Common and Core/MMIO
Showing 7 changed files with 240 additions and 0 deletions. Show Diff Stats Hide Diff Stats
@@ -8,4 +8,5 @@ macro(add_dolphin_test target srcs libs)
add_test(NAME ${target} COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/Tests/${target})
endmacro(add_dolphin_test)
+add_subdirectory(Common)
add_subdirectory(Core)
@@ -0,0 +1,4 @@
+add_dolphin_test(CommonFuncsTest CommonFuncsTest.cpp common)
+add_dolphin_test(FifoQueueTest FifoQueueTest.cpp common)
+add_dolphin_test(FixedSizeQueueTest FixedSizeQueueTest.cpp common)
+add_dolphin_test(MathUtilTest MathUtilTest.cpp common)
@@ -0,0 +1,46 @@
+// Copyright 2014 Dolphin Emulator Project
+// Licensed under GPLv2
+// Refer to the license.txt file included.
+
+#include <gtest/gtest.h>
+#include "Common/CommonFuncs.h"
+TEST(CommonFuncs, ArraySizeMacro)
+{
+ char test[4];
+ u32 test2[42];
+ EXPECT_EQ(4, ArraySize(test));
+ EXPECT_EQ(42, ArraySize(test2));
+}
+TEST(CommonFuncs, RoundUpPow2Macro)
+ EXPECT_EQ(4, ROUND_UP_POW2(3));
+ EXPECT_EQ(4, ROUND_UP_POW2(4));
+ EXPECT_EQ(8, ROUND_UP_POW2(6));
+ EXPECT_EQ(0x40000000, ROUND_UP_POW2(0x23456789));
+TEST(CommonFuncs, CrashMacro)
+ EXPECT_DEATH({ Crash(); }, "");
+TEST(CommonFuncs, MinMax)
+ EXPECT_EQ(4, min(4, 5));
+ EXPECT_EQ(-1, min(-1, 1));
+ EXPECT_EQ(5, max(4, 5));
+ EXPECT_EQ(1, max(-1, 1));
+TEST(CommonFuncs, Swap)
+ EXPECT_EQ(0xf0, Common::swap8(0xf0));
+ EXPECT_EQ(0x1234, Common::swap16(0x3412));
+ EXPECT_EQ(0x12345678, Common::swap32(0x78563412));
+ EXPECT_EQ(0x123456789abcdef0ull, Common::swap64(0xf0debc9a78563412ull));
@@ -0,0 +1,67 @@
+#include <thread>
+#include "Common/FifoQueue.h"
+TEST(FifoQueue, Simple)
+ Common::FifoQueue<u32> q;
+ EXPECT_EQ(0, q.Size());
+ EXPECT_TRUE(q.Empty());
+ q.Push(1);
+ EXPECT_EQ(1, q.Size());
+ EXPECT_FALSE(q.Empty());
+ u32 v; q.Pop(v);
+ EXPECT_EQ(1, v);
+ // Test the FIFO order.
+ for (u32 i = 0; i < 1000; ++i)
+ q.Push(i);
+ EXPECT_EQ(1000, q.Size());
+ {
+ u32 v2; q.Pop(v2);
+ EXPECT_EQ(i, v2);
+ }
+ q.Clear();
+TEST(FifoQueue, MultiThreaded)
+ auto inserter = [&q]() {
+ for (u32 i = 0; i < 100000; ++i)
+ };
+ auto popper = [&q]() {
+ while (q.Empty());
+ EXPECT_EQ(i, v);
+ std::thread popper_thread(popper);
+ std::thread inserter_thread(inserter);
+ popper_thread.join();
+ inserter_thread.join();
@@ -0,0 +1,33 @@
+#include "Common/FixedSizeQueue.h"
+TEST(FixedSizeQueue, Simple)
+ FixedSizeQueue<int, 5> q;
+ EXPECT_EQ(0, q.size());
+ q.push(0);
+ q.push(1);
+ q.push(2);
+ q.push(3);
+ q.push(4);
+ for (int i = 0; i < 1000; ++i)
+ EXPECT_EQ(i, q.front());
+ EXPECT_EQ(i, q.pop_front());
+ q.push(i + 5);
+ EXPECT_EQ(1000, q.pop_front());
+ EXPECT_EQ(1001, q.pop_front());
+ EXPECT_EQ(1002, q.pop_front());
+ EXPECT_EQ(1003, q.pop_front());
+ EXPECT_EQ(1004, q.pop_front());
@@ -0,0 +1,56 @@
+#include <cmath>
+#include "Common/MathUtil.h"
+template <typename T>
+T ClampAndReturn(const T& val, const T& min, const T& max)
+ T ret = val;
+ MathUtil::Clamp(&ret, min, max);
+ return ret;
+TEST(MathUtil, Clamp)
+ EXPECT_EQ(1, ClampAndReturn(1, 0, 2));
+ EXPECT_EQ(1.0, ClampAndReturn(1.0, 0.0, 2.0));
+ EXPECT_EQ(2, ClampAndReturn(4, 0, 2));
+ EXPECT_EQ(2.0, ClampAndReturn(4.0, 0.0, 2.0));
+ EXPECT_EQ(0, ClampAndReturn(-1, 0, 2));
+ EXPECT_EQ(0.0, ClampAndReturn(-1.0, 0.0, 2.0));
+TEST(MathUtil, IsNAN)
+ EXPECT_TRUE(MathUtil::IsNAN(nan("")));
+TEST(MathUtil, IsQNAN)
+ // TODO
+TEST(MathUtil, IsSNAN)
+TEST(MathUtil, Log2)
+ EXPECT_EQ(0, Log2(1));
+ EXPECT_EQ(1, Log2(2));
+ EXPECT_EQ(2, Log2(4));
+ EXPECT_EQ(3, Log2(8));
+ EXPECT_EQ(63, Log2(0x8000000000000000ull));
+ // Rounding behavior.
+ EXPECT_EQ(3, Log2(15));
+ EXPECT_EQ(63, Log2(0xFFFFFFFFFFFFFFFFull));
@@ -23,6 +23,15 @@
}
+TEST(IsMMIOAddress, SpecialAddresses)
+ // WG Pipe address, should not be handled by MMIO.
+ EXPECT_FALSE(MMIO::IsMMIOAddress(0xCC008000));
+ // Memory zone used by games using the "MMU Speedhack".
+ EXPECT_FALSE(MMIO::IsMMIOAddress(0xE0000000));
class MappingTest : public testing::Test
{
protected:
@@ -75,3 +84,27 @@ class MappingTest : public testing::Test
val32 += 1; m_mapping->Write(0xCC001234, val32);
+TEST_F(MappingTest, ReadWriteComplex)
+ bool read_called = false, write_called = false;
+ m_mapping->Register(0xCC001234,
+ MMIO::ComplexRead<u8>([&read_called](u32 addr) {
+ EXPECT_EQ(0xCC001234, addr);
+ read_called = true;
+ return 0x12;
+ }),
+ MMIO::ComplexWrite<u8>([&write_called](u32 addr, u8 val) {
+ EXPECT_EQ(0x34, val);
+ write_called = true;
+ })
+ );
+ u8 val; m_mapping->Read(0xCC001234, &val); EXPECT_EQ(0x12, val);
+ m_mapping->Write(0xCC001234, (u8)0x34);
+ EXPECT_TRUE(read_called);
+ EXPECT_TRUE(write_called);
b003fd7
add_test(NAME ${target} COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/Tests/${target})+{+{+{+ EXPECT_DEATH({ Crash(); }, "");+{+{+{+ {+{+ auto inserter = [&q]() {+ auto popper = [&q]() {+ {+{+ {+{+{+{+ EXPECT_TRUE(MathUtil::IsNAN(nan("")));+{+{+{+{{+{+ MMIO::ComplexRead<u8>([&read_called](u32 addr) {+ MMIO::ComplexWrite<u8>([&write_called](u32 addr, u8 val) {