diff options
author | Rafael H. Schloming <rhs@apache.org> | 2008-02-04 22:11:22 +0000 |
---|---|---|
committer | Rafael H. Schloming <rhs@apache.org> | 2008-02-04 22:11:22 +0000 |
commit | 554980543c9134c84b687090fc86090debb5ce36 (patch) | |
tree | bab955b585b4a6483d752566d91304103600589c | |
parent | 511048f43e0390d90a681c907ff0844c7fa0f1ec (diff) | |
download | qpid-python-554980543c9134c84b687090fc86090debb5ce36.tar.gz |
added a TransportException
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@618462 13f79535-47bb-0310-9956-ffa450edef68
3 files changed, 132 insertions, 1 deletions
diff --git a/java/common/src/main/java/org/apache/qpidity/transport/TransportException.java b/java/common/src/main/java/org/apache/qpidity/transport/TransportException.java new file mode 100644 index 0000000000..593209df82 --- /dev/null +++ b/java/common/src/main/java/org/apache/qpidity/transport/TransportException.java @@ -0,0 +1,46 @@ +/* + * + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + * + */ +package org.apache.qpidity.transport; + + +/** + * TransportException + */ + +public class TransportException extends RuntimeException +{ + + public TransportException(String msg) + { + super(msg); + } + + public TransportException(String msg, Throwable cause) + { + super(msg, cause); + } + + public TransportException(Throwable cause) + { + super(cause); + } + +} diff --git a/java/common/src/main/java/org/apache/qpidity/transport/network/mina/MinaSender.java b/java/common/src/main/java/org/apache/qpidity/transport/network/mina/MinaSender.java index 75af9cfe20..17ae7ea0f7 100644 --- a/java/common/src/main/java/org/apache/qpidity/transport/network/mina/MinaSender.java +++ b/java/common/src/main/java/org/apache/qpidity/transport/network/mina/MinaSender.java @@ -26,6 +26,7 @@ import org.apache.mina.common.IoSession; import org.apache.mina.common.WriteFuture; import org.apache.qpidity.transport.Sender; +import org.apache.qpidity.transport.TransportException; /** @@ -48,7 +49,7 @@ public class MinaSender implements Sender<java.nio.ByteBuffer> { if (session.isClosing()) { - throw new RuntimeException("Trying to write on a closed socket"); + throw new TransportException("attempted to write to a closed socket"); } lastWrite = session.write(ByteBuffer.wrap(buf)); } diff --git a/java/common/src/test/java/org/apache/qpidity/transport/ConnectionTest.java b/java/common/src/test/java/org/apache/qpidity/transport/ConnectionTest.java new file mode 100644 index 0000000000..15c1b691a7 --- /dev/null +++ b/java/common/src/test/java/org/apache/qpidity/transport/ConnectionTest.java @@ -0,0 +1,84 @@ +/* + * + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + * + */ +package org.apache.qpidity.transport; + +import org.apache.qpidity.transport.network.mina.MinaHandler; +import org.apache.qpidity.transport.util.Logger; + +import junit.framework.TestCase; + +/** + * ConnectionTest + */ + +public class ConnectionTest extends TestCase +{ + + private static final Logger log = Logger.get(ConnectionTest.class); + + private static final int PORT = 1234; + + public void testWriteToClosed() throws Exception { + ConnectionDelegate server = new ConnectionDelegate() { + public void init(Channel ch, ProtocolHeader hdr) { + ch.getConnection().close(); + } + + public SessionDelegate getSessionDelegate() { + return new SessionDelegate() {}; + } + public void exception(Throwable t) { + log.error(t, "exception caught"); + } + }; + + MinaHandler.accept("0.0.0.0", PORT, server); + + Connection conn = MinaHandler.connect("0.0.0.0", PORT, + new ConnectionDelegate() + { + public SessionDelegate getSessionDelegate() + { + return new SessionDelegate() {}; + } + public void exception(Throwable t) + { + t.printStackTrace(); + } + }); + + conn.send(new ConnectionEvent(0, new ProtocolHeader(1, 0, 10))); + Channel ch = conn.getChannel(0); + Session ssn = new Session(); + ssn.attach(ch); + + try + { + ssn.sessionOpen(1234); + fail("writing to a closed socket succeeded"); + } + catch (TransportException e) + { + // expected + } + } + +} |