aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorOmair Majid <[email protected]>2013-09-09 11:32:36 -0400
committerOmair Majid <[email protected]>2013-09-09 11:32:36 -0400
commiteae8bd5edfb2300861eb1e646595b27b68293829 (patch)
tree0ad66a0bdefaa8472b8b61b98151bbd316021efd /tests
parent6d8f2f2829a06dee43cfe08eea2be162836b65a3 (diff)
PR1533: Inherit jnlp.packEnabled and jnlp.versionEnabled like other properties
Treat jnlp.packEnabled and jnlp.versionEnabled just like other properties that can be set in one resource element and inherited/filtered in others. 2013-09-09 Omair Majid <[email protected]> * netx/net/sourceforge/jnlp/JNLPFile.java (getDownloadOptionsForJar): Rename to ... (getDownloadOptions): New method. Look up jnlp.packEnabled and jnlp.versionEnabled in any resources element. * netx/net/sourceforge/jnlp/PluginBridge.java (getDownloadOptionsForJar): Rename to ... (getDownloadOptions): New method. * netx/net/sourceforge/jnlp/runtime/JNLPClassLoader.java (initializeResources): Invoke file.getDownloadResources. (getDownloadOptionsForJar): Remove. * tests/netx/unit/net/sourceforge/jnlp/JNLPFileTest.java (testDownloadOptionsAppliedEverywhere): New method. (testDownloadOptionsFilteredOut): New method.
Diffstat (limited to 'tests')
-rw-r--r--tests/netx/unit/net/sourceforge/jnlp/JNLPFileTest.java68
1 files changed, 68 insertions, 0 deletions
diff --git a/tests/netx/unit/net/sourceforge/jnlp/JNLPFileTest.java b/tests/netx/unit/net/sourceforge/jnlp/JNLPFileTest.java
index 1f517be..8285df2 100644
--- a/tests/netx/unit/net/sourceforge/jnlp/JNLPFileTest.java
+++ b/tests/netx/unit/net/sourceforge/jnlp/JNLPFileTest.java
@@ -45,6 +45,7 @@ import java.util.Locale;
import java.util.Map;
import net.sourceforge.jnlp.JNLPFile.Match;
+import net.sourceforge.jnlp.annotations.Bug;
import net.sourceforge.jnlp.mock.MockJNLPFile;
import org.junit.Assert;
@@ -208,4 +209,71 @@ public class JNLPFileTest {
Assert.assertEquals("os2", properties.get("os"));
Assert.assertEquals("arch2", properties.get("arch"));
}
+
+ @Bug(id={"PR1533"})
+ @Test
+ public void testDownloadOptionsAppliedEverywhere() throws MalformedURLException, ParseException {
+ String os = System.getProperty("os.name");
+ String arch = System.getProperty("os.arch");
+
+ String jnlpContents = "<?xml version='1.0'?>\n" +
+ "<jnlp spec='1.5' href='foo' codebase='bar'>\n" +
+ " <information>\n" +
+ " <title>Parsing Test</title>\n" +
+ " <vendor>IcedTea</vendor>\n" +
+ " <offline-allowed/>\n" +
+ " </information>\n" +
+ " <resources>\n" +
+ " <property name='jnlp.packEnabled' value='false'/>" +
+ " <property name='jnlp.versionEnabled' value='false'/>" +
+ " </resources>\n" +
+ " <resources os='" + os + "'>" +
+ " <property name='jnlp.packEnabled' value='true'/>" +
+ " </resources>\n" +
+ " <resources arch='" + arch + "'>" +
+ " <property name='jnlp.versionEnabled' value='true'/>" +
+ " </resources>\n" +
+ " <installer-desc/>\n" +
+ "</jnlp>";
+
+ URL codeBase = new URL("http://icedtea.classpath.org");
+ InputStream is = new ByteArrayInputStream(jnlpContents.getBytes());
+ JNLPFile jnlpFile = new JNLPFile(is, codeBase, new ParserSettings(false,false,false));
+ DownloadOptions downloadOptions = jnlpFile.getDownloadOptions();
+
+ Assert.assertTrue(downloadOptions.useExplicitPack());
+ Assert.assertTrue(downloadOptions.useExplicitVersion());
+ }
+
+ @Bug(id={"PR1533"})
+ @Test
+ public void testDownloadOptionsFilteredOut() throws MalformedURLException, ParseException {
+ String jnlpContents = "<?xml version='1.0'?>\n" +
+ "<jnlp spec='1.5' href='foo' codebase='bar'>\n" +
+ " <information>\n" +
+ " <title>Parsing Test</title>\n" +
+ " <vendor>IcedTea</vendor>\n" +
+ " <offline-allowed/>\n" +
+ " </information>\n" +
+ " <resources>\n" +
+ " <property name='jnlp.packEnabled' value='false'/>" +
+ " <property name='jnlp.versionEnabled' value='false'/>" +
+ " </resources>\n" +
+ " <resources os='someOtherOs'>" +
+ " <property name='jnlp.packEnabled' value='true'/>" +
+ " </resources>\n" +
+ " <resources arch='someOtherArch'>" +
+ " <property name='jnlp.versionEnabled' value='true'/>" +
+ " </resources>\n" +
+ " <installer-desc/>\n" +
+ "</jnlp>";
+
+ URL codeBase = new URL("http://icedtea.classpath.org");
+ InputStream is = new ByteArrayInputStream(jnlpContents.getBytes());
+ JNLPFile jnlpFile = new JNLPFile(is, codeBase, new ParserSettings(false,false,false));
+ DownloadOptions downloadOptions = jnlpFile.getDownloadOptions();
+
+ Assert.assertFalse(downloadOptions.useExplicitPack());
+ Assert.assertFalse(downloadOptions.useExplicitVersion());
+ }
}