/* * Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ /* @test * @bug 4927640 * @summary Tests the SCTP protocol implementation * @author chegar */ import java.net.SocketAddress; import com.sun.nio.sctp.Association; import com.sun.nio.sctp.MessageInfo; public class MessageInfoTests { static final int DEFAULT_STREAM_NUMBER = 14; static final int TEST_STREAM_NUMBER = 15; static final int TEST_PPID = 8; static final long TEST_TTL = 10000L; static final SocketAddress addr = new TestSocketAddress(); static final Association assoc = new TestAssociation(1, 1, 1); void test(String[] args) { /* TEST 1 : createOutGoing(SocketAddress,int) */ MessageInfo info = MessageInfo.createOutgoing(addr, DEFAULT_STREAM_NUMBER); checkDefaults(info); checkGetterSetters(info); /* TEST 2 : createOutGoing(Association,SocketAddress,int) */ info = MessageInfo.createOutgoing(assoc, addr, DEFAULT_STREAM_NUMBER); checkDefaults(info); check(info.association().equals(assoc), "incorrect association"); checkGetterSetters(info); /* TEST 3: null values */ info = MessageInfo.createOutgoing(null, 0); check(info.address() == null, "address should be null"); check(info.association() == null, "association should be null"); info = MessageInfo.createOutgoing(assoc, null, 0); check(info.address() == null, "address should be null"); /* Test 4: IllegalArgumentException */ testIAE(new Runnable() { public void run() { MessageInfo.createOutgoing(addr, -1); } }); testIAE(new Runnable() { public void run() { MessageInfo.createOutgoing(addr, 65537); } }); testIAE(new Runnable() { public void run() { MessageInfo.createOutgoing(null, addr, 0); } }); testIAE(new Runnable() { public void run() { MessageInfo.createOutgoing(assoc, addr, -1); } }); testIAE(new Runnable() { public void run() { MessageInfo.createOutgoing(assoc, addr, 65537);}}); final MessageInfo iaeInfo = MessageInfo.createOutgoing(assoc, addr, 0); testIAE(new Runnable() { public void run() { iaeInfo.streamNumber(-1); } }); testIAE(new Runnable() { public void run() { iaeInfo.streamNumber(65537); } }); } /* TEST : unordered = false, timeToLive = 0, complete = true, * payloadProtocolID = 0. */ void checkDefaults(MessageInfo info) { check(info.isUnordered() == false, "default unordered value not false"); check(info.timeToLive() == 0L, "timeToLive should be 0L"); check(info.isComplete() == true, "default complete value not true"); check(info.payloadProtocolID() == 0, "default PPID not 0"); check(info.bytes() == 0, "default bytes value not 0"); check(info.streamNumber() == DEFAULT_STREAM_NUMBER, "incorrect default stream number"); check(info.address().equals(addr), "incorrect address"); } void checkGetterSetters(MessageInfo info) { check(info.streamNumber(TEST_STREAM_NUMBER).streamNumber() == TEST_STREAM_NUMBER, "stream number not being set correctly"); check(info.complete(false).isComplete() == false, "complete not being set correctly"); check(info.unordered(true).isUnordered() == true, "unordered not being set correctly"); check(info.payloadProtocolID(TEST_PPID).payloadProtocolID() == TEST_PPID, "PPID not being set correctly"); check(info.timeToLive(TEST_TTL).timeToLive() == TEST_TTL, "TTL not being set correctly"); } void testIAE(Runnable runnable) { try { runnable.run(); fail("IllegalArgumentException should have been thrown"); } catch(IllegalArgumentException iae) { pass(); } } static class TestSocketAddress extends SocketAddress {} static class TestAssociation extends Association { TestAssociation(int assocID, int maxInStreams, int maxOutStreams) { super(assocID, maxInStreams, maxOutStreams); } } //--------------------- Infrastructure --------------------------- boolean debug = true; volatile int passed = 0, failed = 0; void pass() {passed++;} void fail() {failed++; Thread.dumpStack();} void fail(String msg) {System.err.println(msg); fail();} void unexpected(Throwable t) {failed++; t.printStackTrace();} void check(boolean cond) {if (cond) pass(); else fail();} void check(boolean cond, String failMessage) {if (cond) pass(); else fail(failMessage);} void debug(String message) {if(debug) { System.out.println(message); } } public static void main(String[] args) throws Throwable { Class<?> k = new Object(){}.getClass().getEnclosingClass(); try {k.getMethod("instanceMain",String[].class) .invoke( k.newInstance(), (Object) args);} catch (Throwable e) {throw e.getCause();}} public void instanceMain(String[] args) throws Throwable { try {test(args);} catch (Throwable t) {unexpected(t);} System.out.printf("%nPassed = %d, failed = %d%n%n", passed, failed); if (failed > 0) throw new AssertionError("Some tests failed");} }