Bug 1058438 - Add additional tests for disabledHost APIs with nonascii characters in URLs. r=MattN

MozReview-Commit-ID: EsN6FNCzbLk

--HG--
extra : rebase_source : 770e87ff6d01cc865ecceab0615948b515fae245
This commit is contained in:
Saad Quadri 2016-07-21 11:26:59 -07:00
Родитель e59a7e6a9a
Коммит 32a5ca816b
1 изменённых файлов: 46 добавлений и 6 удалений

Просмотреть файл

@ -143,15 +143,55 @@ add_task(function test_rememberSignons()
});
/**
* Tests storing disabled hosts containing non-ASCII characters.
* Tests storing disabled hosts with non-ASCII characters where IDN is supported.
*/
add_task(function* test_storage_setLoginSavingEnabled_nonascii()
add_task(function* test_storage_setLoginSavingEnabled_nonascii_IDN_is_supported()
{
let hostname = "http://" + String.fromCharCode(355) + ".example.com";
Services.logins.setLoginSavingEnabled(hostname, false);
let hostname = "http://大.net";
let encoding = "http://xn--pss.net";
// Test adding disabled host with nonascii URL (http://大.net).
Services.logins.setLoginSavingEnabled(hostname, false);
yield* LoginTestUtils.reloadData();
LoginTestUtils.assertDisabledHostsEqual(Services.logins.getAllDisabledHosts(),
[hostname]);
Assert.equal(Services.logins.getLoginSavingEnabled(hostname), false);
Assert.equal(Services.logins.getLoginSavingEnabled(encoding), false);
LoginTestUtils.assertDisabledHostsEqual(Services.logins.getAllDisabledHosts(), [hostname]);
LoginTestUtils.clearData();
// Test adding disabled host with IDN ("http://xn--pss.net").
Services.logins.setLoginSavingEnabled(encoding, false);
yield* LoginTestUtils.reloadData();
Assert.equal(Services.logins.getLoginSavingEnabled(hostname), false);
Assert.equal(Services.logins.getLoginSavingEnabled(encoding), false);
LoginTestUtils.assertDisabledHostsEqual(Services.logins.getAllDisabledHosts(), [hostname]);
LoginTestUtils.clearData();
});
/**
* Tests storing disabled hosts with non-ASCII characters where IDN is not supported.
*/
add_task(function* test_storage_setLoginSavingEnabled_nonascii_IDN_not_supported()
{
let hostname = "http://√.com";
let encoding = "http://xn--19g.com";
// Test adding disabled host with nonascii URL (http://√.com).
Services.logins.setLoginSavingEnabled(hostname, false);
yield* LoginTestUtils.reloadData();
Assert.equal(Services.logins.getLoginSavingEnabled(hostname), false);
Assert.equal(Services.logins.getLoginSavingEnabled(encoding), false);
LoginTestUtils.assertDisabledHostsEqual(Services.logins.getAllDisabledHosts(), [encoding]);
LoginTestUtils.clearData();
// Test adding disabled host with IDN ("http://xn--19g.com").
Services.logins.setLoginSavingEnabled(encoding, false);
yield* LoginTestUtils.reloadData();
Assert.equal(Services.logins.getLoginSavingEnabled(hostname), false);
Assert.equal(Services.logins.getLoginSavingEnabled(encoding), false);
LoginTestUtils.assertDisabledHostsEqual(Services.logins.getAllDisabledHosts(), [encoding]);
LoginTestUtils.clearData();
});