blob: 75c63ceda04f548ee21213bbd972fe38ff8c5ec7 [file] [log] [blame]
/*
* Copyright (c) 2017, 2020 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package org.glassfish.test.jms.jmsxdeliverycount.ejb;
import java.util.logging.*;
import jakarta.annotation.Resource;
import jakarta.ejb.*;
import jakarta.inject.Inject;
import jakarta.jms.*;
@MessageDriven(mappedName = "jms/jms_unit_test_Queue", activationConfig = {
@ActivationConfigProperty(propertyName = "acknowledgeMode", propertyValue = "Dups-ok-acknowledge"),
@ActivationConfigProperty(propertyName = "destinationType", propertyValue = "jakarta.jms.Queue"),
@ActivationConfigProperty(propertyName = "endpointExceptionRedeliveryAttempts", propertyValue = "1")
})
public class NewMessageBean implements MessageListener {
private static final Logger logger = Logger.getLogger(NewMessageBean.class.getName());
private static int count;
@Resource
private MessageDrivenContext mdc;
@Resource(mappedName = "jms/jms_unit_test_Queue")
private Queue queue;
@Resource(mappedName = "jms/jms_unit_result_Queue")
private Queue resultQueue;
@Inject
@JMSConnectionFactory("jms/jms_unit_test_QCF")
@JMSSessionMode(JMSContext.AUTO_ACKNOWLEDGE)
private JMSContext jmsContext;
public NewMessageBean() {
}
@Override
@TransactionAttribute(TransactionAttributeType.NOT_SUPPORTED)
public void onMessage(Message message) {
count++;
try {
int deliveryCount = message.getIntProperty("JMSXDeliveryCount");
if (count == 1) {
if (deliveryCount != 1) {
sendMsg(false, "Invalid JMSXDeliveryCount - Got <" + deliveryCount + ">, but expected <1>.");
return;
}
throw new RuntimeException("This is a fake runtime exception!!!");
} else if (count ==2) {
if (deliveryCount != 2) {
sendMsg(false, "Invalid JMSXDeliveryCount - Got <" + deliveryCount + ">, but expected <2>.");
return;
} else {
sendMsg(true, null);
}
}
} catch (JMSException ex) {
Logger.getLogger(NewMessageBean.class.getName()).log(Level.SEVERE, null, ex);
}
}
private void sendMsg(boolean success, String msg) {
JMSProducer producer = jmsContext.createProducer();
TextMessage tmsg = jmsContext.createTextMessage(success + ":" + msg);
producer.send(resultQueue, tmsg);
}
}