From 0888b48ad1c5b7728ccd35ebf51c83ec61ef9d0c Mon Sep 17 00:00:00 2001 From: kohsuke Date: Wed, 2 Sep 2009 17:00:51 +0000 Subject: [PATCH] enabling back tests. git-svn-id: https://hudson.dev.java.net/svn/hudson/trunk/hudson/main@21357 71c3de6d-444a-0410-be80-ed276b4c234a --- pom.xml | 12 ------------ .../hudson/remoting/BinarySafeStreamTest.java | 6 +++--- .../java/hudson/remoting/ChannelRunner.java | 18 +++++++++++++++++- src/test/java/hudson/remoting/ChannelTest.java | 3 ++- 4 files changed, 22 insertions(+), 17 deletions(-) diff --git a/pom.xml b/pom.xml index 2b717686d..16aaef030 100644 --- a/pom.xml +++ b/pom.xml @@ -41,18 +41,6 @@ THE SOFTWARE. - - - maven-surefire-plugin - - true - - org.codehaus.mojo findbugs-maven-plugin diff --git a/src/test/java/hudson/remoting/BinarySafeStreamTest.java b/src/test/java/hudson/remoting/BinarySafeStreamTest.java index 5745a2a18..4c082523c 100644 --- a/src/test/java/hudson/remoting/BinarySafeStreamTest.java +++ b/src/test/java/hudson/remoting/BinarySafeStreamTest.java @@ -48,9 +48,9 @@ public void test1() throws IOException { o.close(); InputStream in = BinarySafeStream.wrap(new ByteArrayInputStream(buf.toByteArray())); - for (int i = 0; i < data.length; i++) { + for (byte b : data) { int ch = in.read(); - assertEquals(data[i], ch); + assertEquals(b, ch); } assertEquals(-1,in.read()); } @@ -152,7 +152,7 @@ private void randomCopy(Random r, InputStream in, OutputStream out, boolean rand int ch = in.read(); if(dump) System.out.println("read1("+ch+')'); - assert ch>=0; + assertTrue(255>=ch && ch>=-1); // make sure the range is [-1,255] if(ch==-1) return; out.write(ch); diff --git a/src/test/java/hudson/remoting/ChannelRunner.java b/src/test/java/hudson/remoting/ChannelRunner.java index 86ebd16cd..c539299e2 100644 --- a/src/test/java/hudson/remoting/ChannelRunner.java +++ b/src/test/java/hudson/remoting/ChannelRunner.java @@ -28,8 +28,11 @@ import java.io.IOException; import java.io.PipedInputStream; import java.io.PipedOutputStream; +import java.io.File; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; +import java.net.URLClassLoader; +import java.net.URL; /** * Hides the logic of starting/stopping a channel for test. @@ -113,7 +116,9 @@ static class Fork implements ChannelRunner { public Channel start() throws Exception { System.out.println("forking a new process"); // proc = Runtime.getRuntime().exec("java -Xdebug -Xrunjdwp:transport=dt_socket,server=y,address=8000 hudson.remoting.Launcher"); - proc = Runtime.getRuntime().exec("java hudson.remoting.Launcher"); + + + proc = Runtime.getRuntime().exec("java -cp "+getClasspath()+" hudson.remoting.Launcher"); copier = new Copier("copier",proc.getErrorStream(),System.err); copier.start(); @@ -139,5 +144,16 @@ public void stop(Channel channel) throws Exception { public String getName() { return "fork"; } + + public String getClasspath() { + // this assumes we run in Maven + StringBuilder buf = new StringBuilder(); + URLClassLoader ucl = (URLClassLoader)getClass().getClassLoader(); + for (URL url : ucl.getURLs()) { + if (buf.length()>0) buf.append(File.pathSeparatorChar); + buf.append(url.getPath()); // assume all of them are file URLs + } + return buf.toString(); + } } } diff --git a/src/test/java/hudson/remoting/ChannelTest.java b/src/test/java/hudson/remoting/ChannelTest.java index 8b5b2f9fa..d0250a62c 100644 --- a/src/test/java/hudson/remoting/ChannelTest.java +++ b/src/test/java/hudson/remoting/ChannelTest.java @@ -5,6 +5,7 @@ */ public class ChannelTest extends RmiTestBase { public void testCapability() { - assertTrue(channel.remoteCapability.supportsMultiClassLoaderRPC()); + // for now this is disabled + assertTrue(!channel.remoteCapability.supportsMultiClassLoaderRPC()); } }