diff options
Diffstat (limited to 'modules/libjar/test/unit/test_bug597702.js')
-rw-r--r-- | modules/libjar/test/unit/test_bug597702.js | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/modules/libjar/test/unit/test_bug597702.js b/modules/libjar/test/unit/test_bug597702.js new file mode 100644 index 000000000..3f32a8923 --- /dev/null +++ b/modules/libjar/test/unit/test_bug597702.js @@ -0,0 +1,35 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +var Cc = Components.classes; +var Ci = Components.interfaces; +var Cu = Components.utils; +Cu.import("resource://gre/modules/NetUtil.jsm"); + +// Check that reading non existant inner jars results in the right error + +function run_test() { + var file = do_get_file("data/test_bug597702.zip"); + var ios = Cc["@mozilla.org/network/io-service;1"]. + getService(Ci.nsIIOService); + var outerJarBase = "jar:" + ios.newFileURI(file).spec + "!/"; + var goodSpec = "jar:" + outerJarBase + "inner.jar!/hello"; + var badSpec = "jar:" + outerJarBase + "jar_that_isnt_in_the.jar!/hello"; + var goodChannel = NetUtil.newChannel({uri: goodSpec, loadUsingSystemPrincipal: true}); + var badChannel = NetUtil.newChannel({uri: badSpec, loadUsingSystemPrincipal: true}); + + try { + instr = goodChannel.open2(); + } catch (e) { + do_throw("Failed to open file in inner jar"); + } + + try { + instr = badChannel.open2(); + do_throw("Failed to report that file doesn't exist"); + } catch (e) { + do_check_true(e.name == "NS_ERROR_FILE_NOT_FOUND"); + } +} + |