Hiram R. Chirino 2006-07-01 19:03:00 +00:00
parent 3a4f3d5bd9
commit e423bc58a0
1 changed files with 13 additions and 1 deletions

View File

@ -26,6 +26,7 @@ import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import edu.emory.mathcs.backport.java.util.concurrent.CountDownLatch; import edu.emory.mathcs.backport.java.util.concurrent.CountDownLatch;
import edu.emory.mathcs.backport.java.util.concurrent.TimeUnit;
import edu.emory.mathcs.backport.java.util.concurrent.atomic.AtomicBoolean; import edu.emory.mathcs.backport.java.util.concurrent.atomic.AtomicBoolean;
@ -35,6 +36,7 @@ public class WireFormatNegotiator extends TransportFilter {
private OpenWireFormat wireFormat; private OpenWireFormat wireFormat;
private final int minimumVersion; private final int minimumVersion;
private long negotiateTimeout=15000;
private final AtomicBoolean firstStart=new AtomicBoolean(true); private final AtomicBoolean firstStart=new AtomicBoolean(true);
private final CountDownLatch readyCountDownLatch = new CountDownLatch(1); private final CountDownLatch readyCountDownLatch = new CountDownLatch(1);
@ -70,7 +72,8 @@ public class WireFormatNegotiator extends TransportFilter {
public void oneway(Command command) throws IOException { public void oneway(Command command) throws IOException {
try { try {
readyCountDownLatch.await(); if( !readyCountDownLatch.await(negotiateTimeout, TimeUnit.MILLISECONDS) )
throw new IOException("Wire format negociation timeout: peer did not send his wire format.");
} catch (InterruptedException e) { } catch (InterruptedException e) {
throw new InterruptedIOException(); throw new InterruptedIOException();
} }
@ -130,4 +133,13 @@ public class WireFormatNegotiator extends TransportFilter {
protected void onWireFormatNegotiated(WireFormatInfo info) { protected void onWireFormatNegotiated(WireFormatInfo info) {
} }
public long getNegotiateTimeout() {
return negotiateTimeout;
}
public void setNegotiateTimeout(long negotiateTimeout) {
this.negotiateTimeout = negotiateTimeout;
}
} }