package org.jacorb.test.bugs.bug1002; /* * JacORB - a free Java ORB * * Copyright (C) 1997-2015 Gerald Brose / The JacORB Team. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ import java.util.Properties; import org.jacorb.test.BasicServer; import org.jacorb.test.BasicServerHelper; import org.jacorb.test.harness.ORBTestCase; import org.jacorb.test.harness.TestUtils; import org.jacorb.test.orb.BasicServerImpl; import org.jboss.byteman.contrib.bmunit.BMRule; import org.jboss.byteman.contrib.bmunit.BMRules; import org.jboss.byteman.contrib.bmunit.BMUnitRunner; import org.junit.Assume; import org.junit.Before; import org.junit.BeforeClass; import org.junit.Rule; import org.junit.Test; import org.junit.contrib.java.lang.system.LogMode; import org.junit.contrib.java.lang.system.StandardOutputStreamLog; import org.junit.runner.RunWith; import org.omg.CORBA.COMM_FAILURE; import org.omg.CORBA.ORB; import org.omg.CORBA.TIMEOUT; import org.omg.PortableServer.POAManager; import static org.hamcrest.core.StringContains.containsString; import static org.junit.Assert.assertThat; /** * @author Nick Cross */ @RunWith(BMUnitRunner.class) public class Bug1002Test extends ORBTestCase { static { // System.setProperty("org.jboss.byteman.verbose", "true"); // System.setProperty("org.jboss.byteman.debug", "true"); } @Rule public final StandardOutputStreamLog log = new StandardOutputStreamLog ( TestUtils.verbose ? LogMode.LOG_AND_WRITE_TO_STREAM : LogMode.LOG_ONLY ); private POAManager poaManager; @BeforeClass public static void beforeClassSetUp() throws Exception { Assume.assumeFalse(TestUtils.isSSLEnabled); } @Override protected void patchORBProperties(Properties props) throws Exception { props.setProperty("jacorb.iiop.enable_loopback", "false"); props.setProperty("jacorb.connection.client.pending_reply_timeout", "5000"); props.setProperty("jacorb.connection.client.pending_reply_timeout", "5000"); } @Before public void setUp() throws Exception { poaManager = rootPOA.the_POAManager(); } @Test(timeout = 60000) @BMRules(rules = { // Force a COMM_FAILURE to close the connection @BMRule(name = "interrupt-read-injection", targetClass = "StreamConnectionBase", targetMethod = "read(org.omg.ETF.BufferHolder, int, int, int, long)", targetLocation = "AT ENTRY", condition = "! flagged (\"condition1\") && $0.getClass().getName() == \"org.jacorb.orb.iiop.ServerIIOPConnection\"", action = "flag(\"condition1\"), trace(null, $0.getClass().getName())," + " throw new org.omg.CORBA.COMM_FAILURE() ") , @BMRule(name = "notify-injection", targetClass = "^GIOPConnection", targetMethod = "close", // At invoking org.omg.ETF.Connection::close targetLocation = "AT INVOKE Connection.close", condition = "$0.getClass().getName() == \"org.jacorb.orb.giop.ServerGIOPConnection\"", action = "System.out.println (\">>>\" + String.valueOf($0.do_close) + \"<<<\")" ) }) public void testGIOPLoop() throws Exception { poaManager.activate(); BasicServerImpl servant = new BasicServerImpl(); rootPOA.activate_object(servant); org.omg.CORBA.Object o = rootPOA.servant_to_reference(servant); String ior = getORB().object_to_string(o); ORB another = getAnotherORB(orbProps); BasicServer server = BasicServerHelper.narrow(another.string_to_object(ior)); try { server.bounce_short((short) 14); } catch (TIMEOUT e) { } catch (COMM_FAILURE e) { } // Ensure the do_close has been toggled - it is detected and logged by byteman assertThat(log.getLog(), containsString(">>>true<<<")); } }