⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 keepalivefiltertest.java

📁 mina是以Java实现的一个开源的网络程序框架
💻 JAVA
字号:
/* *  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.mina.filter.keepalive;import static org.apache.mina.filter.keepalive.KeepAliveRequestTimeoutHandler.*;import java.net.InetSocketAddress;import java.util.concurrent.atomic.AtomicBoolean;import junit.framework.TestCase;import org.apache.mina.core.buffer.IoBuffer;import org.apache.mina.core.future.ConnectFuture;import org.apache.mina.core.service.IoHandlerAdapter;import org.apache.mina.core.session.IdleStatus;import org.apache.mina.core.session.IoSession;import org.apache.mina.transport.socket.nio.NioSocketAcceptor;import org.apache.mina.transport.socket.nio.NioSocketConnector;/** * Tests {@link KeepAliveFilter} used by the connector with different * interested {@link IdleStatus}es. * * @author The Apache MINA Project (dev@mina.apache.org) * @version $Rev: 751473 $, $Date: 2009-03-08 18:22:14 +0100 (Sun, 08 Mar 2009) $ */public class KeepAliveFilterTest extends TestCase {    // Constants -----------------------------------------------------    private static final IoBuffer PING = IoBuffer.wrap(new byte[] { 1 });    private static final IoBuffer PONG = IoBuffer.wrap(new byte[] { 2 });    private static final int INTERVAL = 2;    private static final int TIMEOUT = 1;    private int port;    private NioSocketAcceptor acceptor;    @Override    protected void setUp() throws Exception {        super.setUp();        acceptor = new NioSocketAcceptor();        KeepAliveMessageFactory factory = new ServerFactory();        KeepAliveFilter filter = new KeepAliveFilter(factory,                IdleStatus.BOTH_IDLE);        acceptor.getFilterChain().addLast("keep-alive", filter);        acceptor.setHandler(new IoHandlerAdapter());        acceptor.setDefaultLocalAddress(new InetSocketAddress(0));        acceptor.bind();        port = acceptor.getLocalAddress().getPort();    }    @Override    protected void tearDown() throws Exception {        acceptor.unbind();        acceptor.dispose();        super.tearDown();    }    public void testKeepAliveFilterForReaderIdle() throws Exception {        keepAliveFilterForIdleStatus(IdleStatus.READER_IDLE);    }    public void testKeepAliveFilterForBothIdle() throws Exception {        keepAliveFilterForIdleStatus(IdleStatus.BOTH_IDLE);    }    public void testKeepAliveFilterForWriterIdle() throws Exception {        keepAliveFilterForIdleStatus(IdleStatus.WRITER_IDLE);    }    // Package protected ---------------------------------------------    // Protected -----------------------------------------------------    // Private -------------------------------------------------------    private void keepAliveFilterForIdleStatus(IdleStatus status)            throws Exception {        NioSocketConnector connector = new NioSocketConnector();        KeepAliveFilter filter = new KeepAliveFilter(new ClientFactory(),                status, EXCEPTION, INTERVAL, TIMEOUT);        filter.setForwardEvent(true);        connector.getFilterChain().addLast("keep-alive", filter);        final AtomicBoolean gotException = new AtomicBoolean(false);        connector.setHandler(new IoHandlerAdapter() {            @Override            public void exceptionCaught(IoSession session, Throwable cause)                    throws Exception {                //cause.printStackTrace();                gotException.set(true);            }            @Override            public void sessionIdle(IoSession session, IdleStatus status)                    throws Exception {                //System.out.println("client idle:" + status);            }        });        ConnectFuture future = connector.connect(                new InetSocketAddress("127.0.0.1", port)).awaitUninterruptibly();        IoSession session = future.getSession();        assertNotNull(session);        Thread.sleep((INTERVAL + TIMEOUT + 1) * 1000);        assertFalse("got an exception on the client", gotException.get());        session.close(true);        connector.dispose();    }    private static boolean checkRequest(IoBuffer message) {        IoBuffer buff = message;        boolean check = buff.get() == 1;        buff.rewind();        return check;    }    private static boolean checkResponse(IoBuffer message) {        IoBuffer buff = message;        boolean check = buff.get() == 2;        buff.rewind();        return check;    }    // Inner classes -------------------------------------------------    private final class ServerFactory implements KeepAliveMessageFactory {        public Object getRequest(IoSession session) {            return null;        }        public Object getResponse(IoSession session, Object request) {            return PONG.duplicate();        }        public boolean isRequest(IoSession session, Object message) {            if (message instanceof IoBuffer) {                return checkRequest((IoBuffer) message);            }            return false;        }        public boolean isResponse(IoSession session, Object message) {            if (message instanceof IoBuffer) {                return checkResponse((IoBuffer) message);            }            return false;        }    }    private final class ClientFactory implements KeepAliveMessageFactory {        public Object getRequest(IoSession session) {            return PING.duplicate();        }        public Object getResponse(IoSession session, Object request) {            return null;        }        public boolean isRequest(IoSession session, Object message) {            if (message instanceof IoBuffer) {                return checkRequest((IoBuffer) message);            }            return false;        }        public boolean isResponse(IoSession session, Object message) {            if (message instanceof IoBuffer) {                return checkResponse((IoBuffer) message);            }            return false;        }    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -