// Copyright (c) 2007-Present Pivotal Software, Inc. All rights reserved.
//
// This software, the RabbitMQ Java client library, is triple-licensed under the
// Mozilla Public License 1.1 ("MPL"), the GNU General Public License version 2
// ("GPL") and the Apache License version 2 ("ASL"). For the MPL, please see
// LICENSE-MPL-RabbitMQ. For the GPL, please see LICENSE-GPL2. For the ASL,
// please see LICENSE-APACHE2.
//
// This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND,
// either express or implied. See the LICENSE file for specific language governing
// rights and limitations of this software.
//
// If you have any questions regarding licensing, please contact us at
// info@rabbitmq.com.
package com.rabbitmq.client.test.server;
import java.io.IOException;
import org.junit.Test;
import com.rabbitmq.client.AMQP;
import com.rabbitmq.client.MessageProperties;
import com.rabbitmq.client.test.ConfirmBase;
import org.junit.Test;
public class MessageRecovery extends ConfirmBase
{
private final static String Q = "recovery-test";
private final static String Q2 = "recovery-test-ha-check";
@Test public void messageRecovery()
throws Exception
{
channel.queueDelete(Q);
channel.queueDelete(Q2);
channel.confirmSelect();
channel.queueDeclare(Q, true, false, false, null);
channel.basicPublish("", Q, false, false,
MessageProperties.PERSISTENT_BASIC,
"nop".getBytes());
waitForConfirms();
channel.queueDeclare(Q2, false, false, false, null);
restart();
// When testing in HA mode the message will be collected from
// a promoted slave and will have its redelivered flag
// set. But that only happens if there actually *is* a
// slave. We test that by passively declaring, and
// subsequently deleting, the secondary, non-durable queue,
// which only succeeds if the queue survived the restart,
// which in turn implies that it must have been a HA queue
// with slave(s).
// NB: this wont work when running against a single node broker
// and running the test individually outside of the HA suite
boolean expectDelivered = HATests.HA_TESTS_RUNNING;
try {
channel.queueDeclarePassive(Q2);
channel.queueDelete(Q2);
expectDelivered = true;
} catch (IOException e) {
checkShutdownSignal(AMQP.NOT_FOUND, e);
openChannel();
}
assertDelivered(Q, 1, expectDelivered);
channel.queueDelete(Q);
channel.queueDelete(Q2);
}
}