diff options
author | Gordon Sim <gsim@apache.org> | 2007-07-19 10:59:58 +0000 |
---|---|---|
committer | Gordon Sim <gsim@apache.org> | 2007-07-19 10:59:58 +0000 |
commit | ce54cfd7fb654c1fe36b8f3dcbc85feae7f21a16 (patch) | |
tree | b3e758b7f833000a50623b47e2d26eb810348993 | |
parent | 1f4463ff0c56261e2ee7f5a163ba2ba8ced80793 (diff) | |
download | qpid-python-ce54cfd7fb654c1fe36b8f3dcbc85feae7f21a16.tar.gz |
Added difference operator to the sequence number
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk@557570 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r-- | qpid/cpp/src/qpid/framing/SequenceNumber.cpp | 11 | ||||
-rw-r--r-- | qpid/cpp/src/qpid/framing/SequenceNumber.h | 3 | ||||
-rw-r--r-- | qpid/cpp/src/tests/SequenceNumberTest.cpp | 74 |
3 files changed, 83 insertions, 5 deletions
diff --git a/qpid/cpp/src/qpid/framing/SequenceNumber.cpp b/qpid/cpp/src/qpid/framing/SequenceNumber.cpp index 9bba67d4ae..ea1a34b1cf 100644 --- a/qpid/cpp/src/qpid/framing/SequenceNumber.cpp +++ b/qpid/cpp/src/qpid/framing/SequenceNumber.cpp @@ -60,3 +60,14 @@ bool SequenceNumber::operator>(const SequenceNumber& other) const { return other < *this; } + +namespace qpid { +namespace framing { + +int32_t operator-(const SequenceNumber& a, const SequenceNumber& b) +{ + int32_t result = a.value - b.value; + return result; +} + +}} diff --git a/qpid/cpp/src/qpid/framing/SequenceNumber.h b/qpid/cpp/src/qpid/framing/SequenceNumber.h index 6d38084a25..bf9d133cef 100644 --- a/qpid/cpp/src/qpid/framing/SequenceNumber.h +++ b/qpid/cpp/src/qpid/framing/SequenceNumber.h @@ -32,6 +32,7 @@ namespace framing { class SequenceNumber { int32_t value; + public: SequenceNumber(); SequenceNumber(uint32_t v); @@ -43,6 +44,8 @@ class SequenceNumber bool operator<(const SequenceNumber& other) const; bool operator>(const SequenceNumber& other) const; uint32_t getValue() const { return (uint32_t) value; } + + friend int32_t operator-(const SequenceNumber& a, const SequenceNumber& b); }; }} // namespace qpid::framing diff --git a/qpid/cpp/src/tests/SequenceNumberTest.cpp b/qpid/cpp/src/tests/SequenceNumberTest.cpp index f42ccfc061..941eb9bf2e 100644 --- a/qpid/cpp/src/tests/SequenceNumberTest.cpp +++ b/qpid/cpp/src/tests/SequenceNumberTest.cpp @@ -31,6 +31,9 @@ class SequenceNumberTest : public CppUnit::TestCase CPPUNIT_TEST(testIncrementPostfix); CPPUNIT_TEST(testIncrementPrefix); CPPUNIT_TEST(testWrapAround); + CPPUNIT_TEST(testDifference); + CPPUNIT_TEST(testDifferenceWithWrapAround1); + CPPUNIT_TEST(testDifferenceWithWrapAround2); CPPUNIT_TEST_SUITE_END(); public: @@ -83,24 +86,85 @@ class SequenceNumberTest : public CppUnit::TestCase const uint32_t max = 0xFFFFFFFF; SequenceNumber a(max - 10); SequenceNumber b(max - 5); + checkComparison(a, b, 5); + const uint32_t max_signed = 0x7FFFFFFF; + SequenceNumber c(max_signed - 10); + SequenceNumber d(max_signed - 5); + checkComparison(c, d, 5); + } + + void checkComparison(SequenceNumber& a, SequenceNumber& b, int gap) + { //increment until b wraps around - for (int i = 0; i < 6; i++) { + for (int i = 0; i < (gap + 2); i++) { CPPUNIT_ASSERT(++a < ++b);//test prefix } - //verify we have wrapped around - CPPUNIT_ASSERT(a.getValue() > b.getValue()); //keep incrementing until a also wraps around - for (int i = 0; i < 6; i++) { + for (int i = 0; i < (gap + 2); i++) { CPPUNIT_ASSERT(a++ < b++);//test postfix } //let a 'catch up' - for (int i = 0; i < 5; i++) { + for (int i = 0; i < gap; i++) { a++; } CPPUNIT_ASSERT(a == b); CPPUNIT_ASSERT(++a > b); } + + void testDifference() + { + SequenceNumber a; + SequenceNumber b; + + for (int i = 0; i < 10; i++, ++a) { + CPPUNIT_ASSERT_EQUAL(i, a - b); + CPPUNIT_ASSERT_EQUAL(-i, b - a); + } + + b = a; + + for (int i = 0; i < 10; i++, ++b) { + CPPUNIT_ASSERT_EQUAL(-i, a - b); + CPPUNIT_ASSERT_EQUAL(i, b - a); + } + } + + void testDifferenceWithWrapAround1() + { + const uint32_t max = 0xFFFFFFFF; + SequenceNumber a(max - 5); + SequenceNumber b(max - 10); + checkDifference(a, b, 5); + } + + void testDifferenceWithWrapAround2() + { + const uint32_t max_signed = 0x7FFFFFFF; + SequenceNumber c(max_signed - 5); + SequenceNumber d(max_signed - 10); + checkDifference(c, d, 5); + } + + void checkDifference(SequenceNumber& a, SequenceNumber& b, int gap) + { + CPPUNIT_ASSERT_EQUAL(gap, a - b); + CPPUNIT_ASSERT_EQUAL(-gap, b - a); + + //increment until b wraps around + for (int i = 0; i < (gap + 2); i++, ++a, ++b) { + CPPUNIT_ASSERT_EQUAL(gap, a - b); + } + //keep incrementing until a also wraps around + for (int i = 0; i < (gap + 2); i++, ++a, ++b) { + CPPUNIT_ASSERT_EQUAL(gap, a - b); + } + //let b catch up and overtake + for (int i = 0; i < (gap*2); i++, ++b) { + CPPUNIT_ASSERT_EQUAL(gap - i, a - b); + CPPUNIT_ASSERT_EQUAL(i - gap, b - a); + } + } }; // Make this test suite a plugin. |