aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog8
-rw-r--r--netx/net/sourceforge/jnlp/security/SecurityDialogs.java61
-rw-r--r--tests/netx/unit/net/sourceforge/jnlp/security/SecurityDialogsTest.java70
3 files changed, 100 insertions, 39 deletions
diff --git a/ChangeLog b/ChangeLog
index 2e020a6..e7c79e8 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2013-09-04 Andrew Azores <[email protected]>
+
+ * netx/net/sourceforge/jnlp/security/SecurityDialogs.java:
+ (getIntegerResponseAsBoolean) extracted integer response casting/handling
+ logic into new method
+ * tests/netx/unit/net/sourceforge/jnlp/security/SecurityDialogsTest.java:
+ new unit test for SecurityDialogs#getIntegerReponseAsBoolean()
+
2013-08-23 Adam Domurad <[email protected]>
Spawn Java side during C++ unit tests. Many new tests.
diff --git a/netx/net/sourceforge/jnlp/security/SecurityDialogs.java b/netx/net/sourceforge/jnlp/security/SecurityDialogs.java
index a2dc6eb..da70d79 100644
--- a/netx/net/sourceforge/jnlp/security/SecurityDialogs.java
+++ b/netx/net/sourceforge/jnlp/security/SecurityDialogs.java
@@ -132,16 +132,7 @@ public class SecurityDialogs {
Object selectedValue = getUserResponse(message);
- if (selectedValue == null) {
- return false;
- } else if (selectedValue instanceof Integer) {
- if (((Integer) selectedValue).intValue() == 0)
- return true;
- else
- return false;
- } else {
- return false;
- }
+ return getIntegerResponseAsBoolean(selectedValue);
}
/**
@@ -164,17 +155,7 @@ public class SecurityDialogs {
Object selectedValue = getUserResponse(message);
- if (selectedValue == null) {
- return false;
- } else if (selectedValue instanceof Integer) {
- if (((Integer) selectedValue).intValue() == 0) {
- return true;
- } else {
- return false;
- }
- } else {
- return false;
- }
+ return getIntegerResponseAsBoolean(selectedValue);
}
/**
@@ -224,16 +205,7 @@ public class SecurityDialogs {
Object selectedValue = getUserResponse(message);
- if (selectedValue == null) {
- return false;
- } else if (selectedValue instanceof Integer) {
- if (((Integer) selectedValue).intValue() == 0)
- return true;
- else
- return false;
- } else {
- return false;
- }
+ return getIntegerResponseAsBoolean(selectedValue);
}
/**
@@ -263,11 +235,7 @@ public class SecurityDialogs {
message.extras = new Object[] { host, port, prompt, type };
Object response = getUserResponse(message);
- if (response == null) {
- return null;
- } else {
- return (Object[]) response;
- }
+ return (Object[]) response;
}
/**
@@ -286,11 +254,11 @@ public class SecurityDialogs {
Object selectedValue = getUserResponse(message);
// result 0 = Yes, 1 = No, 2 = Cancel
- if (selectedValue == null) {
- return 2;
- } else if (selectedValue instanceof Integer) {
+ if (selectedValue instanceof Integer) {
+ // If the selected value can be cast to Integer, use that value
return ((Integer) selectedValue).intValue();
} else {
+ // Otherwise default to "cancel"
return 2;
}
}
@@ -376,6 +344,21 @@ public class SecurityDialogs {
}
/**
+ * Returns true iff the given Object reference can be cast to Integer and that Integer's
+ * intValue is 0.
+ * @param ref the Integer (hopefully) reference
+ * @return whether the given reference is both an Integer type and has intValue of 0
+ */
+ public static boolean getIntegerResponseAsBoolean(Object ref) {
+ boolean isInteger = ref instanceof Integer;
+ if (isInteger) {
+ Integer i = (Integer) ref;
+ return i.intValue() == 0;
+ }
+ return false;
+ }
+
+ /**
* Returns whether the current runtime configuration allows prompting user
* for security warnings.
*
diff --git a/tests/netx/unit/net/sourceforge/jnlp/security/SecurityDialogsTest.java b/tests/netx/unit/net/sourceforge/jnlp/security/SecurityDialogsTest.java
new file mode 100644
index 0000000..5f1e3fd
--- /dev/null
+++ b/tests/netx/unit/net/sourceforge/jnlp/security/SecurityDialogsTest.java
@@ -0,0 +1,70 @@
+/*Copyright (C) 2013 Red Hat, Inc.
+
+This file is part of IcedTea.
+
+IcedTea is free software; you can redistribute it and/or
+modify it under the terms of the GNU General Public License as published by
+the Free Software Foundation, version 2.
+
+IcedTea 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 for more details.
+
+You should have received a copy of the GNU General Public License
+along with IcedTea; see the file COPYING. If not, write to
+the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+02110-1301 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library. Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module. An independent module is a module which is not derived from
+or based on this library. If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so. If you do not wish to do so, delete this
+exception statement from your version.
+ */
+
+package net.sourceforge.jnlp.security;
+
+import static net.sourceforge.jnlp.security.SecurityDialogs.getIntegerResponseAsBoolean;
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertTrue;
+import org.junit.Test;
+
+public class SecurityDialogsTest {
+
+ @Test
+ public void testGetIntegerResponseAsBoolean() throws Exception {
+ Object nullRef = null;
+ Object objRef = new Object();
+ Float floatRef = new Float(0.0f);
+ Double doubleRef = new Double(0.0d);
+ Long longRef = new Long(0);
+ Byte byteRef = new Byte((byte)0);
+ Short shortRef = new Short((short)0);
+ String strRef = "0";
+ Integer intRef1 = new Integer(5);
+ Integer intRef2 = new Integer(0);
+
+ assertFalse("null reference should have resulted in false", getIntegerResponseAsBoolean(nullRef));
+ assertFalse("Object reference should have resulted in false", getIntegerResponseAsBoolean(objRef));
+ assertFalse("Float reference should have resulted in false", getIntegerResponseAsBoolean(floatRef));
+ assertFalse("Double reference should have resulted in false", getIntegerResponseAsBoolean(doubleRef));
+ assertFalse("Long reference should have resulted in false", getIntegerResponseAsBoolean(longRef));
+ assertFalse("Byte reference should have resulted in false", getIntegerResponseAsBoolean(byteRef));
+ assertFalse("Short reference should have resulted in false", getIntegerResponseAsBoolean(shortRef));
+ assertFalse("String reference should have resulted in false", getIntegerResponseAsBoolean(strRef));
+ assertFalse("Non-0 Integer reference should have resulted in false", getIntegerResponseAsBoolean(intRef1));
+ assertTrue("0 Integer reference should have resulted in true", getIntegerResponseAsBoolean(intRef2));
+ }
+}