// 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 static org.junit.Assert.assertEquals; import java.io.IOException; import org.junit.Test; import com.rabbitmq.client.test.functional.ClusteredTestBase; /** * From bug 19844 - we want to be sure that publish vs everything else can't * happen out of order */ public class EffectVisibilityCrossNodeTest extends ClusteredTestBase { private final String[] queues = new String[QUEUES]; @Override protected void createResources() throws IOException { for (int i = 0; i < queues.length ; i++) { queues[i] = alternateChannel.queueDeclare("", false, false, true, null).getQueue(); alternateChannel.queueBind(queues[i], "amq.fanout", ""); } } @Override protected void releaseResources() throws IOException { for (int i = 0; i < queues.length ; i++) { alternateChannel.queueDelete(queues[i]); } } private static final int QUEUES = 5; private static final int BATCHES = 500; private static final int MESSAGES_PER_BATCH = 10; private static final byte[] msg = "".getBytes(); @Test public void effectVisibility() throws Exception { for (int i = 0; i < BATCHES; i++) { for (int j = 0; j < MESSAGES_PER_BATCH; j++) { channel.basicPublish("amq.fanout", "", null, msg); } for (int j = 0; j < queues.length ; j++) { assertEquals(MESSAGES_PER_BATCH, channel.queuePurge(queues[j]).getMessageCount()); } } } }