var Cc = Components.classes; var Ci = Components.interfaces; function run_test() { function makeURI(aURLSpec, aCharset) { var ios = Cc["@mozilla.org/network/io-service;1"]. getService(Ci.nsIIOService); return ios.newURI(aURLSpec, aCharset, null); } var httpURI = makeURI("http://foo.com"); do_check_eq(-1, httpURI.port); // Setting to default shouldn't cause a change httpURI.port = 80; do_check_eq(-1, httpURI.port); // Setting to default after setting to non-default shouldn't cause a change (bug 403480) httpURI.port = 123; do_check_eq(123, httpURI.port); httpURI.port = 80; do_check_eq(-1, httpURI.port); do_check_false(/80/.test(httpURI.spec)); // URL parsers shouldn't set ports to default value (bug 407538) httpURI.spec = "http://foo.com:81"; do_check_eq(81, httpURI.port); httpURI.spec = "http://foo.com:80"; do_check_eq(-1, httpURI.port); do_check_false(/80/.test(httpURI.spec)); httpURI = makeURI("http://foo.com"); do_check_eq(-1, httpURI.port); do_check_false(/80/.test(httpURI.spec)); httpURI = makeURI("http://foo.com:80"); do_check_eq(-1, httpURI.port); do_check_false(/80/.test(httpURI.spec)); httpURI = makeURI("http://foo.com:80"); do_check_eq(-1, httpURI.port); do_check_false(/80/.test(httpURI.spec)); httpURI = makeURI("https://foo.com"); do_check_eq(-1, httpURI.port); do_check_false(/443/.test(httpURI.spec)); httpURI = makeURI("https://foo.com:443"); do_check_eq(-1, httpURI.port); do_check_false(/443/.test(httpURI.spec)); // XXX URL parsers shouldn't set ports to default value, even when changing scheme? // not really possible given current nsIURI impls //httpURI.spec = "https://foo.com:443"; //do_check_eq(-1, httpURI.port); }