mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-17 17:44:40 +02:00
6608234: SwingWorker.get throws CancellationException
Reviewed-by: psadhukhan, kaddepalli, prr
This commit is contained in:
parent
bbe63638bb
commit
dfb3e113cf
2 changed files with 79 additions and 10 deletions
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2017, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2018, 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
|
||||||
|
@ -22,21 +22,30 @@
|
||||||
* or visit www.oracle.com if you need additional information or have any
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package javax.swing;
|
package javax.swing;
|
||||||
|
|
||||||
|
import java.awt.event.ActionEvent;
|
||||||
|
import java.awt.event.ActionListener;
|
||||||
|
import java.beans.PropertyChangeEvent;
|
||||||
|
import java.beans.PropertyChangeListener;
|
||||||
|
import java.beans.PropertyChangeSupport;
|
||||||
import java.lang.ref.WeakReference;
|
import java.lang.ref.WeakReference;
|
||||||
import java.security.AccessController;
|
import java.security.AccessController;
|
||||||
import java.security.PrivilegedAction;
|
import java.security.PrivilegedAction;
|
||||||
import java.beans.PropertyChangeListener;
|
|
||||||
import java.beans.PropertyChangeSupport;
|
|
||||||
import java.beans.PropertyChangeEvent;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.concurrent.*;
|
import java.util.concurrent.Callable;
|
||||||
import java.util.concurrent.locks.*;
|
import java.util.concurrent.CancellationException;
|
||||||
|
import java.util.concurrent.ExecutionException;
|
||||||
import java.awt.event.*;
|
import java.util.concurrent.ExecutorService;
|
||||||
|
import java.util.concurrent.Executors;
|
||||||
import javax.swing.SwingUtilities;
|
import java.util.concurrent.FutureTask;
|
||||||
|
import java.util.concurrent.LinkedBlockingQueue;
|
||||||
|
import java.util.concurrent.RunnableFuture;
|
||||||
|
import java.util.concurrent.ThreadFactory;
|
||||||
|
import java.util.concurrent.ThreadPoolExecutor;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
import java.util.concurrent.TimeoutException;
|
||||||
|
|
||||||
import sun.awt.AppContext;
|
import sun.awt.AppContext;
|
||||||
import sun.swing.AccumulativeRunnable;
|
import sun.swing.AccumulativeRunnable;
|
||||||
|
@ -597,6 +606,8 @@ public abstract class SwingWorker<T, V> implements RunnableFuture<T> {
|
||||||
* //the dialog will be visible until the SwingWorker is done
|
* //the dialog will be visible until the SwingWorker is done
|
||||||
* dialog.setVisible(true);
|
* dialog.setVisible(true);
|
||||||
* </pre>
|
* </pre>
|
||||||
|
*
|
||||||
|
* @throws CancellationException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
public final T get() throws InterruptedException, ExecutionException {
|
public final T get() throws InterruptedException, ExecutionException {
|
||||||
return future.get();
|
return future.get();
|
||||||
|
@ -606,6 +617,8 @@ public abstract class SwingWorker<T, V> implements RunnableFuture<T> {
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
* <p>
|
* <p>
|
||||||
* Please refer to {@link #get} for more details.
|
* Please refer to {@link #get} for more details.
|
||||||
|
*
|
||||||
|
* @throws CancellationException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
public final T get(long timeout, TimeUnit unit) throws InterruptedException,
|
public final T get(long timeout, TimeUnit unit) throws InterruptedException,
|
||||||
ExecutionException, TimeoutException {
|
ExecutionException, TimeoutException {
|
||||||
|
|
|
@ -0,0 +1,56 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.util.concurrent.CancellationException;
|
||||||
|
import java.util.concurrent.CountDownLatch;
|
||||||
|
|
||||||
|
import javax.swing.SwingWorker;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @bug 6608234
|
||||||
|
*/
|
||||||
|
public final class CheckCancellationException {
|
||||||
|
|
||||||
|
private static final CountDownLatch go = new CountDownLatch(1);
|
||||||
|
|
||||||
|
public static void main(final String[] args) throws Exception {
|
||||||
|
SwingWorker<?, ?> worker = new SwingWorker() {
|
||||||
|
protected Void doInBackground() {
|
||||||
|
go.countDown();
|
||||||
|
while (!Thread.interrupted()) ;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
worker.execute();
|
||||||
|
go.await();
|
||||||
|
worker.cancel(true);
|
||||||
|
try {
|
||||||
|
worker.get();
|
||||||
|
} catch (final CancellationException expected) {
|
||||||
|
// expected exception
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
throw new RuntimeException("CancellationException was not thrown");
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue