/* * Copyright 2015 The Netty Project * * The Netty Project 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 io.netty.channel.kqueue; import io.netty.bootstrap.Bootstrap; import io.netty.channel.ChannelException; import io.netty.channel.ChannelInboundHandlerAdapter; import io.netty.channel.EventLoopGroup; import org.junit.After; import org.junit.AfterClass; import org.junit.Before; import org.junit.BeforeClass; import org.junit.Test; import java.net.InetSocketAddress; import java.nio.channels.ClosedChannelException; import java.util.Random; import static io.netty.channel.kqueue.BsdSocket.BSD_SND_LOW_AT_MAX; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; import static org.junit.Assume.assumeNoException; public class KQueueSocketChannelConfigTest { private static EventLoopGroup group; private static KQueueSocketChannel ch; private static Random rand; @BeforeClass public static void beforeClass() { rand = new Random(); group = new KQueueEventLoopGroup(1); } @AfterClass public static void afterClass() { group.shutdownGracefully(); } @Before public void setup() { Bootstrap bootstrap = new Bootstrap(); ch = (KQueueSocketChannel) bootstrap.group(group) .channel(KQueueSocketChannel.class) .handler(new ChannelInboundHandlerAdapter()) .bind(new InetSocketAddress(0)).syncUninterruptibly().channel(); } @After public void teardown() { ch.close().syncUninterruptibly(); } @Test public void testRandomSndLowAt() { final int expected = Math.min(BSD_SND_LOW_AT_MAX, Math.abs(rand.nextInt())); final int actual; try { ch.config().setSndLowAt(expected); actual = ch.config().getSndLowAt(); } catch (RuntimeException e) { assumeNoException(e); return; // Needed to prevent compile error for final variables to be used below } assertEquals(expected, actual); } @Test public void testInvalidHighSndLowAt() { try { ch.config().setSndLowAt(Integer.MIN_VALUE); } catch (ChannelException e) { return; } catch (RuntimeException e) { assumeNoException(e); } fail(); } @Test public void testTcpNoPush() { ch.config().setTcpNoPush(false); assertFalse(ch.config().isTcpNoPush()); ch.config().setTcpNoPush(true); assertTrue(ch.config().isTcpNoPush()); } @Test public void testSetOptionWhenClosed() { ch.close().syncUninterruptibly(); try { ch.config().setSoLinger(0); fail(); } catch (ChannelException e) { assertTrue(e.getCause() instanceof ClosedChannelException); } } @Test public void testGetOptionWhenClosed() { ch.close().syncUninterruptibly(); try { ch.config().getSoLinger(); fail(); } catch (ChannelException e) { assertTrue(e.getCause() instanceof ClosedChannelException); } } }