8320328: Restore interrupted flag in ImageIcon.loadImage

Reviewed-by: aivanov, serb
This commit is contained in:
Rajat Mahajan 2024-01-15 13:09:00 +00:00 committed by Alexey Ivanov
parent a45b5b4921
commit f368a0c12e
2 changed files with 10 additions and 4 deletions

View File

@ -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.
*
* 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);
} catch (InterruptedException e) {
interrupted = true;
Thread.currentThread().interrupt();
}
loadStatus = mTracker.statusID(id, false);

View File

@ -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.
*
* This code is free software; you can redistribute it and/or modify it
@ -32,7 +32,7 @@ import java.nio.charset.StandardCharsets;
/*
* @test
* @bug 8236987
* @bug 8236987 8320328
* @summary Verifies ImageIcon constructor produces no output when the
* thread is interrupted
* @run main LoadInterruptTest
@ -74,6 +74,8 @@ public class LoadInterruptTest {
Thread.currentThread().interrupt();
ImageIcon i = new ImageIcon("https://openjdk.org/images/openjdk.png");
int status = i.getImageLoadStatus();
boolean interrupted = Thread.currentThread().isInterrupted();
System.out.flush();
String outString = testOut.toString(StandardCharsets.UTF_8);
@ -84,6 +86,9 @@ public class LoadInterruptTest {
if (status == MediaTracker.LOADING) {
throw new RuntimeException("Test Case Failed!!! LOADING... status!!!");
}
}
}
if (!interrupted) {
throw new RuntimeException("Interrupted state of the thread is not preserved");
}
}
}