diff options
author | Omair Majid <[email protected]> | 2013-09-09 11:32:36 -0400 |
---|---|---|
committer | Omair Majid <[email protected]> | 2013-09-09 11:32:36 -0400 |
commit | eae8bd5edfb2300861eb1e646595b27b68293829 (patch) | |
tree | 0ad66a0bdefaa8472b8b61b98151bbd316021efd /tests | |
parent | 6d8f2f2829a06dee43cfe08eea2be162836b65a3 (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.java | 68 |
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()); + } } |