Hi guys,
I've seen a few threads on why it's a bad idea to try to embed ZK in your app.
I'm not trying to do that for my production app. I am trying to do that for
unit tests. I could try to mock out ZK but I'm concerned that'd be both a lot
of typing and wouldn't, well, test against the real thing.
Has anyone done this before?
When I tried doing this I saw the ZK session request initiated by the unit test
go through (after first trying IPv6, then falling back to IPv4), but then the
first operation attempted timed out after 40 seconds. The same test case
passes against a 3 node external ZK cluster.
Note that I'm spinning up a new ZK instance for every test run - I've tried
inserting a several minute sleep after startup to give it time to initialize,
but that didn't make a difference.
import java.io.File;
import java.util.UUID;
import java.util.concurrent.Semaphore;
import org.apache.commons.io.FileUtils;
import org.apache.zookeeper.server.ZooKeeperServerMain;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* A single-node embedded zookeeper server. <p>
* WARNING: This class is only intended for unit testing. It's not production-
* grade.
*
* @author jblatt
*/
public class EmbeddedZooKeeper extends ZooKeeperServerMain {
private static final Logger LOGGER =
LoggerFactory.getLogger(EmbeddedZooKeeper.class);
private final File dataDir = new File(
FileUtils.getTempDirectoryPath() + "/"
+ UUID.randomUUID().toString());
private final int clientPort;
private final Semaphore isRunning = new Semaphore(0);
private Thread thread;
public EmbeddedZooKeeper(int clientPort) throws ZooKeeperException {
this.clientPort = clientPort;
}
public void start() throws ZooKeeperException {
try {
FileUtils.forceMkdir(dataDir);
final EmbeddedZooKeeper self = this;
thread = new Thread() {
@Override
public void run() {
try {
LOGGER.info("Starting ZK server");
self.initializeAndRun(new String[]{
Integer.toString(clientPort),
dataDir.getAbsolutePath()});
LOGGER.info("Started ZK server");
isRunning.acquire();
LOGGER.info("Stopped ZK server");
} catch (Throwable t) {
LOGGER.error("Failure in embedded ZooKeeper", t);
}
}
};
thread.start();
} catch (Throwable t) {
throw new ZooKeeperException("Cannot start embedded zookeeper", t);
}
}
public void stop() throws ZooKeeperException {
try {
LOGGER.info("Stopping ZK server");
super.shutdown();
isRunning.release();
thread.join();
} catch (Throwable t) {
throw new ZooKeeperException("Cannot stop embedded zookeeper", t);
} finally {
// Unconditionally try to cleanup tmp dirs even if this is done
// on a running ZK server. We don't want to clutter up the user's
// local fs.
try {
FileUtils.deleteDirectory(dataDir);
} catch (Throwable t) {
LOGGER.error("Cannot cleanup tmp dirs {}",
dataDir.getAbsolutePath());
}
}
}
}
Log output:
11:07:24.064 INFO [main]
st.ata.vcc.proxy.common.model.EmbeddedZooKeeperForUnitTest - Begin
EmbeddedZooKeeperForUnitTests.start()
11:07:24.066 INFO [main]
st.ata.vcc.proxy.common.model.EmbeddedZooKeeperForUnitTest - Embedded ZooKeeper
started
11:07:24.066 INFO [Thread-1]
st.ata.vcc.control.core.zookeeper.EmbeddedZooKeeper - Starting ZK server
11:07:24.086 INFO [main] st.ata.vcc.proxy.common.model.RoutePublisherTest -
Begin RoutePublisherTest.start()
11:07:24.087 DEBUG [main] st.ata.vcc.proxy.common.model.RoutePublisher -
Starting ZK connection on st.ata.vcc.proxy.common.model.RoutePublisher@6b08d7cf
11:07:24.087 INFO [main] st.ata.vcc.control.core.zookeeper.ZooKeeperConnection
- Connecting to localhost:2181
11:07:24.093 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:zookeeper.version=3.4.5-1392090, built on 09/30/2012 17:52 GMT
11:07:24.093 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:host.name=10.66.225.162
11:07:24.093 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:java.version=1.7.0_05
11:07:24.093 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:java.vendor=Oracle Corporation
11:07:24.093 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:java.home=/Library/Java/JavaVirtualMachines/1.7.0.jdk/Contents/Home/jre
11:07:24.093 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:java.class.path=/Users/jblatt/dev/proxy/common/target/test-classes:/Users/jblatt/dev/proxy/common/target/classes:/Users/jblatt/.m2/repository/st/ata/control/core/0.2.67/core-0.2.67.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty/7.0.0.pre5/jetty-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/servlet-api/3.0.pre4/servlet-api-3.0.pre4.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty-util/7.0.0.pre5/jetty-util-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty-ssl/7.0.0.pre5/jetty-ssl-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty-security/7.0.0.pre5/jetty-security-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty-xml/7.0.0.pre5/jetty-xml-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-grizzly2/1.12/jersey-grizzly2-1.12.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-server/1.12/jersey-server-1.12.jar:/Users/jblatt/.m2/repository/asm/asm/3.1/asm-3.1.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-core/1.12/jersey-core-1.12.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-client/1.12/jersey-client-1.12.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-json/1.12/jersey-json-1.12.jar:/Users/jblatt/.m2/repository/org/codehaus/jettison/jettison/1.1/jettison-1.1.jar:/Users/jblatt/.m2/repository/com/sun/xml/bind/jaxb-impl/2.2.3-1/jaxb-impl-2.2.3-1.jar:/Users/jblatt/.m2/repository/javax/xml/bind/jaxb-api/2.2.2/jaxb-api-2.2.2.jar:/Users/jblatt/.m2/repository/javax/xml/stream/stax-api/1.0-2/stax-api-1.0-2.jar:/Users/jblatt/.m2/repository/javax/activation/activation/1.1/activation-1.1.jar:/Users/jblatt/.m2/repository/org/codehaus/jackson/jackson-core-asl/1.9.7/jackson-core-asl-1.9.7.jar:/Users/jblatt/.m2/repository/org/codehaus/jackson/jackson-mapper-asl/1.9.7/jackson-mapper-asl-1.9.7.jar:/Users/jblatt/.m2/repository/org/codehaus/jackson/jackson-xc/1.9.7/jackson-xc-1.9.7.jar:/Users/jblatt/.m2/repository/com/sun/jersey/contribs/jersey-multipart/1.12/jersey-multipart-1.12.jar:/Users/jblatt/.m2/repository/org/jvnet/mimepull/1.6/mimepull-1.6.jar:/Users/jblatt/.m2/repository/com/sun/jersey/contribs/jersey-non-blocking-client/1.12/jersey-non-blocking-client-1.12.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-http/2.2.9/grizzly-http-2.2.9.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-framework/2.2.9/grizzly-framework-2.2.9.jar:/Users/jblatt/.m2/repository/org/glassfish/gmbal/gmbal-api-only/3.0.0-b023/gmbal-api-only-3.0.0-b023.jar:/Users/jblatt/.m2/repository/org/glassfish/external/management-api/3.0.0-b012/management-api-3.0.0-b012.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-http-server/2.2.9/grizzly-http-server-2.2.9.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-rcm/2.2.9/grizzly-rcm-2.2.9.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-http-client/1.1/grizzly-http-client-1.1.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-websockets/2.2.5/grizzly-websockets-2.2.5.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-servlet/1.12/jersey-servlet-1.12.jar:/Users/jblatt/.m2/repository/org/apache/directory/studio/org.apache.commons.io/2.1/org.apache.commons.io-2.1.jar:/Users/jblatt/.m2/repository/commons-io/commons-io/2.1/commons-io-2.1.jar:/Users/jblatt/.m2/repository/commons-daemon/commons-daemon/1.0.10/commons-daemon-1.0.10.jar:/Users/jblatt/.m2/repository/ch/ethz/ganymed/ganymed-ssh2/build210/ganymed-ssh2-build210.jar:/Users/jblatt/.m2/repository/org/slf4j/jul-to-slf4j/1.6.6/jul-to-slf4j-1.6.6.jar:/Users/jblatt/.m2/repository/ch/qos/logback/logback-classic/1.0.6/logback-classic-1.0.6.jar:/Users/jblatt/.m2/repository/ch/qos/logback/logback-core/1.0.6/logback-core-1.0.6.jar:/Users/jblatt/.m2/repository/com/amazonaws/aws-java-sdk/1.3.11/aws-java-sdk-1.3.11.jar:/Users/jblatt/.m2/repository/commons-logging/commons-logging/1.1.1/commons-logging-1.1.1.jar:/Users/jblatt/.m2/repository/org/apache/httpcomponents/httpclient/4.2-beta1/httpclient-4.2-beta1.jar:/Users/jblatt/.m2/repository/org/apache/httpcomponents/httpcore/4.2-beta1/httpcore-4.2-beta1.jar:/Users/jblatt/.m2/repository/commons-codec/commons-codec/1.3/commons-codec-1.3.jar:/Users/jblatt/.m2/repository/st/ata/control/core/0.2.67/core-0.2.67-tests.jar:/Users/jblatt/.m2/repository/st/ata/vc/task/task/0.5.156/task-0.5.156.jar:/Users/jblatt/.m2/repository/org/codehaus/jackson/jackson-jaxrs/1.9.7/jackson-jaxrs-1.9.7.jar:/Users/jblatt/.m2/repository/org/slf4j/slf4j-log4j12/1.6.6/slf4j-log4j12-1.6.6.jar:/Users/jblatt/.m2/repository/log4j/log4j/1.2.17/log4j-1.2.17.jar:/Users/jblatt/.m2/repository/com/ning/async-http-client/1.7.5/async-http-client-1.7.5.jar:/Users/jblatt/.m2/repository/io/netty/netty/3.4.4.Final/netty-3.4.4.Final.jar:/Users/jblatt/.m2/repository/org/slf4j/log4j-over-slf4j/1.6.6/log4j-over-slf4j-1.6.6.jar:/Users/jblatt/.m2/repository/org/apache/zookeeper/zookeeper/3.4.5/zookeeper-3.4.5.jar:/Users/jblatt/.m2/repository/jline/jline/0.9.94/jline-0.9.94.jar:/Users/jblatt/.m2/repository/junit/junit/3.8.1/junit-3.8.1.jar:/Users/jblatt/.m2/repository/org/jboss/netty/netty/3.2.2.Final/netty-3.2.2.Final.jar:/Users/jblatt/.m2/repository/org/testng/testng/6.5.2/testng-6.5.2.jar:/Users/jblatt/.m2/repository/org/beanshell/bsh/2.0b4/bsh-2.0b4.jar:/Users/jblatt/.m2/repository/com/beust/jcommander/1.12/jcommander-1.12.jar:/Users/jblatt/.m2/repository/org/yaml/snakeyaml/1.6/snakeyaml-1.6.jar:/Users/jblatt/.m2/repository/mockit/jmockit/0.999.10/jmockit-0.999.10.jar:/Users/jblatt/.m2/repository/org/jacoco/org.jacoco.agent/0.5.7.201204190339/org.jacoco.agent-0.5.7.201204190339-runtime.jar:/Users/jblatt/.m2/repository/org/slf4j/slf4j-api/1.6.6/slf4j-api-1.6.6.jar:/Users/jblatt/.m2/repository/org/apache/maven/surefire/surefire-testng-utils/2.12/surefire-testng-utils-2.12.jar:/Users/jblatt/.m2/repository/org/apache/maven/surefire/surefire-grouper/2.12/surefire-grouper-2.12.jar:
11:07:24.094 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:java.library.path=/Users/jblatt/Library/Java/Extensions:/Library/Java/Extensions:/Network/Library/Java/Extensions:/System/Library/Java/Extensions:/usr/lib/java:.
11:07:24.094 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:java.io.tmpdir=/var/folders/zq/76dngxt50rd1hzys0bnzhwg40000gn/T/
11:07:24.094 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:java.compiler=<NA>
11:07:24.094 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:os.name=Mac OS X
11:07:24.094 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:os.arch=x86_64
11:07:24.094 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:os.version=10.8.2
11:07:24.094 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:user.name=jblatt
11:07:24.094 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:user.home=/Users/jblatt
11:07:24.094 INFO [main] org.apache.zookeeper.ZooKeeper - Client
environment:user.dir=/Users/jblatt/dev/proxy/common
11:07:24.095 INFO [main] org.apache.zookeeper.ZooKeeper - Initiating client
connection, connectString=localhost:2181 sessionTimeout=300000
watcher=st.ata.vcc.control.core.zookeeper.ZooKeeperConnection$ConnectionWatcher@457b9183
11:07:24.100 DEBUG [main] org.apache.zookeeper.ClientCnxn -
zookeeper.disableAutoWatchReset is false
11:07:24.114 INFO [main-SendThread(localhost:2181)]
org.apache.zookeeper.ClientCnxn - Opening socket connection to server
localhost/0:0:0:0:0:0:0:1:2181. Will not attempt to authenticate using SASL
(unknown error)
11:07:24.125 WARN [main-SendThread(localhost:2181)]
org.apache.zookeeper.ClientCnxn - Session 0x0 for server null, unexpected
error, closing socket connection and attempting reconnect
java.net.ConnectException: Connection refused
at sun.nio.ch.SocketChannelImpl.checkConnect(Native Method)
~[na:1.7.0_05]
at
sun.nio.ch.SocketChannelImpl.finishConnect(SocketChannelImpl.java:701)
~[na:1.7.0_05]
at
org.apache.zookeeper.ClientCnxnSocketNIO.doTransport(ClientCnxnSocketNIO.java:350)
~[zookeeper-3.4.5.jar:3.4.5-1392090]
at org.apache.zookeeper.ClientCnxn$SendThread.run(ClientCnxn.java:1068)
~[zookeeper-3.4.5.jar:3.4.5-1392090]
11:07:24.125 DEBUG [main-SendThread(localhost:2181)]
org.apache.zookeeper.ClientCnxnSocketNIO - Ignoring exception during shutdown
input
java.nio.channels.ClosedChannelException: null
at
sun.nio.ch.SocketChannelImpl.shutdownInput(SocketChannelImpl.java:762)
~[na:1.7.0_05]
at sun.nio.ch.SocketAdaptor.shutdownInput(SocketAdaptor.java:421)
~[na:1.7.0_05]
at
org.apache.zookeeper.ClientCnxnSocketNIO.cleanup(ClientCnxnSocketNIO.java:189)
~[zookeeper-3.4.5.jar:3.4.5-1392090]
at
org.apache.zookeeper.ClientCnxn$SendThread.cleanup(ClientCnxn.java:1157)
[zookeeper-3.4.5.jar:3.4.5-1392090]
at org.apache.zookeeper.ClientCnxn$SendThread.run(ClientCnxn.java:1097)
[zookeeper-3.4.5.jar:3.4.5-1392090]
11:07:24.126 DEBUG [main-SendThread(localhost:2181)]
org.apache.zookeeper.ClientCnxnSocketNIO - Ignoring exception during shutdown
output
java.nio.channels.ClosedChannelException: null
at
sun.nio.ch.SocketChannelImpl.shutdownOutput(SocketChannelImpl.java:779)
~[na:1.7.0_05]
at sun.nio.ch.SocketAdaptor.shutdownOutput(SocketAdaptor.java:429)
~[na:1.7.0_05]
at
org.apache.zookeeper.ClientCnxnSocketNIO.cleanup(ClientCnxnSocketNIO.java:196)
~[zookeeper-3.4.5.jar:3.4.5-1392090]
at
org.apache.zookeeper.ClientCnxn$SendThread.cleanup(ClientCnxn.java:1157)
[zookeeper-3.4.5.jar:3.4.5-1392090]
at org.apache.zookeeper.ClientCnxn$SendThread.run(ClientCnxn.java:1097)
[zookeeper-3.4.5.jar:3.4.5-1392090]
log4j:WARN No appenders could be found for logger
(org.apache.log4j.jmx.HierarchyDynamicMBean).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more
info.
11:07:24.135 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServerMain -
Starting server
11:07:24.139 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:zookeeper.version=3.4.5-1392090, built on 09/30/2012 17:52
GMT
11:07:24.139 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:host.name=10.66.225.162
11:07:24.139 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:java.version=1.7.0_05
11:07:24.139 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:java.vendor=Oracle Corporation
11:07:24.139 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server
environment:java.home=/Library/Java/JavaVirtualMachines/1.7.0.jdk/Contents/Home/jre
11:07:24.139 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server
environment:java.class.path=/Users/jblatt/dev/proxy/common/target/test-classes:/Users/jblatt/dev/proxy/common/target/classes:/Users/jblatt/.m2/repository/st/ata/control/core/0.2.67/core-0.2.67.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty/7.0.0.pre5/jetty-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/servlet-api/3.0.pre4/servlet-api-3.0.pre4.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty-util/7.0.0.pre5/jetty-util-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty-ssl/7.0.0.pre5/jetty-ssl-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty-security/7.0.0.pre5/jetty-security-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/org/mortbay/jetty/jetty-xml/7.0.0.pre5/jetty-xml-7.0.0.pre5.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-grizzly2/1.12/jersey-grizzly2-1.12.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-server/1.12/jersey-server-1.12.jar:/Users/jblatt/.m2/repository/asm/asm/3.1/asm-3.1.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-core/1.12/jersey-core-1.12.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-client/1.12/jersey-client-1.12.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-json/1.12/jersey-json-1.12.jar:/Users/jblatt/.m2/repository/org/codehaus/jettison/jettison/1.1/jettison-1.1.jar:/Users/jblatt/.m2/repository/com/sun/xml/bind/jaxb-impl/2.2.3-1/jaxb-impl-2.2.3-1.jar:/Users/jblatt/.m2/repository/javax/xml/bind/jaxb-api/2.2.2/jaxb-api-2.2.2.jar:/Users/jblatt/.m2/repository/javax/xml/stream/stax-api/1.0-2/stax-api-1.0-2.jar:/Users/jblatt/.m2/repository/javax/activation/activation/1.1/activation-1.1.jar:/Users/jblatt/.m2/repository/org/codehaus/jackson/jackson-core-asl/1.9.7/jackson-core-asl-1.9.7.jar:/Users/jblatt/.m2/repository/org/codehaus/jackson/jackson-mapper-asl/1.9.7/jackson-mapper-asl-1.9.7.jar:/Users/jblatt/.m2/repository/org/codehaus/jackson/jackson-xc/1.9.7/jackson-xc-1.9.7.jar:/Users/jblatt/.m2/repository/com/sun/jersey/contribs/jersey-multipart/1.12/jersey-multipart-1.12.jar:/Users/jblatt/.m2/repository/org/jvnet/mimepull/1.6/mimepull-1.6.jar:/Users/jblatt/.m2/repository/com/sun/jersey/contribs/jersey-non-blocking-client/1.12/jersey-non-blocking-client-1.12.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-http/2.2.9/grizzly-http-2.2.9.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-framework/2.2.9/grizzly-framework-2.2.9.jar:/Users/jblatt/.m2/repository/org/glassfish/gmbal/gmbal-api-only/3.0.0-b023/gmbal-api-only-3.0.0-b023.jar:/Users/jblatt/.m2/repository/org/glassfish/external/management-api/3.0.0-b012/management-api-3.0.0-b012.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-http-server/2.2.9/grizzly-http-server-2.2.9.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-rcm/2.2.9/grizzly-rcm-2.2.9.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-http-client/1.1/grizzly-http-client-1.1.jar:/Users/jblatt/.m2/repository/org/glassfish/grizzly/grizzly-websockets/2.2.5/grizzly-websockets-2.2.5.jar:/Users/jblatt/.m2/repository/com/sun/jersey/jersey-servlet/1.12/jersey-servlet-1.12.jar:/Users/jblatt/.m2/repository/org/apache/directory/studio/org.apache.commons.io/2.1/org.apache.commons.io-2.1.jar:/Users/jblatt/.m2/repository/commons-io/commons-io/2.1/commons-io-2.1.jar:/Users/jblatt/.m2/repository/commons-daemon/commons-daemon/1.0.10/commons-daemon-1.0.10.jar:/Users/jblatt/.m2/repository/ch/ethz/ganymed/ganymed-ssh2/build210/ganymed-ssh2-build210.jar:/Users/jblatt/.m2/repository/org/slf4j/jul-to-slf4j/1.6.6/jul-to-slf4j-1.6.6.jar:/Users/jblatt/.m2/repository/ch/qos/logback/logback-classic/1.0.6/logback-classic-1.0.6.jar:/Users/jblatt/.m2/repository/ch/qos/logback/logback-core/1.0.6/logback-core-1.0.6.jar:/Users/jblatt/.m2/repository/com/amazonaws/aws-java-sdk/1.3.11/aws-java-sdk-1.3.11.jar:/Users/jblatt/.m2/repository/commons-logging/commons-logging/1.1.1/commons-logging-1.1.1.jar:/Users/jblatt/.m2/repository/org/apache/httpcomponents/httpclient/4.2-beta1/httpclient-4.2-beta1.jar:/Users/jblatt/.m2/repository/org/apache/httpcomponents/httpcore/4.2-beta1/httpcore-4.2-beta1.jar:/Users/jblatt/.m2/repository/commons-codec/commons-codec/1.3/commons-codec-1.3.jar:/Users/jblatt/.m2/repository/st/ata/control/core/0.2.67/core-0.2.67-tests.jar:/Users/jblatt/.m2/repository/st/ata/vc/task/task/0.5.156/task-0.5.156.jar:/Users/jblatt/.m2/repository/org/codehaus/jackson/jackson-jaxrs/1.9.7/jackson-jaxrs-1.9.7.jar:/Users/jblatt/.m2/repository/org/slf4j/slf4j-log4j12/1.6.6/slf4j-log4j12-1.6.6.jar:/Users/jblatt/.m2/repository/log4j/log4j/1.2.17/log4j-1.2.17.jar:/Users/jblatt/.m2/repository/com/ning/async-http-client/1.7.5/async-http-client-1.7.5.jar:/Users/jblatt/.m2/repository/io/netty/netty/3.4.4.Final/netty-3.4.4.Final.jar:/Users/jblatt/.m2/repository/org/slf4j/log4j-over-slf4j/1.6.6/log4j-over-slf4j-1.6.6.jar:/Users/jblatt/.m2/repository/org/apache/zookeeper/zookeeper/3.4.5/zookeeper-3.4.5.jar:/Users/jblatt/.m2/repository/jline/jline/0.9.94/jline-0.9.94.jar:/Users/jblatt/.m2/repository/junit/junit/3.8.1/junit-3.8.1.jar:/Users/jblatt/.m2/repository/org/jboss/netty/netty/3.2.2.Final/netty-3.2.2.Final.jar:/Users/jblatt/.m2/repository/org/testng/testng/6.5.2/testng-6.5.2.jar:/Users/jblatt/.m2/repository/org/beanshell/bsh/2.0b4/bsh-2.0b4.jar:/Users/jblatt/.m2/repository/com/beust/jcommander/1.12/jcommander-1.12.jar:/Users/jblatt/.m2/repository/org/yaml/snakeyaml/1.6/snakeyaml-1.6.jar:/Users/jblatt/.m2/repository/mockit/jmockit/0.999.10/jmockit-0.999.10.jar:/Users/jblatt/.m2/repository/org/jacoco/org.jacoco.agent/0.5.7.201204190339/org.jacoco.agent-0.5.7.201204190339-runtime.jar:/Users/jblatt/.m2/repository/org/slf4j/slf4j-api/1.6.6/slf4j-api-1.6.6.jar:/Users/jblatt/.m2/repository/org/apache/maven/surefire/surefire-testng-utils/2.12/surefire-testng-utils-2.12.jar:/Users/jblatt/.m2/repository/org/apache/maven/surefire/surefire-grouper/2.12/surefire-grouper-2.12.jar:
11:07:24.140 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server
environment:java.library.path=/Users/jblatt/Library/Java/Extensions:/Library/Java/Extensions:/Network/Library/Java/Extensions:/System/Library/Java/Extensions:/usr/lib/java:.
11:07:24.140 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server
environment:java.io.tmpdir=/var/folders/zq/76dngxt50rd1hzys0bnzhwg40000gn/T/
11:07:24.140 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:java.compiler=<NA>
11:07:24.140 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:os.name=Mac OS X
11:07:24.140 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:os.arch=x86_64
11:07:24.140 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:os.version=10.8.2
11:07:24.140 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:user.name=jblatt
11:07:24.140 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:user.home=/Users/jblatt
11:07:24.140 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
Server environment:user.dir=/Users/jblatt/dev/proxy/common
11:07:24.142 DEBUG [Thread-1]
org.apache.zookeeper.server.persistence.FileTxnSnapLog - Opening
datadir:/var/folders/zq/76dngxt50rd1hzys0bnzhwg40000gn/T/51bc2e1d-270b-42df-bb82-6330a1081748
snapDir:/var/folders/zq/76dngxt50rd1hzys0bnzhwg40000gn/T/51bc2e1d-270b-42df-bb82-6330a1081748
11:07:24.145 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
tickTime set to 3000
11:07:24.145 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
minSessionTimeout set to -1
11:07:24.145 INFO [Thread-1] org.apache.zookeeper.server.ZooKeeperServer -
maxSessionTimeout set to -1
11:07:24.151 INFO [Thread-1] org.apache.zookeeper.server.NIOServerCnxnFactory
- binding to port 0.0.0.0/0.0.0.0:2181
11:07:24.162 INFO [Thread-1]
org.apache.zookeeper.server.persistence.FileTxnSnapLog - Snapshotting: 0x0 to
/var/folders/zq/76dngxt50rd1hzys0bnzhwg40000gn/T/51bc2e1d-270b-42df-bb82-6330a1081748/version-2/snapshot.0
11:07:29.230 INFO [main-SendThread(fe80:0:0:0:0:0:0:1%1:2181)]
org.apache.zookeeper.ClientCnxn - Opening socket connection to server
fe80:0:0:0:0:0:0:1%1/fe80:0:0:0:0:0:0:1%1:2181. Will not attempt to
authenticate using SASL (unknown error)
11:07:29.231 INFO [main-SendThread(fe80:0:0:0:0:0:0:1%1:2181)]
org.apache.zookeeper.ClientCnxn - Socket connection established to
fe80:0:0:0:0:0:0:1%1/fe80:0:0:0:0:0:0:1%1:2181, initiating session
11:07:29.231 INFO [NIOServerCxn.Factory:0.0.0.0/0.0.0.0:2181]
org.apache.zookeeper.server.NIOServerCnxnFactory - Accepted socket connection
from /fe80:0:0:0:0:0:0:1%1:50774
11:07:29.232 DEBUG [main-SendThread(fe80:0:0:0:0:0:0:1%1:2181)]
org.apache.zookeeper.ClientCnxn - Session establishment request sent on
fe80:0:0:0:0:0:0:1%1/fe80:0:0:0:0:0:0:1%1:2181
11:07:29.235 DEBUG [NIOServerCxn.Factory:0.0.0.0/0.0.0.0:2181]
org.apache.zookeeper.server.ZooKeeperServer - Session establishment request
from client /fe80:0:0:0:0:0:0:1%1:50774 client's lastZxid is 0x0
11:07:29.236 INFO [NIOServerCxn.Factory:0.0.0.0/0.0.0.0:2181]
org.apache.zookeeper.server.ZooKeeperServer - Client attempting to establish
new session at /fe80:0:0:0:0:0:0:1%1:50774
11:07:29.238 INFO [SyncThread:0]
org.apache.zookeeper.server.persistence.FileTxnLog - Creating new log file:
log.1
11:07:29.243 DEBUG [SyncThread:0]
org.apache.zookeeper.server.FinalRequestProcessor - Processing request::
sessionid:0x13b622a66870000 type:createSession cxid:0x0 zxid:0x1 txntype:-10
reqpath:n/a
11:07:29.246 DEBUG [SyncThread:0]
org.apache.zookeeper.server.FinalRequestProcessor - sessionid:0x13b622a66870000
type:createSession cxid:0x0 zxid:0x1 txntype:-10 reqpath:n/a
11:07:29.249 INFO [SyncThread:0] org.apache.zookeeper.server.ZooKeeperServer -
Established session 0x13b622a66870000 with negotiated timeout 60000 for client
/fe80:0:0:0:0:0:0:1%1:50774
11:07:29.249 INFO [main-SendThread(fe80:0:0:0:0:0:0:1%1:2181)]
org.apache.zookeeper.ClientCnxn - Session establishment complete on server
fe80:0:0:0:0:0:0:1%1/fe80:0:0:0:0:0:0:1%1:2181, sessionid = 0x13b622a66870000,
negotiated timeout = 60000
11:07:29.250 DEBUG [main-EventThread]
st.ata.vcc.control.core.zookeeper.ZooKeeperConnection - ZK event: type=None,
state=SyncConnected, path=null
11:07:29.250 DEBUG [main] st.ata.vcc.control.core.zookeeper.ZooKeeperConnection
- Connected to localhost:2181
11:08:09.250 INFO [main-SendThread(fe80:0:0:0:0:0:0:1%1:2181)]
org.apache.zookeeper.ClientCnxn - Client session timed out, have not heard from
server in 40000ms for sessionid 0x13b622a66870000, closing socket connection
and attempting reconnect
11:08:09.352 DEBUG [main-EventThread]
st.ata.vcc.control.core.zookeeper.ZooKeeperConnection - ZK event: type=None,
state=Disconnected, path=null
11:08:09.352 DEBUG [main-EventThread]
st.ata.vcc.control.core.zookeeper.ZooKeeperConnection - Lost connection to
localhost:2181
11:08:09.352 DEBUG [main-EventThread] org.apache.zookeeper.ZooKeeper - Closing
session: 0x13b622a66870000
11:08:09.353 DEBUG [main-EventThread] org.apache.zookeeper.ClientCnxn - Closing
client for session: 0x13b622a66870000
11:08:09.359 ERROR [main] st.ata.vcc.proxy.common.model.RoutePublisherTest -
Cannot start RoutePublisherTest
st.ata.vcc.proxy.common.model.RouteException: Cannot start ZK connection
at st.ata.vcc.proxy.common.model.RouteBase.start(RouteBase.java:103)
~[classes/:na]
at
st.ata.vcc.proxy.common.model.RoutePublisher.start(RoutePublisher.java:36)
~[classes/:na]
at
st.ata.vcc.proxy.common.model.RoutePublisherTest.start(RoutePublisherTest.java:35)
~[test-classes/:na]
at
st.ata.vcc.proxy.common.model.RoutePublisherUnitTest.start(RoutePublisherUnitTest.java:28)
[test-classes/:na]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
~[na:1.7.0_05]
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
~[na:1.7.0_05]
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
~[na:1.7.0_05]
at java.lang.reflect.Method.invoke(Method.java:601) ~[na:1.7.0_05]
at
org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:80)
[testng-6.5.2.jar:na]
at
org.testng.internal.MethodInvocationHelper$2.runConfigurationMethod(MethodInvocationHelper.java:274)
[testng-6.5.2.jar:na]
at
mockit.integration.testng.internal.TestNGRunnerDecorator.run(TestNGRunnerDecorator.java:81)
[jmockit-0.999.10.jar:na]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
~[na:1.7.0_05]
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
~[na:1.7.0_05]
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
~[na:1.7.0_05]
at java.lang.reflect.Method.invoke(Method.java:601) ~[na:1.7.0_05]
at
org.testng.internal.MethodInvocationHelper.invokeConfigurable(MethodInvocationHelper.java:286)
[testng-6.5.2.jar:na]
at
org.testng.internal.Invoker.invokeConfigurationMethod(Invoker.java:543)
[testng-6.5.2.jar:na]
at org.testng.internal.Invoker.invokeConfigurations(Invoker.java:213)
[testng-6.5.2.jar:na]
at org.testng.internal.Invoker.invokeConfigurations(Invoker.java:138)
[testng-6.5.2.jar:na]
at
org.testng.internal.TestMethodWorker.invokeBeforeClassMethods(TestMethodWorker.java:175)
[testng-6.5.2.jar:na]
at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:107)
[testng-6.5.2.jar:na]
at org.testng.TestRunner.privateRun(TestRunner.java:768)
[testng-6.5.2.jar:na]
at org.testng.TestRunner.run(TestRunner.java:617) [testng-6.5.2.jar:na]
at org.testng.SuiteRunner.runTest(SuiteRunner.java:334)
[testng-6.5.2.jar:na]
at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:329)
[testng-6.5.2.jar:na]
at org.testng.SuiteRunner.privateRun(SuiteRunner.java:291)
[testng-6.5.2.jar:na]
at org.testng.SuiteRunner.run(SuiteRunner.java:240)
[testng-6.5.2.jar:na]
at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:53)
[testng-6.5.2.jar:na]
at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:87)
[testng-6.5.2.jar:na]
at org.testng.TestNG.runSuitesSequentially(TestNG.java:1188)
[testng-6.5.2.jar:na]
at org.testng.TestNG.runSuitesLocally(TestNG.java:1113)
[testng-6.5.2.jar:na]
at org.testng.TestNG.run(TestNG.java:1025) [testng-6.5.2.jar:na]
at
org.apache.maven.surefire.testng.TestNGExecutor.run(TestNGExecutor.java:76)
[surefire-testng-2.12.jar:2.12]
at
org.apache.maven.surefire.testng.TestNGDirectoryTestSuite.executeMulti(TestNGDirectoryTestSuite.java:161)
[surefire-testng-2.12.jar:2.12]
at
org.apache.maven.surefire.testng.TestNGDirectoryTestSuite.execute(TestNGDirectoryTestSuite.java:101)
[surefire-testng-2.12.jar:2.12]
at
org.apache.maven.surefire.testng.TestNGProvider.invoke(TestNGProvider.java:115)
[surefire-testng-2.12.jar:2.12]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
~[na:1.7.0_05]
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
~[na:1.7.0_05]
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
~[na:1.7.0_05]
at java.lang.reflect.Method.invoke(Method.java:601) ~[na:1.7.0_05]
at
org.apache.maven.surefire.util.ReflectionUtils.invokeMethodWithArray(ReflectionUtils.java:189)
[surefire-api-2.12.jar:2.12]
at
org.apache.maven.surefire.booter.ProviderFactory$ProviderProxy.invoke(ProviderFactory.java:165)
[surefire-booter-2.12.jar:2.12]
at
org.apache.maven.surefire.booter.ProviderFactory.invokeProvider(ProviderFactory.java:85)
[surefire-booter-2.12.jar:2.12]
at
org.apache.maven.surefire.booter.ForkedBooter.runSuitesInProcess(ForkedBooter.java:103)
[surefire-booter-2.12.jar:2.12]
at
org.apache.maven.surefire.booter.ForkedBooter.main(ForkedBooter.java:74)
[surefire-booter-2.12.jar:2.12]
Caused by: org.apache.zookeeper.KeeperException$ConnectionLossException:
KeeperErrorCode = ConnectionLoss for /proxy
at org.apache.zookeeper.KeeperException.create(KeeperException.java:99)
~[zookeeper-3.4.5.jar:3.4.5-1392090]
at org.apache.zookeeper.KeeperException.create(KeeperException.java:51)
~[zookeeper-3.4.5.jar:3.4.5-1392090]
at org.apache.zookeeper.ZooKeeper.exists(ZooKeeper.java:1041)
~[zookeeper-3.4.5.jar:3.4.5-1392090]
at org.apache.zookeeper.ZooKeeper.exists(ZooKeeper.java:1069)
~[zookeeper-3.4.5.jar:3.4.5-1392090]
at st.ata.vcc.proxy.common.model.RouteBase.mkdir_p(RouteBase.java:161)
~[classes/:na]
at st.ata.vcc.proxy.common.model.RouteBase.start(RouteBase.java:98)
~[classes/:na]
... 44 common frames omitted
Tests run: 5, Failures: 1, Errors: 0, Skipped: 2, Time elapsed: 46.141 sec <<<
FAILURE!
start(st.ata.vcc.proxy.common.model.RoutePublisherUnitTest) Time elapsed:
45.281 sec <<< FAILURE!
st.ata.vcc.proxy.common.model.RouteException: Cannot start ZK connection
at st.ata.vcc.proxy.common.model.RouteBase.start(RouteBase.java:103)
at
st.ata.vcc.proxy.common.model.RoutePublisher.start(RoutePublisher.java:36)
at
st.ata.vcc.proxy.common.model.RoutePublisherTest.start(RoutePublisherTest.java:35)
at
st.ata.vcc.proxy.common.model.RoutePublisherUnitTest.start(RoutePublisherUnitTest.java:28)
Caused by: org.apache.zookeeper.KeeperException$ConnectionLossException:
KeeperErrorCode = ConnectionLoss for /proxy
at org.apache.zookeeper.KeeperException.create(KeeperException.java:99)
at org.apache.zookeeper.KeeperException.create(KeeperException.java:51)
at org.apache.zookeeper.ZooKeeper.exists(ZooKeeper.java:1041)
at org.apache.zookeeper.ZooKeeper.exists(ZooKeeper.java:1069)
at st.ata.vcc.proxy.common.model.RouteBase.mkdir_p(RouteBase.java:161)
at st.ata.vcc.proxy.common.model.RouteBase.start(RouteBase.java:98)
... 44 more
Any ideas?
Thanks,
Josh