2007-12-01 00:00:00 +00:00
|
|
|
/*
|
2019-01-21 06:55:59 +00:00
|
|
|
* Copyright (c) 2001, 2019, Oracle and/or its affiliates. All rights reserved.
|
2007-12-01 00:00:00 +00:00
|
|
|
* 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.
|
|
|
|
*
|
2010-05-25 15:58:33 -07:00
|
|
|
* 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.
|
2007-12-01 00:00:00 +00:00
|
|
|
*/
|
|
|
|
|
2019-01-21 06:55:59 +00:00
|
|
|
import java.io.IOException;
|
|
|
|
import java.net.DatagramPacket;
|
|
|
|
import java.net.DatagramSocket;
|
|
|
|
import java.net.InetAddress;
|
|
|
|
import java.net.MulticastSocket;
|
|
|
|
import java.net.SocketTimeoutException;
|
|
|
|
|
|
|
|
import jdk.test.lib.NetworkConfiguration;
|
2019-04-16 13:06:23 -07:00
|
|
|
import jdk.test.lib.net.IPSupport;
|
2019-01-21 06:55:59 +00:00
|
|
|
|
|
|
|
/**
|
2007-12-01 00:00:00 +00:00
|
|
|
* @test
|
|
|
|
* @bug 4488458
|
|
|
|
* @summary IPv4 and IPv6 multicasting broken on Linux
|
2019-01-21 06:55:59 +00:00
|
|
|
* @library /test/lib
|
|
|
|
* @build jdk.test.lib.NetworkConfiguration
|
|
|
|
* jdk.test.lib.Platform
|
|
|
|
* @run main Test
|
|
|
|
* @run main/othervm -Djava.net.preferIPv4Stack=true Test
|
2007-12-01 00:00:00 +00:00
|
|
|
*/
|
|
|
|
public class Test {
|
|
|
|
|
|
|
|
static int count = 0;
|
|
|
|
static int failures = 0;
|
|
|
|
|
2019-01-21 06:55:59 +00:00
|
|
|
void doTest(String address) throws IOException {
|
2007-12-01 00:00:00 +00:00
|
|
|
boolean failed = false;
|
|
|
|
|
|
|
|
InetAddress ia = InetAddress.getByName(address);
|
|
|
|
|
|
|
|
count++;
|
|
|
|
System.out.println("**********************");
|
|
|
|
System.out.println("Test " + count + ": " + ia);
|
|
|
|
|
|
|
|
MulticastSocket mc = new MulticastSocket();
|
|
|
|
int port = mc.getLocalPort();
|
|
|
|
DatagramSocket s1 = new DatagramSocket();
|
|
|
|
|
|
|
|
byte msg[] = "Hello".getBytes();
|
|
|
|
DatagramPacket p = new DatagramPacket(msg, msg.length);
|
|
|
|
|
|
|
|
mc.setSoTimeout(2000);
|
|
|
|
|
|
|
|
try {
|
|
|
|
for (int i=0; i<2; i++) {
|
|
|
|
|
|
|
|
System.out.println("Join: " + ia);
|
|
|
|
mc.joinGroup(ia);
|
|
|
|
|
|
|
|
/* packets should be received */
|
|
|
|
|
2019-01-21 06:55:59 +00:00
|
|
|
for (int j = 0; j < 2; j++) {
|
2007-12-01 00:00:00 +00:00
|
|
|
p.setAddress(ia);
|
|
|
|
p.setPort(port);
|
|
|
|
|
|
|
|
System.out.println("Send packet to: " + ia);
|
|
|
|
s1.send(p);
|
|
|
|
|
|
|
|
try {
|
|
|
|
mc.receive(p);
|
|
|
|
System.out.println("Got packet! - Good.");
|
|
|
|
} catch (SocketTimeoutException e) {
|
|
|
|
failed = true;
|
|
|
|
System.out.println("Failed: No packet received within timeout!!!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
System.out.println("Leave: " + ia);
|
|
|
|
mc.leaveGroup(ia);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* If there are multiple interface we might be a couple of
|
|
|
|
* copies still in our queue
|
|
|
|
*/
|
|
|
|
try {
|
|
|
|
while (true) {
|
|
|
|
mc.receive(p);
|
|
|
|
}
|
|
|
|
} catch (SocketTimeoutException e) { }
|
|
|
|
|
|
|
|
/* packets should not be received */
|
|
|
|
|
|
|
|
p.setAddress(ia);
|
|
|
|
p.setPort(port);
|
|
|
|
|
|
|
|
s1.send(p);
|
|
|
|
|
|
|
|
try {
|
|
|
|
mc.receive(p);
|
|
|
|
System.out.println("Failed: Got packet after leaving group!!!");
|
|
|
|
failed = true;
|
|
|
|
} catch (SocketTimeoutException e) {
|
|
|
|
System.out.println("No packet received within timeout! - Good.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} catch (IOException ioe) {
|
|
|
|
System.out.println("Failed: Unexpected exception thrown: ");
|
|
|
|
ioe.printStackTrace();
|
|
|
|
failed = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
mc.close();
|
|
|
|
s1.close();
|
|
|
|
|
|
|
|
if (failed) {
|
|
|
|
failures++;
|
|
|
|
System.out.println("Test failed!!");
|
|
|
|
} else {
|
|
|
|
System.out.println("Test passed.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-21 06:55:59 +00:00
|
|
|
void allTests() throws IOException {
|
|
|
|
NetworkConfiguration nc = NetworkConfiguration.probe();
|
2007-12-01 00:00:00 +00:00
|
|
|
|
2019-01-21 06:55:59 +00:00
|
|
|
// unconditionally test IPv4 address
|
2007-12-01 00:00:00 +00:00
|
|
|
doTest("224.80.80.80");
|
|
|
|
|
2019-01-21 06:55:59 +00:00
|
|
|
// If IPv6 is enabled perform multicast tests with various scopes
|
|
|
|
if (nc.hasTestableIPv6Address()) {
|
2007-12-01 00:00:00 +00:00
|
|
|
doTest("ff01::a");
|
|
|
|
}
|
|
|
|
|
2019-01-21 06:55:59 +00:00
|
|
|
if (nc.hasLinkLocalAddress()) {
|
2007-12-01 00:00:00 +00:00
|
|
|
doTest("ff02::a");
|
|
|
|
}
|
|
|
|
|
2019-01-21 06:55:59 +00:00
|
|
|
if (nc.hasSiteLocalAddress()) {
|
2007-12-01 00:00:00 +00:00
|
|
|
doTest("ff05::a");
|
|
|
|
}
|
|
|
|
|
2019-01-21 06:55:59 +00:00
|
|
|
if (nc.has_globaladdress()) {
|
2007-12-01 00:00:00 +00:00
|
|
|
doTest("ff0e::a");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void main(String args[]) throws Exception {
|
2019-05-09 10:28:29 -07:00
|
|
|
IPSupport.throwSkippedExceptionIfNonOperational();
|
2019-04-16 13:06:23 -07:00
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
Test t = new Test();
|
|
|
|
|
|
|
|
if (args.length == 0) {
|
|
|
|
t.allTests();
|
|
|
|
} else {
|
2019-01-21 06:55:59 +00:00
|
|
|
for (int i = 0; i < args.length; i++) {
|
2007-12-01 00:00:00 +00:00
|
|
|
t.doTest(args[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
System.out.println("**********************");
|
|
|
|
System.out.println(count + " test(s) executed. " + failures +
|
|
|
|
" test(s) failed.");
|
|
|
|
|
|
|
|
if (failures > 0) {
|
|
|
|
throw new Exception("Test failed - see log file for details");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|