summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGordon Sim <gsim@apache.org>2007-07-19 10:59:58 +0000
committerGordon Sim <gsim@apache.org>2007-07-19 10:59:58 +0000
commitce54cfd7fb654c1fe36b8f3dcbc85feae7f21a16 (patch)
treeb3e758b7f833000a50623b47e2d26eb810348993
parent1f4463ff0c56261e2ee7f5a163ba2ba8ced80793 (diff)
downloadqpid-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.cpp11
-rw-r--r--qpid/cpp/src/qpid/framing/SequenceNumber.h3
-rw-r--r--qpid/cpp/src/tests/SequenceNumberTest.cpp74
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.