#include #include "common/rect.h" class RectTestSuite : public CxxTest::TestSuite { public: void test_point_sqrDist() { Common::Point p0; Common::Point p11(1, 1); Common::Point p21(2, 1); Common::Point p23(2, 3); Common::Point p32(3, 2); TS_ASSERT_EQUALS(p0.sqrDist(p11), (uint) 2); TS_ASSERT_EQUALS(p0.sqrDist(p21), (uint) 5); TS_ASSERT_EQUALS(p0.sqrDist(p23), p0.sqrDist(p32)); TS_ASSERT_EQUALS(p11.sqrDist(p11), (uint) 0); TS_ASSERT_EQUALS(p11.sqrDist(p23), (uint) 5); } void test_intersects() { TS_ASSERT(Common::Rect(0, 0, 2, 2).intersects(Common::Rect(0, 0, 1, 1))); TS_ASSERT(Common::Rect(0, 0, 2, 2).intersects(Common::Rect(1, 1, 2, 2))); TS_ASSERT(!Common::Rect(0, 0, 1, 1).intersects(Common::Rect(1, 1, 2, 2))); } void test_contains() { Common::Rect r0; Common::Rect r1(0, 0, 1, 1); Common::Rect r2(0, 0, 2, 2); TS_ASSERT(!r0.contains(r1)); TS_ASSERT(!r0.contains(r2)); TS_ASSERT(!r1.contains(r2)); TS_ASSERT(r0.contains(r0)); TS_ASSERT(r1.contains(r0)); TS_ASSERT(r1.contains(r1)); TS_ASSERT(r2.contains(r0)); TS_ASSERT(r2.contains(r1)); TS_ASSERT(r2.contains(r2)); } void test_extend() { Common::Rect r0; Common::Rect r1(0, 0, 1, 1); Common::Rect r2(0, 0, 2, 2); TS_ASSERT(!r0.contains(r1)); r0.extend(r1); TS_ASSERT(r0.contains(r1)); TS_ASSERT_EQUALS(r0.top, 0); TS_ASSERT_EQUALS(r0.left, 0); TS_ASSERT_EQUALS(r0.bottom, 1); TS_ASSERT_EQUALS(r0.right, 1); r2.extend(r1); TS_ASSERT_EQUALS(r2.top, 0); TS_ASSERT_EQUALS(r2.left, 0); TS_ASSERT_EQUALS(r2.bottom, 2); TS_ASSERT_EQUALS(r2.right, 2); } };