[rfc] [icedtea-web] Fix EDT hanging on OpenJDK 11

Jiri Vanek jvanek at redhat.com
Tue Sep 11 14:27:15 UTC 2018


On 9/11/18 2:46 PM, Laurent Bourgès wrote:
> Jiri & Mario,
> 
> Here is my final patch (after merging with backports):
> http://cr.openjdk.java.net/~lbourges/itw/patch_EDT.log.3
> 
> Laurent


ok. I have the patch ready to push. The private class added, and one import removed.
Here is the changelogused:

2018-09-11  Laurent Bourgès <bourges.laurent at gmail.com>

	Fixed EDT hanging
	* AUTHORS: added Laurent
	* netx/net/sourceforge/jnlp/GuiLaunchHandler.java: invokeLater and invokeAndWait moved from 
SwingUtilities local wrapper of SwingUtils.
	Simplified splasshcreen loading
	* netx/net/sourceforge/jnlp/JNLPSplashScreen.java: added name to the dialog
	* netx/net/sourceforge/jnlp/Launcher.java: added log entry for main class loading. Highlighted 
usage of SwingUtilities on top SwingUtils
	for this particular space
	* netx/net/sourceforge/jnlp/about/AboutDialog.java: added name.  Highlighted usage of 
SwingUtilities on top SwingUtils
	for this particular space
	* netx/net/sourceforge/jnlp/cache/DefaultDownloadIndicator.java: reworked to work in 
SwingUtils.invokeAndWait. Added name.
	* netx/net/sourceforge/jnlp/controlpanel/AdvancedProxySettingsDialog.java: added name
	* netx/net/sourceforge/jnlp/controlpanel/CacheViewer.java: added name
	* netx/net/sourceforge/jnlp/controlpanel/ControlPanel.java: added top level setup for enabling 
SwingUtils debugging abilities
	added log entry for main class loading. Highlighted usage of SwingUtilities on top SwingUtils for 
this particular space
	* netx/net/sourceforge/jnlp/runtime/Boot.java: added top level setup for enabling SwingUtils 
debugging abilities
	CertificateViwer moved to invokeAndWait. added log entry for main class loading. Highlighted usage 
of SwingUtilities on top SwingUtils
	for this particular space.
	* netx/net/sourceforge/jnlp/runtime/HtmlBoot.java:invokeLater and invokeAndWait moved from 
SwingUtilities local wrapper of SwingUtils
	* netx/net/sourceforge/jnlp/runtime/JNLPRuntime.java: removed import of import javax.swing.JWindow
	* netx/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java: direct call to JWindow().getOwner(), 
moved to  SwingUtils.getOrCreateWindowOwner.
	Its existence doubtful
	* netx/net/sourceforge/jnlp/security/SecurityDialog.java: installPanel moved to invokeAndWait
	* netx/net/sourceforge/jnlp/security/SecurityDialogs.java: used SwingUtils instead of 
SwingUtilities, added name
	* netx/net/sourceforge/jnlp/security/dialogs/ViwableDialog.java: swing ops moved to invokeAndWait
	* netx/net/sourceforge/jnlp/security/viewer/CertificateViewer.java: calling Swingutils.setup, 
astill al the same
	* netx/net/sourceforge/jnlp/splashscreen/impls/defaultsplashscreen2012/BasePainter.java: still the same
	* netx/net/sourceforge/jnlp/util/BasicExceptionDialog.java: same - name, SwingUtils x 
SwingUtilities, and proepr usage of invokes
	* netx/net/sourceforge/jnlp/util/FileUtils.java: SwingUtils x SwingUtilities
	* netx/net/sourceforge/jnlp/util/logging/JavaConsole.java: observable.notifyObservers moved to 
invokeLater and
	and invoked only if observable.hasChanged
	* netx/net/sourceforge/swing/SwingUtils.java: new class. Wrapper around most commonly used 
SwingUtilities calls. Add debugging bridge
	property of icedtea-web.edt.debug set to true, can enable it on runtime.
	* netx/net/sourceforge/swing/ThreadCheckingRepaintManager.java: Based on 
http://weblogs.java.net/blog/alexfromsun/archive/2006/02/debugging_swing.html
	debugging repaint manager
	* netx/net/sourceforge/swing/TracingEventQueue.java: new class to debug EDT - showing very long 
event processing (hanging or EDT blocked ?)



I will wait with push until Mario tell his opinion too.

thank you very much for !
   J.
> 
> Le mar. 11 sept. 2018 à 08:48, Laurent Bourgès <bourges.laurent at gmail.com 
> <mailto:bourges.laurent at gmail.com>> a écrit :
> 
>     Jiri,
> 
> 
>          >     Please note http://icedtea.classpath.org/hg/icedtea-web/rev/5290684409aa it will
>         interact with the
>          >     patch for bleeding edge.  Maybe it is worthy to backport it to 1.7 and to adapt your
>         patch on
>          >     top of it?
>          >
>          >
>          > Please backport to 1.7.
>         done. Plus few more.
>         Head and 1.7 are now very very similar. All except rust launchers.
> 
> 
>     Thanks a lot, I merged and it works well.
> 
> 
>          > I merged so the patch should not have these changes after backport:
> 
>         So your patch now do not apply correctly, but the two rejected hunks can be happily
>         ignored/removed.
>         Feel free to provide updated version, but not necessary.
> 
> 
>     I agree you should just ignore changes to JNLPRuntime.
>     I can post an updated patch for tracability ?
> 
> 
>          > I tested again and both 'javaws -viewer' and itw-settings dialogs are OK.
>          >
> 
>         Nothing more on my nitpicking list. Unless you or Mario will bring some news tomorrow, I
>         will apply
>         it to 1.7 and will look forward for patch for head, and other patches.
> 
> 
>     Excellent: my first patch is accepted.
> 
>         Note, that I'm on vacation 13-23.9, and I will be a bit delayed with replies. Lets guess a week
>         delayed :)
> 
> 
>     Enjoy holidays, I will have more time to improve shell scripts.
>     Probably I will setup an ITW mirror on github following your instructions (license...).
> 
> 
>         I will write an changelog on your behalf. If you wish to write it on your own, feel free.
> 
> 
>     I can review the update to the change log...
> 
>     Laurent
> 
> 
> 
> -- 
> -- 
> Laurent Bourgès


-- 
Jiri Vanek
Senior QE engineer, OpenJDK QE lead, Mgr.
Red Hat Czech
jvanek at redhat.com    M: +420775390109


More information about the distro-pkg-dev mailing list