summaryrefslogtreecommitdiff
path: root/cpp/src/tests/SequenceNumberTest.cpp
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
commit888c0bfbb1731124e1c84775400fcdad7798920e (patch)
tree6b560e8167b84976971d77a3bf87cf2e5553f0f8 /cpp/src/tests/SequenceNumberTest.cpp
parentb87a1e9d27755e2f98792567c29a0625b92c8654 (diff)
downloadqpid-python-888c0bfbb1731124e1c84775400fcdad7798920e.tar.gz
Added difference operator to the sequence number
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@557570 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/tests/SequenceNumberTest.cpp')
-rw-r--r--cpp/src/tests/SequenceNumberTest.cpp74
1 files changed, 69 insertions, 5 deletions
diff --git a/cpp/src/tests/SequenceNumberTest.cpp b/cpp/src/tests/SequenceNumberTest.cpp
index f42ccfc061..941eb9bf2e 100644
--- a/cpp/src/tests/SequenceNumberTest.cpp
+++ b/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.