mirror of https://github.com/apache/activemq.git
AMQ-9192 - Fix flaky AdvisoryTests
Properly shutdown broker for each test and speed up tests by sending less messages
This commit is contained in:
parent
95bb3f3f49
commit
044f5346e9
|
@ -66,13 +66,14 @@ import org.junit.runners.Parameterized.Parameters;
|
|||
@RunWith(Parameterized.class)
|
||||
public class AdvisoryTests {
|
||||
|
||||
protected static final int MESSAGE_COUNT = 2000;
|
||||
protected static final int MESSAGE_COUNT = 100;
|
||||
protected BrokerService broker;
|
||||
protected Connection connection;
|
||||
protected String bindAddress = ActiveMQConnectionFactory.DEFAULT_BROKER_BIND_URL;
|
||||
protected final boolean includeBodyForAdvisory;
|
||||
protected final boolean persistent;
|
||||
protected final int EXPIRE_MESSAGE_PERIOD = 3000;
|
||||
protected final int DEFAULT_PREFETCH = 50;
|
||||
|
||||
@Parameters(name = "includeBodyForAdvisory={0}, persistent={1}")
|
||||
public static Collection<Object[]> data() {
|
||||
|
@ -126,7 +127,7 @@ public class AdvisoryTests {
|
|||
|
||||
@Test(timeout = 60000)
|
||||
public void testTopicSlowConsumerAdvisory() throws Exception {
|
||||
broker.getDestinationPolicy().getDefaultEntry().setTopicPrefetch(500);
|
||||
broker.getDestinationPolicy().getDefaultEntry().setTopicPrefetch(10);
|
||||
broker.getDestinationPolicy().getDefaultEntry().setPendingMessageLimitStrategy(null);
|
||||
testSlowConsumerAdvisory(new ActiveMQTopic(getClass().getName()));
|
||||
}
|
||||
|
@ -597,8 +598,7 @@ public class AdvisoryTests {
|
|||
MessageConsumer advisoryConsumer = s.createConsumer(advisoryTopic);
|
||||
// start throwing messages at the consumer
|
||||
MessageProducer producer = s.createProducer(topic);
|
||||
int count = (new ActiveMQPrefetchPolicy().getTopicPrefetch() * 2);
|
||||
for (int i = 0; i < count; i++) {
|
||||
for (int i = 0; i < MESSAGE_COUNT; i++) {
|
||||
BytesMessage m = s.createBytesMessage();
|
||||
m.writeBytes(new byte[1024]);
|
||||
producer.send(m);
|
||||
|
@ -672,7 +672,11 @@ public class AdvisoryTests {
|
|||
|
||||
@After
|
||||
public void tearDown() throws Exception {
|
||||
connection.close();
|
||||
try {
|
||||
connection.close();
|
||||
} catch (Exception e) {
|
||||
//swallow exception so we can still stop the broker even on error
|
||||
}
|
||||
if (broker != null) {
|
||||
broker.stop();
|
||||
}
|
||||
|
@ -704,6 +708,10 @@ public class AdvisoryTests {
|
|||
policy.setAdvisoryWhenFull(true);
|
||||
policy.setIncludeBodyForAdvisory(includeBodyForAdvisory);
|
||||
policy.setProducerFlowControl(false);
|
||||
policy.setDurableTopicPrefetch(DEFAULT_PREFETCH);
|
||||
policy.setTopicPrefetch(DEFAULT_PREFETCH);
|
||||
policy.setQueuePrefetch(DEFAULT_PREFETCH);
|
||||
|
||||
ConstantPendingMessageLimitStrategy strategy = new ConstantPendingMessageLimitStrategy();
|
||||
strategy.setLimit(10);
|
||||
policy.setPendingMessageLimitStrategy(strategy);
|
||||
|
|
Loading…
Reference in New Issue