summaryrefslogtreecommitdiff
path: root/cpp/src/tests/SequenceSet.cpp
diff options
context:
space:
mode:
authorGordon Sim <gsim@apache.org>2008-03-03 17:55:21 +0000
committerGordon Sim <gsim@apache.org>2008-03-03 17:55:21 +0000
commita711889b0b3c16d7bffe008ece53cd41d5069909 (patch)
treec30de08bc1c5145416d4bab561f3a0dcb632312d /cpp/src/tests/SequenceSet.cpp
parentb09b179dd7bc5537373b063ee943411de6e52967 (diff)
downloadqpid-python-a711889b0b3c16d7bffe008ece53cd41d5069909.tar.gz
Fixed consolidation of ranges and added further validation to tests.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@633206 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/tests/SequenceSet.cpp')
-rw-r--r--cpp/src/tests/SequenceSet.cpp54
1 files changed, 50 insertions, 4 deletions
diff --git a/cpp/src/tests/SequenceSet.cpp b/cpp/src/tests/SequenceSet.cpp
index bffeed648e..c98b02b4b7 100644
--- a/cpp/src/tests/SequenceSet.cpp
+++ b/cpp/src/tests/SequenceSet.cpp
@@ -23,23 +23,55 @@ QPID_AUTO_TEST_SUITE(SequenceSetTestSuite)
using namespace qpid::framing;
+struct RangeExpectations
+{
+ typedef std::pair<SequenceNumber, SequenceNumber> Range;
+ typedef std::list<Range> Ranges;
+
+ Ranges ranges;
+
+ RangeExpectations& expect(const SequenceNumber& start, const SequenceNumber& end) {
+ ranges.push_back(Range(start, end));
+ return *this;
+ }
+
+ void operator()(const SequenceNumber& start, const SequenceNumber& end) {
+ BOOST_CHECK(!ranges.empty());
+ if (!ranges.empty()) {
+ BOOST_CHECK_EQUAL(start, ranges.front().first);
+ BOOST_CHECK_EQUAL(end, ranges.front().second);
+ ranges.pop_front();
+ }
+ }
+
+ void check(SequenceSet& set) {
+ set.for_each(*this);
+ BOOST_CHECK(ranges.empty());
+ }
+};
+
BOOST_AUTO_TEST_CASE(testAdd) {
SequenceSet s;
s.add(2);
s.add(8,8);
s.add(3,5);
- for (uint32_t i = 0; i <= 1; i++) //0, 1
+ for (uint32_t i = 0; i <= 1; i++)
BOOST_CHECK(!s.contains(i));
- for (uint32_t i = 2; i <= 5; i++) //2, 3, 4 & 5
+ for (uint32_t i = 2; i <= 5; i++)
BOOST_CHECK(s.contains(i));
- for (uint32_t i = 0; i <= 1; i++) //6, 7
+ for (uint32_t i = 6; i <= 7; i++)
BOOST_CHECK(!s.contains(i));
- BOOST_CHECK(s.contains(8));//8
+ BOOST_CHECK(s.contains(8));
+
+ for (uint32_t i = 9; i <= 10; i++)
+ BOOST_CHECK(!s.contains(i));
+ RangeExpectations().expect(2, 5).expect(8, 8).check(s);
+
SequenceSet t;
t.add(6, 10);
t.add(s);
@@ -49,6 +81,17 @@ BOOST_AUTO_TEST_CASE(testAdd) {
for (uint32_t i = 2; i <= 10; i++)
BOOST_CHECK(t.contains(i));
+
+ RangeExpectations().expect(2, 10).check(t);
+}
+
+BOOST_AUTO_TEST_CASE(testAdd2) {
+ SequenceSet s;
+ s.add(7,6);
+ s.add(4,4);
+ s.add(3,10);
+ s.add(2);
+ RangeExpectations().expect(2, 10).check(s);
}
BOOST_AUTO_TEST_CASE(testRemove) {
@@ -86,6 +129,9 @@ BOOST_AUTO_TEST_CASE(testRemove) {
BOOST_CHECK(!s.contains(i));
BOOST_CHECK(t.contains(i));
}
+
+ RangeExpectations().expect(0, 2).expect(6, 6).expect(8, 8).check(s);
+ RangeExpectations().expect(3, 5).expect(7, 7).expect(9, 10).check(t);
}
QPID_AUTO_TEST_SUITE_END()