summaryrefslogtreecommitdiff
path: root/cpp/src/tests/AccumulatedAckTest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/src/tests/AccumulatedAckTest.cpp')
-rw-r--r--cpp/src/tests/AccumulatedAckTest.cpp372
1 files changed, 177 insertions, 195 deletions
diff --git a/cpp/src/tests/AccumulatedAckTest.cpp b/cpp/src/tests/AccumulatedAckTest.cpp
index cbe44e6814..028ce71907 100644
--- a/cpp/src/tests/AccumulatedAckTest.cpp
+++ b/cpp/src/tests/AccumulatedAckTest.cpp
@@ -20,231 +20,213 @@
*
*/
#include "qpid/framing/AccumulatedAck.h"
-#include "qpid_test_plugin.h"
+#include "unit_test.h"
#include <iostream>
#include <list>
using std::list;
using namespace qpid::framing;
-class AccumulatedAckTest : public CppUnit::TestCase
+
+bool covers(const AccumulatedAck& ack, int i)
{
- CPPUNIT_TEST_SUITE(AccumulatedAckTest);
- CPPUNIT_TEST(testGeneral);
- CPPUNIT_TEST(testCovers);
- CPPUNIT_TEST(testUpdateFromCompletionData);
- CPPUNIT_TEST(testCase1);
- CPPUNIT_TEST(testCase2);
- CPPUNIT_TEST(testCase3);
- CPPUNIT_TEST(testCase4);
- CPPUNIT_TEST(testConsolidation1);
- CPPUNIT_TEST(testConsolidation2);
- CPPUNIT_TEST(testConsolidation3);
- CPPUNIT_TEST(testConsolidation4);
- CPPUNIT_TEST_SUITE_END();
-
-public:
- bool covers(const AccumulatedAck& ack, int i)
- {
- return ack.covers(SequenceNumber(i));
- }
+ return ack.covers(SequenceNumber(i));
+}
- void update(AccumulatedAck& ack, int start, int end)
- {
- ack.update(SequenceNumber(start), SequenceNumber(end));
- }
+void update(AccumulatedAck& ack, int start, int end)
+{
+ ack.update(SequenceNumber(start), SequenceNumber(end));
+}
- void testGeneral()
- {
- AccumulatedAck ack(0);
- ack.clear();
- update(ack, 3,3);
- update(ack, 7,7);
- update(ack, 9,9);
- update(ack, 1,2);
- update(ack, 4,5);
- update(ack, 6,6);
+QPID_AUTO_TEST_SUITE(AccumulatedAckTestSuite)
- for(int i = 1; i <= 7; i++) CPPUNIT_ASSERT(covers(ack, i));
- CPPUNIT_ASSERT(covers(ack, 9));
+QPID_AUTO_TEST_CASE(testGeneral)
+{
+ AccumulatedAck ack(0);
+ ack.clear();
+ update(ack, 3,3);
+ update(ack, 7,7);
+ update(ack, 9,9);
+ update(ack, 1,2);
+ update(ack, 4,5);
+ update(ack, 6,6);
- CPPUNIT_ASSERT(!covers(ack, 8));
- CPPUNIT_ASSERT(!covers(ack, 10));
+ for(int i = 1; i <= 7; i++) BOOST_CHECK(covers(ack, i));
+ BOOST_CHECK(covers(ack, 9));
- ack.consolidate();
+ BOOST_CHECK(!covers(ack, 8));
+ BOOST_CHECK(!covers(ack, 10));
- for(int i = 1; i <= 7; i++) CPPUNIT_ASSERT(covers(ack, i));
- CPPUNIT_ASSERT(covers(ack, 9));
+ ack.consolidate();
- CPPUNIT_ASSERT(!covers(ack, 8));
- CPPUNIT_ASSERT(!covers(ack, 10));
- }
+ for(int i = 1; i <= 7; i++) BOOST_CHECK(covers(ack, i));
+ BOOST_CHECK(covers(ack, 9));
- void testCovers()
- {
- AccumulatedAck ack(5);
- update(ack, 7, 7);
- update(ack, 9, 9);
-
- CPPUNIT_ASSERT(covers(ack, 1));
- CPPUNIT_ASSERT(covers(ack, 2));
- CPPUNIT_ASSERT(covers(ack, 3));
- CPPUNIT_ASSERT(covers(ack, 4));
- CPPUNIT_ASSERT(covers(ack, 5));
- CPPUNIT_ASSERT(covers(ack, 7));
- CPPUNIT_ASSERT(covers(ack, 9));
-
- CPPUNIT_ASSERT(!covers(ack, 6));
- CPPUNIT_ASSERT(!covers(ack, 8));
- CPPUNIT_ASSERT(!covers(ack, 10));
- }
+ BOOST_CHECK(!covers(ack, 8));
+ BOOST_CHECK(!covers(ack, 10));
+}
- void testUpdateFromCompletionData()
- {
- AccumulatedAck ack(0);
- SequenceNumber mark(2);
- SequenceNumberSet ranges;
- ranges.addRange(SequenceNumber(5), SequenceNumber(8));
- ranges.addRange(SequenceNumber(10), SequenceNumber(15));
- ranges.addRange(SequenceNumber(9), SequenceNumber(9));
- ranges.addRange(SequenceNumber(3), SequenceNumber(4));
-
- ack.update(mark, ranges);
-
- for(int i = 0; i <= 15; i++) {
- CPPUNIT_ASSERT(covers(ack, i));
- }
- CPPUNIT_ASSERT(!covers(ack, 16));
- CPPUNIT_ASSERT_EQUAL((uint32_t) 15, ack.mark.getValue());
+QPID_AUTO_TEST_CASE(testCovers)
+{
+ AccumulatedAck ack(5);
+ update(ack, 7, 7);
+ update(ack, 9, 9);
+
+ BOOST_CHECK(covers(ack, 1));
+ BOOST_CHECK(covers(ack, 2));
+ BOOST_CHECK(covers(ack, 3));
+ BOOST_CHECK(covers(ack, 4));
+ BOOST_CHECK(covers(ack, 5));
+ BOOST_CHECK(covers(ack, 7));
+ BOOST_CHECK(covers(ack, 9));
+
+ BOOST_CHECK(!covers(ack, 6));
+ BOOST_CHECK(!covers(ack, 8));
+ BOOST_CHECK(!covers(ack, 10));
+}
+
+QPID_AUTO_TEST_CASE(testUpdateFromCompletionData)
+{
+ AccumulatedAck ack(0);
+ SequenceNumber mark(2);
+ SequenceNumberSet ranges;
+ ranges.addRange(SequenceNumber(5), SequenceNumber(8));
+ ranges.addRange(SequenceNumber(10), SequenceNumber(15));
+ ranges.addRange(SequenceNumber(9), SequenceNumber(9));
+ ranges.addRange(SequenceNumber(3), SequenceNumber(4));
+
+ ack.update(mark, ranges);
+
+ for(int i = 0; i <= 15; i++) {
+ BOOST_CHECK(covers(ack, i));
}
+ BOOST_CHECK(!covers(ack, 16));
+ BOOST_CHECK_EQUAL((uint32_t) 15, ack.mark.getValue());
+}
- void testCase1()
- {
- AccumulatedAck ack(3);
- update(ack, 1,2);
- for(int i = 1; i <= 3; i++) CPPUNIT_ASSERT(covers(ack, i));
- CPPUNIT_ASSERT(!covers(ack, 4));
- }
+QPID_AUTO_TEST_CASE(testCase1)
+{
+ AccumulatedAck ack(3);
+ update(ack, 1,2);
+ for(int i = 1; i <= 3; i++) BOOST_CHECK(covers(ack, i));
+ BOOST_CHECK(!covers(ack, 4));
+}
- void testCase2()
- {
- AccumulatedAck ack(3);
- update(ack, 3,6);
- for(int i = 1; i <= 6; i++) CPPUNIT_ASSERT(covers(ack, i));
- CPPUNIT_ASSERT(!covers(ack, 7));
- }
+QPID_AUTO_TEST_CASE(testCase2)
+{
+ AccumulatedAck ack(3);
+ update(ack, 3,6);
+ for(int i = 1; i <= 6; i++) BOOST_CHECK(covers(ack, i));
+ BOOST_CHECK(!covers(ack, 7));
+}
- void testCase3()
- {
- AccumulatedAck ack(3);
- update(ack, 4,6);
- for(int i = 1; i <= 6; i++) {
- CPPUNIT_ASSERT(covers(ack, i));
- }
- CPPUNIT_ASSERT(!covers(ack, 7));
+QPID_AUTO_TEST_CASE(testCase3)
+{
+ AccumulatedAck ack(3);
+ update(ack, 4,6);
+ for(int i = 1; i <= 6; i++) {
+ BOOST_CHECK(covers(ack, i));
}
+ BOOST_CHECK(!covers(ack, 7));
+}
- void testCase4()
- {
- AccumulatedAck ack(3);
- update(ack, 5,6);
- for(int i = 1; i <= 6; i++) {
- if (i == 4) CPPUNIT_ASSERT(!covers(ack, i));
- else CPPUNIT_ASSERT(covers(ack, i));
- }
- CPPUNIT_ASSERT(!covers(ack, 7));
+QPID_AUTO_TEST_CASE(testCase4)
+{
+ AccumulatedAck ack(3);
+ update(ack, 5,6);
+ for(int i = 1; i <= 6; i++) {
+ if (i == 4) BOOST_CHECK(!covers(ack, i));
+ else BOOST_CHECK(covers(ack, i));
}
+ BOOST_CHECK(!covers(ack, 7));
+}
- void testConsolidation1()
- {
- AccumulatedAck ack(3);
- update(ack, 7,7);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 3, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 1, ack.ranges.size());
-
- update(ack, 8,9);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 3, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 1, ack.ranges.size());
-
- update(ack, 1,2);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 3, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 1, ack.ranges.size());
+QPID_AUTO_TEST_CASE(testConsolidation1)
+{
+ AccumulatedAck ack(3);
+ update(ack, 7,7);
+ BOOST_CHECK_EQUAL((uint32_t) 3, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 1, ack.ranges.size());
- update(ack, 4,5);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 5, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 1, ack.ranges.size());
+ update(ack, 8,9);
+ BOOST_CHECK_EQUAL((uint32_t) 3, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 1, ack.ranges.size());
- update(ack, 6,6);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 9, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 0, ack.ranges.size());
+ update(ack, 1,2);
+ BOOST_CHECK_EQUAL((uint32_t) 3, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 1, ack.ranges.size());
- for(int i = 1; i <= 9; i++) CPPUNIT_ASSERT(covers(ack, i));
- CPPUNIT_ASSERT(!covers(ack, 10));
- }
+ update(ack, 4,5);
+ BOOST_CHECK_EQUAL((uint32_t) 5, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 1, ack.ranges.size());
- void testConsolidation2()
- {
- AccumulatedAck ack(0);
- update(ack, 10,12);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 0, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 1, ack.ranges.size());
-
- update(ack, 7,9);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 0, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 1, ack.ranges.size());
- CPPUNIT_ASSERT_EQUAL((uint32_t) 7, ack.ranges.front().start.getValue());
- CPPUNIT_ASSERT_EQUAL((uint32_t) 12, ack.ranges.front().end.getValue());
-
- update(ack, 5,7);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 0, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 1, ack.ranges.size());
- CPPUNIT_ASSERT_EQUAL((uint32_t) 5, ack.ranges.front().start.getValue());
- CPPUNIT_ASSERT_EQUAL((uint32_t) 12, ack.ranges.front().end.getValue());
-
- update(ack, 3,4);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 0, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 1, ack.ranges.size());
- CPPUNIT_ASSERT_EQUAL((uint32_t) 3, ack.ranges.front().start.getValue());
- CPPUNIT_ASSERT_EQUAL((uint32_t) 12, ack.ranges.front().end.getValue());
-
- update(ack, 1,2);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 12, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 0, ack.ranges.size());
-
- for(int i = 1; i <= 12; i++) CPPUNIT_ASSERT(covers(ack, i));
- CPPUNIT_ASSERT(!covers(ack, 13));
- }
+ update(ack, 6,6);
+ BOOST_CHECK_EQUAL((uint32_t) 9, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 0, ack.ranges.size());
- void testConsolidation3()
- {
- AccumulatedAck ack(0);
- update(ack, 10,12);
- update(ack, 6,7);
- update(ack, 3,4);
- update(ack, 1,15);
- CPPUNIT_ASSERT_EQUAL((uint32_t) 15, ack.mark.getValue());
- CPPUNIT_ASSERT_EQUAL((size_t) 0, ack.ranges.size());
- }
+ for(int i = 1; i <= 9; i++) BOOST_CHECK(covers(ack, i));
+ BOOST_CHECK(!covers(ack, 10));
+}
- void testConsolidation4()
- {
- AccumulatedAck ack(0);
- ack.update(SequenceNumber(0), SequenceNumber(2));
- ack.update(SequenceNumber(5), SequenceNumber(8));
- ack.update(SequenceNumber(10), SequenceNumber(15));
- ack.update(SequenceNumber(9), SequenceNumber(9));
- ack.update(SequenceNumber(3), SequenceNumber(4));
-
- for(int i = 0; i <= 15; i++) {
- CPPUNIT_ASSERT(covers(ack, i));
- }
- CPPUNIT_ASSERT(!covers(ack, 16));
- CPPUNIT_ASSERT_EQUAL((uint32_t) 15, ack.mark.getValue());
+QPID_AUTO_TEST_CASE(testConsolidation2)
+{
+ AccumulatedAck ack(0);
+ update(ack, 10,12);
+ BOOST_CHECK_EQUAL((uint32_t) 0, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 1, ack.ranges.size());
+
+ update(ack, 7,9);
+ BOOST_CHECK_EQUAL((uint32_t) 0, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 1, ack.ranges.size());
+ BOOST_CHECK_EQUAL((uint32_t) 7, ack.ranges.front().start.getValue());
+ BOOST_CHECK_EQUAL((uint32_t) 12, ack.ranges.front().end.getValue());
+
+ update(ack, 5,7);
+ BOOST_CHECK_EQUAL((uint32_t) 0, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 1, ack.ranges.size());
+ BOOST_CHECK_EQUAL((uint32_t) 5, ack.ranges.front().start.getValue());
+ BOOST_CHECK_EQUAL((uint32_t) 12, ack.ranges.front().end.getValue());
+
+ update(ack, 3,4);
+ BOOST_CHECK_EQUAL((uint32_t) 0, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 1, ack.ranges.size());
+ BOOST_CHECK_EQUAL((uint32_t) 3, ack.ranges.front().start.getValue());
+ BOOST_CHECK_EQUAL((uint32_t) 12, ack.ranges.front().end.getValue());
+
+ update(ack, 1,2);
+ BOOST_CHECK_EQUAL((uint32_t) 12, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 0, ack.ranges.size());
+
+ for(int i = 1; i <= 12; i++) BOOST_CHECK(covers(ack, i));
+ BOOST_CHECK(!covers(ack, 13));
+}
+
+QPID_AUTO_TEST_CASE(testConsolidation3)
+{
+ AccumulatedAck ack(0);
+ update(ack, 10,12);
+ update(ack, 6,7);
+ update(ack, 3,4);
+ update(ack, 1,15);
+ BOOST_CHECK_EQUAL((uint32_t) 15, ack.mark.getValue());
+ BOOST_CHECK_EQUAL((size_t) 0, ack.ranges.size());
+}
+
+QPID_AUTO_TEST_CASE(testConsolidation4)
+{
+ AccumulatedAck ack(0);
+ ack.update(SequenceNumber(0), SequenceNumber(2));
+ ack.update(SequenceNumber(5), SequenceNumber(8));
+ ack.update(SequenceNumber(10), SequenceNumber(15));
+ ack.update(SequenceNumber(9), SequenceNumber(9));
+ ack.update(SequenceNumber(3), SequenceNumber(4));
+
+ for(int i = 0; i <= 15; i++) {
+ BOOST_CHECK(covers(ack, i));
}
+ BOOST_CHECK(!covers(ack, 16));
+ BOOST_CHECK_EQUAL((uint32_t) 15, ack.mark.getValue());
+}
-};
-
-// Make this test suite a plugin.
-CPPUNIT_PLUGIN_IMPLEMENT();
-CPPUNIT_TEST_SUITE_REGISTRATION(AccumulatedAckTest);
+QPID_AUTO_TEST_SUITE_END()