summaryrefslogtreecommitdiff
path: root/qpid/cpp/src/tests/Cluster.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'qpid/cpp/src/tests/Cluster.cpp')
-rw-r--r--qpid/cpp/src/tests/Cluster.cpp72
1 files changed, 72 insertions, 0 deletions
diff --git a/qpid/cpp/src/tests/Cluster.cpp b/qpid/cpp/src/tests/Cluster.cpp
new file mode 100644
index 0000000000..ed50cc5d7b
--- /dev/null
+++ b/qpid/cpp/src/tests/Cluster.cpp
@@ -0,0 +1,72 @@
+/*
+ *
+ * Copyright (c) 2006 The Apache Software Foundation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#define BOOST_AUTO_TEST_MAIN // Must come before #include<boost/test/*>
+#include <boost/test/auto_unit_test.hpp>
+#include "test_tools.h"
+#include "Cluster.h"
+#include "qpid/framing/ChannelOkBody.h"
+#include "qpid/framing/BasicGetOkBody.h"
+
+
+
+static const ProtocolVersion VER;
+
+/** Verify membership ind a cluster with one member. */
+BOOST_AUTO_TEST_CASE(clusterOne) {
+ VectorFrameHandler received;
+ Cluster cluster("Test", "amqp:one:1", received, VER);
+ AMQFrame frame(VER, 1, new ChannelOkBody(VER));
+
+ cluster.handle(frame);
+ BOOST_REQUIRE(received.waitFor(1));
+ BOOST_CHECK_EQUAL(1u, cluster.size());
+ Cluster::MemberList members = cluster.getMembers();
+ BOOST_CHECK_EQUAL(1u, members.size());
+ BOOST_REQUIRE_EQUAL(members.front()->url, "amqp:one:1");
+ BOOST_CHECK_EQUAL(1u, received.size());
+ BOOST_CHECK_TYPEID_EQUAL(ChannelOkBody, *received[0].getBody());
+}
+
+/** Fork a process to verify membership in a cluster with two members */
+BOOST_AUTO_TEST_CASE(clusterTwo) {
+ VectorFrameHandler received;
+ pid_t pid=fork();
+ BOOST_REQUIRE(pid >= 0);
+ if (pid) { // Parent
+ TestCluster cluster("Test", "amqp::1", received, VER);
+ BOOST_REQUIRE(cluster.waitFor(2));
+
+ // Exchange frames with child.
+ AMQFrame frame(VER, 1, new ChannelOkBody(VER));
+ cluster.handle(frame);
+ BOOST_REQUIRE(received.waitFor(2));
+ BOOST_CHECK_TYPEID_EQUAL(ChannelOkBody, *received[0].getBody());
+ BOOST_CHECK_TYPEID_EQUAL(BasicGetOkBody, *received[1].getBody());
+
+ // Wait for child to exit.
+ int status;
+ BOOST_CHECK_EQUAL(::wait(&status), pid);
+ BOOST_CHECK_EQUAL(0, status);
+ BOOST_CHECK(cluster.waitFor(1));
+ BOOST_CHECK_EQUAL(1u, cluster.size());
+ }
+ else { // Child
+ BOOST_REQUIRE(execl("Cluster_child", "Cluster_child", NULL));
+ }
+}