/** * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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. */ package org.apache.activemq.bugs; import javax.jms.Connection; import javax.jms.DeliveryMode; import javax.jms.MessageProducer; import javax.jms.Session; import java.util.concurrent.atomic.AtomicBoolean; import org.apache.activemq.ActiveMQConnectionFactory; import org.apache.activemq.broker.BrokerService; import org.apache.activemq.broker.util.LoggingBrokerPlugin; import org.apache.activemq.util.DefaultTestAppender; import org.apache.log4j.Appender; import org.apache.log4j.Logger; import org.apache.log4j.spi.LoggingEvent; import org.junit.After; import org.junit.Before; import org.junit.Test; import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; public class AMQ3779Test { private static final Logger LOG = Logger.getLogger(AMQ3779Test.class); private static final String qName = "QNameToFind"; private BrokerService brokerService; private Appender appender; private final AtomicBoolean ok = new AtomicBoolean(false); private final AtomicBoolean gotZeroSize = new AtomicBoolean(false); @Before public void setUp() throws Exception { ok.set(false); appender = new DefaultTestAppender() { @Override public void doAppend(LoggingEvent event) { if (event.getLoggerName().toString().contains(qName)) { ok.set(true); } if (event.getMessage().toString().contains("Sending") && event.getMessage().toString().contains("size = 0")) { gotZeroSize.set(true); } } }; Logger.getRootLogger().addAppender(appender); try { brokerService = new BrokerService(); LoggingBrokerPlugin loggingBrokerPlugin = new LoggingBrokerPlugin(); loggingBrokerPlugin.setPerDestinationLogger(true); loggingBrokerPlugin.setLogAll(true); brokerService.setPlugins(new LoggingBrokerPlugin[]{loggingBrokerPlugin}); brokerService.setPersistent(false); brokerService.setUseJmx(false); brokerService.start(); } finally { LOG.removeAppender(appender); } } @After public void tearDown() throws Exception { try { if (brokerService != null) { brokerService.stop(); brokerService.waitUntilStopped(); } } finally { Logger.getRootLogger().removeAppender(appender); } } @Test(timeout = 60000) public void testLogPerDest() throws Exception { Connection connection = new ActiveMQConnectionFactory(brokerService.getVmConnectorURI()).createConnection(); Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); MessageProducer messageProducer = session.createProducer(session.createQueue(qName)); messageProducer.setDeliveryMode(DeliveryMode.PERSISTENT); connection.start(); messageProducer.send(session.createTextMessage("Hi")); connection.close(); assertTrue("got expected log message", ok.get()); assertFalse("did not get zero size in send message", gotZeroSize.get()); } }