8205641: Make java/nio/channels/Selector/RacyDeregister.java noisier and flush after prints

Reviewed-by: alanb
This commit is contained in:
Brian Burkhalter 2018-06-26 09:33:55 -07:00
parent f4ae3d5325
commit c390783ee2

View File

@ -34,7 +34,7 @@ import java.nio.channels.SocketChannel;
/* /*
* @test * @test
* @bug 6429204 8203766 * @bug 6429204 8203766 8205641
* @summary SelectionKey.interestOps does not update interest set on Windows. * @summary SelectionKey.interestOps does not update interest set on Windows.
* @author Frank Ding * @author Frank Ding
* @run main/timeout=1200 RacyDeregister * @run main/timeout=1200 RacyDeregister
@ -91,6 +91,9 @@ public class RacyDeregister {
public void run() { public void run() {
try { try {
for (int k = 0; k < NUM_OUTER_LOOP_ITERATIONS; k++) { for (int k = 0; k < NUM_OUTER_LOOP_ITERATIONS; k++) {
System.out.format("outer loop %3d at %7d ms%n", k,
System.currentTimeMillis() - t0);
System.out.flush();
for (int i = 0; i < 10000; i++) { for (int i = 0; i < 10000; i++) {
synchronized (notifyLock) { synchronized (notifyLock) {
synchronized (selectorLock) { synchronized (selectorLock) {
@ -115,6 +118,7 @@ public class RacyDeregister {
System.err.printf System.err.printf
("Notified after %d ms%n", ("Notified after %d ms%n",
t - beginTime); t - beginTime);
System.err.flush();
break; break;
} }
} }
@ -130,6 +134,7 @@ public class RacyDeregister {
if (t - t0 > TIMEOUT_THRESHOLD_MILLIS) { if (t - t0 > TIMEOUT_THRESHOLD_MILLIS) {
System.err.format System.err.format
("Timeout after %d outer loop iterations%n", k); ("Timeout after %d outer loop iterations%n", k);
System.err.flush();
succTermination = false; succTermination = false;
// wake up main thread doing select() // wake up main thread doing select()
sel.wakeup(); sel.wakeup();
@ -141,6 +146,7 @@ public class RacyDeregister {
sel.wakeup(); sel.wakeup();
} catch (Exception e) { } catch (Exception e) {
System.out.println(e); System.out.println(e);
System.out.flush();
succTermination = true; succTermination = true;
// wake up main thread doing select() // wake up main thread doing select()
sel.wakeup(); sel.wakeup();
@ -153,11 +159,13 @@ public class RacyDeregister {
sel.select(); sel.select();
if (Boolean.TRUE.equals(succTermination)) { if (Boolean.TRUE.equals(succTermination)) {
System.out.println("Test passed"); System.out.println("Test passed");
System.out.flush();
sel.close(); sel.close();
sc.close(); sc.close();
break; break;
} else if (Boolean.FALSE.equals(succTermination)) { } else if (Boolean.FALSE.equals(succTermination)) {
System.err.println("Failed to pass the test"); System.err.println("Failed to pass the test");
System.err.flush();
sel.close(); sel.close();
sc.close(); sc.close();
throw new RuntimeException("Failed to pass the test"); throw new RuntimeException("Failed to pass the test");