8320328: Restore interrupted flag in ImageIcon.loadImage
Reviewed-by: aivanov, serb
This commit is contained in:
parent
a45b5b4921
commit
f368a0c12e
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -330,6 +330,7 @@ public class ImageIcon implements Icon, Serializable, Accessible {
|
|||||||
mTracker.waitForID(id, 0);
|
mTracker.waitForID(id, 0);
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
interrupted = true;
|
interrupted = true;
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
}
|
}
|
||||||
|
|
||||||
loadStatus = mTracker.statusID(id, false);
|
loadStatus = mTracker.statusID(id, false);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2022, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2022, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -32,7 +32,7 @@ import java.nio.charset.StandardCharsets;
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 8236987
|
* @bug 8236987 8320328
|
||||||
* @summary Verifies ImageIcon constructor produces no output when the
|
* @summary Verifies ImageIcon constructor produces no output when the
|
||||||
* thread is interrupted
|
* thread is interrupted
|
||||||
* @run main LoadInterruptTest
|
* @run main LoadInterruptTest
|
||||||
@ -74,6 +74,8 @@ public class LoadInterruptTest {
|
|||||||
Thread.currentThread().interrupt();
|
Thread.currentThread().interrupt();
|
||||||
ImageIcon i = new ImageIcon("https://openjdk.org/images/openjdk.png");
|
ImageIcon i = new ImageIcon("https://openjdk.org/images/openjdk.png");
|
||||||
int status = i.getImageLoadStatus();
|
int status = i.getImageLoadStatus();
|
||||||
|
boolean interrupted = Thread.currentThread().isInterrupted();
|
||||||
|
|
||||||
System.out.flush();
|
System.out.flush();
|
||||||
String outString = testOut.toString(StandardCharsets.UTF_8);
|
String outString = testOut.toString(StandardCharsets.UTF_8);
|
||||||
|
|
||||||
@ -84,6 +86,9 @@ public class LoadInterruptTest {
|
|||||||
if (status == MediaTracker.LOADING) {
|
if (status == MediaTracker.LOADING) {
|
||||||
throw new RuntimeException("Test Case Failed!!! LOADING... status!!!");
|
throw new RuntimeException("Test Case Failed!!! LOADING... status!!!");
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (!interrupted) {
|
||||||
|
throw new RuntimeException("Interrupted state of the thread is not preserved");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user