2007-04-27 07:50:15 -07:00
|
|
|
function run_test() {
|
|
|
|
var tld =
|
|
|
|
Cc["@mozilla.org/network/effective-tld-service;1"].
|
|
|
|
getService(Ci.nsIEffectiveTLDService);
|
|
|
|
|
2007-10-25 01:14:26 -07:00
|
|
|
var etld;
|
|
|
|
|
|
|
|
do_check_eq(tld.getPublicSuffixFromHost("localhost"), "localhost");
|
|
|
|
do_check_eq(tld.getPublicSuffixFromHost("localhost."), "localhost.");
|
|
|
|
do_check_eq(tld.getPublicSuffixFromHost("domain.com"), "com");
|
|
|
|
do_check_eq(tld.getPublicSuffixFromHost("domain.com."), "com.");
|
|
|
|
do_check_eq(tld.getPublicSuffixFromHost("domain.co.uk"), "co.uk");
|
|
|
|
do_check_eq(tld.getPublicSuffixFromHost("domain.co.uk."), "co.uk.");
|
2010-01-12 10:29:20 -08:00
|
|
|
do_check_eq(tld.getPublicSuffixFromHost("co.uk"), "co.uk");
|
2007-10-25 01:14:26 -07:00
|
|
|
do_check_eq(tld.getBaseDomainFromHost("domain.co.uk"), "domain.co.uk");
|
|
|
|
do_check_eq(tld.getBaseDomainFromHost("domain.co.uk."), "domain.co.uk.");
|
|
|
|
|
2010-01-12 10:29:20 -08:00
|
|
|
try {
|
|
|
|
etld = tld.getPublicSuffixFromHost("");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_INSUFFICIENT_DOMAIN_LEVELS);
|
|
|
|
}
|
|
|
|
|
2007-10-25 01:14:26 -07:00
|
|
|
try {
|
|
|
|
etld = tld.getBaseDomainFromHost("domain.co.uk", 1);
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
2010-01-12 10:29:20 -08:00
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_INSUFFICIENT_DOMAIN_LEVELS);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getBaseDomainFromHost("co.uk");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_INSUFFICIENT_DOMAIN_LEVELS);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getBaseDomainFromHost("");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_INSUFFICIENT_DOMAIN_LEVELS);
|
2007-10-25 01:14:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getPublicSuffixFromHost("1.2.3.4");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
2010-01-12 10:29:20 -08:00
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_HOST_IS_IP_ADDRESS);
|
2007-10-25 01:14:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getPublicSuffixFromHost("2010:836B:4179::836B:4179");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
2010-01-12 10:29:20 -08:00
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_HOST_IS_IP_ADDRESS);
|
2007-10-25 01:14:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getPublicSuffixFromHost("3232235878");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
2010-01-12 10:29:20 -08:00
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_HOST_IS_IP_ADDRESS);
|
2007-10-25 01:14:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getPublicSuffixFromHost("::ffff:192.9.5.5");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
2010-01-12 10:29:20 -08:00
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_HOST_IS_IP_ADDRESS);
|
2007-10-25 01:14:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getPublicSuffixFromHost("::1");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
2010-01-12 10:29:20 -08:00
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_HOST_IS_IP_ADDRESS);
|
2007-10-25 01:14:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Check IP addresses with trailing dot as well, Necko sometimes accepts
|
|
|
|
// those (depending on operating system, see bug 380543)
|
|
|
|
try {
|
|
|
|
etld = tld.getPublicSuffixFromHost("127.0.0.1.");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
2010-01-12 10:29:20 -08:00
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_HOST_IS_IP_ADDRESS);
|
2007-10-25 01:14:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getPublicSuffixFromHost("::ffff:127.0.0.1.");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
2010-01-12 10:29:20 -08:00
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_HOST_IS_IP_ADDRESS);
|
2007-10-25 01:14:26 -07:00
|
|
|
}
|
2007-12-04 18:28:37 -08:00
|
|
|
|
|
|
|
// check normalization: output should be consistent with
|
|
|
|
// nsIURI::GetAsciiHost(), i.e. lowercased and ASCII/ACE encoded
|
|
|
|
var ioService = Components.classes["@mozilla.org/network/io-service;1"]
|
|
|
|
.getService(Components.interfaces.nsIIOService);
|
|
|
|
|
|
|
|
var uri = ioService.newURI("http://b\u00FCcher.co.uk", null, null);
|
|
|
|
do_check_eq(tld.getBaseDomain(uri), "xn--bcher-kva.co.uk");
|
|
|
|
do_check_eq(tld.getBaseDomainFromHost("b\u00FCcher.co.uk"), "xn--bcher-kva.co.uk");
|
|
|
|
do_check_eq(tld.getPublicSuffix(uri), "co.uk");
|
|
|
|
do_check_eq(tld.getPublicSuffixFromHost("b\u00FCcher.co.uk"), "co.uk");
|
2010-01-12 10:29:20 -08:00
|
|
|
|
|
|
|
// check that malformed hosts are rejected as invalid args
|
|
|
|
try {
|
|
|
|
etld = tld.getBaseDomainFromHost("domain.co.uk..");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_ILLEGAL_VALUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getBaseDomainFromHost("domain.co..uk");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_ILLEGAL_VALUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getBaseDomainFromHost(".domain.co.uk");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_ILLEGAL_VALUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getBaseDomainFromHost(".domain.co.uk");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_ILLEGAL_VALUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getBaseDomainFromHost(".");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_ILLEGAL_VALUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
etld = tld.getBaseDomainFromHost("..");
|
|
|
|
do_throw("this should fail");
|
|
|
|
} catch(e) {
|
|
|
|
do_check_eq(e.result, Cr.NS_ERROR_ILLEGAL_VALUE);
|
|
|
|
}
|
2007-04-27 07:50:15 -07:00
|
|
|
}
|