/hg/icedtea-web: Splashscreen error report made more detailed by...
jvanek at icedtea.classpath.org
jvanek at icedtea.classpath.org
Wed Jan 30 07:50:42 PST 2013
changeset f321ab6fb6c5 in /hg/icedtea-web
details: http://icedtea.classpath.org/hg/icedtea-web?cmd=changeset;node=f321ab6fb6c5
author: Jiri Vanek <jvanek at redhat.com>
date: Wed Jan 30 16:51:08 2013 +0100
Splashscreen error report made more detailed by stored LaunchErrors
* netx/net/sourceforge/jnlp/LaunchException.java: (LaunchExceptionWithStamp)
new inner class for storing timestamp togetehr with error.
(launchExceptionChain) new static list to capture LaunchErrors during
runtime.
* /netx/net/sourceforge/jnlp/resources/Messages.properties:
* netx/net/sourceforge/jnlp/resources/Messages_cs_CZ.properties:
Added explanation string
* netx/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialog.java:
Is now displaying launchExceptionChain in its error report and is copying
it to clipboard.
* tests/unit/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialogTest.java:
(getTextTest) adapted calls of getText for new Date.
diffstat:
ChangeLog | 16 ++
netx/net/sourceforge/jnlp/LaunchException.java | 43 +++++++
netx/net/sourceforge/jnlp/resources/Messages.properties | 1 +
netx/net/sourceforge/jnlp/resources/Messages_cs_CZ.properties | 3 +-
netx/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialog.java | 60 +++++++++-
tests/netx/unit/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialogTest.java | 9 +-
6 files changed, 123 insertions(+), 9 deletions(-)
diffs (282 lines):
diff -r 74a70e0b15ef -r f321ab6fb6c5 ChangeLog
--- a/ChangeLog Mon Jan 28 11:38:34 2013 -0500
+++ b/ChangeLog Wed Jan 30 16:51:08 2013 +0100
@@ -1,3 +1,19 @@
+2013-01-30 Jiri Vanek <jvanek at redhat.com>
+
+ Splashscreen error report made more detailed by stored LaunchErrors
+ * netx/net/sourceforge/jnlp/LaunchException.java: (LaunchExceptionWithStamp)
+ new inner class for storing timestamp togetehr with error.
+ (launchExceptionChain) new static list to capture LaunchErrors during
+ runtime.
+ * /netx/net/sourceforge/jnlp/resources/Messages.properties:
+ * netx/net/sourceforge/jnlp/resources/Messages_cs_CZ.properties:
+ Added explanation string
+ * netx/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialog.java:
+ Is now displaying launchExceptionChain in its error report and is copying
+ it to clipboard.
+ * tests/unit/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialogTest.java:
+ (getTextTest) adapted calls of getText for new Date.
+
2013-01-28 Adam Domurad <adomurad at redhat.com>
Fix PR1157: Applets can hang browser after fatal exception
diff -r 74a70e0b15ef -r f321ab6fb6c5 netx/net/sourceforge/jnlp/LaunchException.java
--- a/netx/net/sourceforge/jnlp/LaunchException.java Mon Jan 28 11:38:34 2013 -0500
+++ b/netx/net/sourceforge/jnlp/LaunchException.java Wed Jan 30 16:51:08 2013 +0100
@@ -16,6 +16,11 @@
package net.sourceforge.jnlp;
+import java.util.Collections;
+import java.util.Date;
+import java.util.LinkedList;
+import java.util.List;
+
/**
* Thrown when a JNLP application, applet, or installer could not
* be created.
@@ -25,6 +30,29 @@
*/
public class LaunchException extends Exception {
+
+ public static class LaunchExceptionWithStamp{
+ private final LaunchException ex;
+ private final Date stamp;
+
+ private LaunchExceptionWithStamp(LaunchException ex) {
+ this.ex=ex;
+ this.stamp=new Date();
+ }
+
+ public LaunchException getEx() {
+ return ex;
+ }
+
+ public Date getStamp() {
+ return stamp;
+ }
+
+
+
+ }
+ private static final List<LaunchExceptionWithStamp> launchExceptionChain = Collections.synchronizedList(new LinkedList<LaunchExceptionWithStamp>());
+
private static final long serialVersionUID = 7283827853612357423L;
/** the file being launched */
@@ -54,6 +82,7 @@
this.summary = summary;
this.description = description;
this.severity = severity;
+ saveLaunchException(this);
}
/**
@@ -61,6 +90,7 @@
*/
public LaunchException(Throwable cause) {
super(cause);
+ saveLaunchException(this);
}
/**
@@ -68,6 +98,7 @@
*/
public LaunchException(String message, Throwable cause) {
super(message, cause);
+ saveLaunchException(this);
}
/**
@@ -78,6 +109,7 @@
*/
public LaunchException(String message) {
super(message);
+ saveLaunchException(this);
}
/**
@@ -117,4 +149,15 @@
return severity;
}
+ private synchronized void saveLaunchException(LaunchException ex) {
+ launchExceptionChain.add(new LaunchExceptionWithStamp(ex));
+
+ }
+
+ public synchronized static List<LaunchExceptionWithStamp> getLaunchExceptionChain() {
+ return launchExceptionChain;
+ }
+
+
+
}
diff -r 74a70e0b15ef -r f321ab6fb6c5 netx/net/sourceforge/jnlp/resources/Messages.properties
--- a/netx/net/sourceforge/jnlp/resources/Messages.properties Mon Jan 28 11:38:34 2013 -0500
+++ b/netx/net/sourceforge/jnlp/resources/Messages.properties Wed Jan 30 16:51:08 2013 +0100
@@ -473,3 +473,4 @@
SPLASHdefaultHomepage = Unspecified homepage, verify source rather
SPLASHerrorInInformation = Error during loading of information element, verify source rather
SPLASHmissingInformation = Information element is missing, verify source rather
+SPLASHchainWas = This is the list of exceptions that occurred launching your applet. Please note, those exceptions can be from multiple applets. For a good bug report, be sure to run only one applet.
diff -r 74a70e0b15ef -r f321ab6fb6c5 netx/net/sourceforge/jnlp/resources/Messages_cs_CZ.properties
--- a/netx/net/sourceforge/jnlp/resources/Messages_cs_CZ.properties Mon Jan 28 11:38:34 2013 -0500
+++ b/netx/net/sourceforge/jnlp/resources/Messages_cs_CZ.properties Wed Jan 30 16:51:08 2013 +0100
@@ -468,4 +468,5 @@
SPLASHanotherInfo= Dal\u0161\u00ed dostupn\u00e9 informace
SPLASHdefaultHomepage = Nespecifikovan\u00e1 domovsk\u00e1 st\u00e1nka, je doporu\u010deno zkontrolovat zdroj
SPLASHerrorInInformation = Chyba na\u010d\u00edt\u00e1n\u00ed informa\u010dn\u00edho elementu, je doporu\u010deno zkontrolovat zdroj
-SPLASHmissingInformation = Informa\u010dn\u00ed element chyb\u00fd, je doporu\u010deno zkontrolovat zdroj
\ No newline at end of file
+SPLASHmissingInformation = Informa\u010dn\u00ed element chyb\u00fd, je doporu\u010deno zkontrolovat zdroj
+SPLASHchainWas = N\u00ed\u017ee je seznam v\u00fdjimek, kter\u00e9 prov\u00e1zely start appeltu. Tento seznam ale m\u016f\u017er poch\u00e1zet z n\u011bkolik\u00e1 r\u016fzn\u00fdch applet\u016f. Pro dob\u00e9 chybo\u00e9 hl\u00e1\u0161en\u00ed stoj\u00e9 za to pustit applet izolovane.
\ No newline at end of file
diff -r 74a70e0b15ef -r f321ab6fb6c5 netx/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialog.java
--- a/netx/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialog.java Mon Jan 28 11:38:34 2013 -0500
+++ b/netx/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialog.java Wed Jan 30 16:51:08 2013 +0100
@@ -42,6 +42,8 @@
import java.awt.event.WindowEvent;
import java.io.PrintWriter;
import java.io.StringWriter;
+import java.text.DateFormat;
+import java.util.Date;
import java.util.List;
import javax.swing.BorderFactory;
import javax.swing.GroupLayout;
@@ -60,6 +62,7 @@
import javax.swing.WindowConstants;
import javax.swing.event.HyperlinkEvent;
import javax.swing.event.HyperlinkListener;
+import net.sourceforge.jnlp.LaunchException;
import net.sourceforge.jnlp.runtime.Translator;
public class JEditorPaneBasedExceptionDialog extends JDialog implements HyperlinkListener {
@@ -78,15 +81,19 @@
// End of components declaration
private final String message;
private final Throwable exception;
+ private final Date shown;
+ private final String anotherInfo;
/** Creates new form JEditorPaneBasedExceptionDialog */
public JEditorPaneBasedExceptionDialog(java.awt.Frame parent, boolean modal, Throwable ex, InformationElement information, String anotherInfo) {
super(parent, modal);
+ shown = new Date();
initComponents();
htmlErrorAndHelpPanel.setContentType("text/html");
htmlErrorAndHelpPanel.setEditable(false);
+ this.anotherInfo=anotherInfo;
List<String> l = infoElementToList(information);
- this.message = getText(ex, l, anotherInfo);
+ this.message = getText(ex, l, anotherInfo, shown);
this.exception = ex;
if (exception == null) {
closeAndCopyButton.setVisible(false);
@@ -199,7 +206,7 @@
private void copyAndCloseButtonActionPerformed(java.awt.event.ActionEvent evt) {
if (exception != null) {
try {
- StringSelection data = new StringSelection(getExceptionStackTraceAsString(exception));
+ StringSelection data = new StringSelection(anotherInfo+"\n"+shown.toString()+"\n"+getExceptionStackTraceAsString(exception)+addPlainChain());
Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard();
clipboard.setContents(data, data);
} catch (Exception ex) {
@@ -241,7 +248,7 @@
});
}
- static String getText(Throwable ex, List<String> l, String anotherInfo) {
+ static String getText(Throwable ex, List<String> l, String anotherInfo,Date shown) {
StringBuilder s = new StringBuilder("<html><body>");
String info = "<p>"
+ Translator.R(InfoItem.SPLASH + "mainL1", createLink())
@@ -258,9 +265,11 @@
+ Translator.R(InfoItem.SPLASH + "mainL4")
+ " </p>\n"
+ info + formatListInfoList(l) + formatInfo(anotherInfo)
+ +"<br>"+DateFormat.getInstance().format(shown)+"<br>"
+ "<p>"
+ Translator.R(InfoItem.SPLASH + "exWas")
- + " <br/>\n" + "<pre>" + getExceptionStackTraceAsString(ex) + "</pre>";
+ + " <br/>\n" + "<pre>" + getExceptionStackTraceAsString(ex) + "</pre>"
+ + addChain();
} else {
@@ -354,4 +363,47 @@
}
+ private static String addChain() {
+ if (LaunchException.getLaunchExceptionChain().isEmpty()) {
+ return "";
+ }
+ return Translator.R(InfoItem.SPLASH + "chainWas")
+ + " <br/>\n" + "<pre>" + getChainAsString(true) + "</pre>";
+
+ }
+
+ private static String addPlainChain() {
+ if (LaunchException.getLaunchExceptionChain().isEmpty()) {
+ return "";
+ }
+ return "\n Chain: \n" + getChainAsString(false);
+
+ }
+
+ private static String getChainAsString(boolean formatTime) {
+ return getChainAsString(LaunchException.getLaunchExceptionChain(), formatTime);
+ }
+
+ private static String getChainAsString(List<LaunchException.LaunchExceptionWithStamp> launchExceptionChain, boolean formatTime) {
+ String s = "";
+ if (launchExceptionChain != null) {
+ int i = 0;
+ for (LaunchException.LaunchExceptionWithStamp launchException : launchExceptionChain) {
+ i++;
+ s = s + i + ") at " + formatTime(launchException.getStamp(), formatTime) + "\n" + getExceptionStackTraceAsString(launchException.getEx());
+ }
+ }
+ return s;
+ }
+
+ private static String formatTime(Date dateTime, boolean formatTime) {
+ if (dateTime == null) {
+ return "unknown time";
+ }
+ if (formatTime) {
+ return DateFormat.getInstance().format(dateTime);
+ } else {
+ return dateTime.toString();
+ }
+ }
}
diff -r 74a70e0b15ef -r f321ab6fb6c5 tests/netx/unit/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialogTest.java
--- a/tests/netx/unit/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialogTest.java Mon Jan 28 11:38:34 2013 -0500
+++ b/tests/netx/unit/net/sourceforge/jnlp/splashscreen/parts/JEditorPaneBasedExceptionDialogTest.java Wed Jan 30 16:51:08 2013 +0100
@@ -40,6 +40,7 @@
import java.io.StringWriter;
import java.util.ArrayList;
import java.util.Arrays;
+import java.util.Date;
import java.util.List;
import net.sourceforge.jnlp.runtime.Translator;
import org.junit.Assert;
@@ -107,10 +108,10 @@
@Test
public void getTextTest() {
- String s1 = JEditorPaneBasedExceptionDialog.getText(ex, l, ai);
- String s2 = JEditorPaneBasedExceptionDialog.getText(ex, l, null);
- String s3 = JEditorPaneBasedExceptionDialog.getText(ex, null, ai);
- String s4 = JEditorPaneBasedExceptionDialog.getText(null, l, ai);
+ String s1 = JEditorPaneBasedExceptionDialog.getText(ex, l, ai, new Date());
+ String s2 = JEditorPaneBasedExceptionDialog.getText(ex, l, null, new Date());
+ String s3 = JEditorPaneBasedExceptionDialog.getText(ex, null, ai, new Date());
+ String s4 = JEditorPaneBasedExceptionDialog.getText(null, l, ai, new Date());
assertHtml(s1);
assertHtml(s2);
assertHtml(s3);
More information about the distro-pkg-dev
mailing list