mirror of https://github.com/apache/activemq.git
remove dependence on host name resolution to resolve failure on some machines, https://issues.apache.org/activemq/browse/AMQ-1855
git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@812046 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
0cdda142d7
commit
26d147afe2
|
@ -32,6 +32,8 @@ import org.apache.activemq.util.SocketProxy;
|
||||||
import org.apache.activemq.util.Wait;
|
import org.apache.activemq.util.Wait;
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
import org.hamcrest.BaseMatcher;
|
||||||
|
import org.hamcrest.Description;
|
||||||
import org.jmock.Expectations;
|
import org.jmock.Expectations;
|
||||||
import org.jmock.Mockery;
|
import org.jmock.Mockery;
|
||||||
import org.jmock.api.Invocation;
|
import org.jmock.api.Invocation;
|
||||||
|
@ -50,25 +52,40 @@ public class DiscoveryNetworkReconnectTest {
|
||||||
|
|
||||||
private static final Log LOG = LogFactory.getLog(DiscoveryNetworkReconnectTest.class);
|
private static final Log LOG = LogFactory.getLog(DiscoveryNetworkReconnectTest.class);
|
||||||
final int maxReconnects = 5;
|
final int maxReconnects = 5;
|
||||||
BrokerService brokerA, brokerB;
|
|
||||||
Mockery context;
|
|
||||||
ManagementContext managementContext;
|
|
||||||
|
|
||||||
final String groupName = "GroupID-" + "DiscoveryNetworkReconnectTest";
|
final String groupName = "GroupID-" + "DiscoveryNetworkReconnectTest";
|
||||||
final String discoveryAddress = "multicast://default?group=" + groupName + "&initialReconnectDelay=1000";
|
final String discoveryAddress = "multicast://default?group=" + groupName + "&initialReconnectDelay=1000";
|
||||||
final Semaphore mbeanRegistered = new Semaphore(0);
|
final Semaphore mbeanRegistered = new Semaphore(0);
|
||||||
final Semaphore mbeanUnregistered = new Semaphore(0);
|
final Semaphore mbeanUnregistered = new Semaphore(0);
|
||||||
|
BrokerService brokerA, brokerB;
|
||||||
|
Mockery context;
|
||||||
private DiscoveryAgent agent;
|
ManagementContext managementContext;
|
||||||
|
DiscoveryAgent agent;
|
||||||
SocketProxy proxy;
|
SocketProxy proxy;
|
||||||
|
|
||||||
|
// ignore the hostname resolution component as this is machine dependent
|
||||||
|
class NetworkBridgeObjectNameMatcher<T> extends BaseMatcher<T> {
|
||||||
|
T name;
|
||||||
|
NetworkBridgeObjectNameMatcher(T o) {
|
||||||
|
name = o;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean matches(Object arg0) {
|
||||||
|
ObjectName other = (ObjectName) arg0;
|
||||||
|
ObjectName mine = (ObjectName) name;
|
||||||
|
return other.getKeyProperty("Type").equals(mine.getKeyProperty("Type")) &&
|
||||||
|
other.getKeyProperty("NetworkConnectorName").equals(mine.getKeyProperty("NetworkConnectorName"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void describeTo(Description arg0) {
|
||||||
|
arg0.appendText(this.getClass().getName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
context = new JUnit4Mockery() {{
|
context = new JUnit4Mockery() {{
|
||||||
setImposteriser(ClassImposteriser.INSTANCE);
|
setImposteriser(ClassImposteriser.INSTANCE);
|
||||||
}};
|
}};
|
||||||
|
|
||||||
brokerA = new BrokerService();
|
brokerA = new BrokerService();
|
||||||
brokerA.setBrokerName("BrokerA");
|
brokerA.setBrokerName("BrokerA");
|
||||||
configure(brokerA);
|
configure(brokerA);
|
||||||
|
@ -91,7 +108,7 @@ public class DiscoveryNetworkReconnectTest {
|
||||||
allowing (managementContext).registerMBean(with(any(Object.class)), with(equal(
|
allowing (managementContext).registerMBean(with(any(Object.class)), with(equal(
|
||||||
new ObjectName("Test:BrokerName=BrokerNC,Type=Topic,Destination=ActiveMQ.Advisory.Connection"))));
|
new ObjectName("Test:BrokerName=BrokerNC,Type=Topic,Destination=ActiveMQ.Advisory.Connection"))));
|
||||||
|
|
||||||
atLeast(maxReconnects - 1).of (managementContext).registerMBean(with(any(Object.class)), with(equal(
|
atLeast(maxReconnects - 1).of (managementContext).registerMBean(with(any(Object.class)), with(new NetworkBridgeObjectNameMatcher<ObjectName>(
|
||||||
new ObjectName("Test:BrokerName=BrokerNC,Type=NetworkBridge,NetworkConnectorName=localhost,Name=localhost/127.0.0.1_"
|
new ObjectName("Test:BrokerName=BrokerNC,Type=NetworkBridge,NetworkConnectorName=localhost,Name=localhost/127.0.0.1_"
|
||||||
+ proxy.getUrl().getPort())))); will(new CustomAction("signal register network mbean") {
|
+ proxy.getUrl().getPort())))); will(new CustomAction("signal register network mbean") {
|
||||||
public Object invoke(Invocation invocation) throws Throwable {
|
public Object invoke(Invocation invocation) throws Throwable {
|
||||||
|
@ -100,7 +117,7 @@ public class DiscoveryNetworkReconnectTest {
|
||||||
return new ObjectInstance((ObjectName)invocation.getParameter(0), "dscription");
|
return new ObjectInstance((ObjectName)invocation.getParameter(0), "dscription");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
atLeast(maxReconnects - 1).of (managementContext).unregisterMBean(with(equal(
|
atLeast(maxReconnects - 1).of (managementContext).unregisterMBean(with(new NetworkBridgeObjectNameMatcher<ObjectName>(
|
||||||
new ObjectName("Test:BrokerName=BrokerNC,Type=NetworkBridge,NetworkConnectorName=localhost,Name=localhost/127.0.0.1_"
|
new ObjectName("Test:BrokerName=BrokerNC,Type=NetworkBridge,NetworkConnectorName=localhost,Name=localhost/127.0.0.1_"
|
||||||
+ proxy.getUrl().getPort())))); will(new CustomAction("signal unregister network mbean") {
|
+ proxy.getUrl().getPort())))); will(new CustomAction("signal unregister network mbean") {
|
||||||
public Object invoke(Invocation invocation) throws Throwable {
|
public Object invoke(Invocation invocation) throws Throwable {
|
||||||
|
|
Loading…
Reference in New Issue