gecko-dev/browser/extensions/formautofill/test/unit/test_nameUtils.js
Kris Maglione e930b89c34 Bug 1514594: Part 3 - Change ChromeUtils.import API.
***
Bug 1514594: Part 3a - Change ChromeUtils.import to return an exports object; not pollute global. r=mccr8

This changes the behavior of ChromeUtils.import() to return an exports object,
rather than a module global, in all cases except when `null` is passed as a
second argument, and changes the default behavior not to pollute the global
scope with the module's exports. Thus, the following code written for the old
model:

  ChromeUtils.import("resource://gre/modules/Services.jsm");

is approximately the same as the following, in the new model:

  var {Services} = ChromeUtils.import("resource://gre/modules/Services.jsm");

Since the two behaviors are mutually incompatible, this patch will land with a
scripted rewrite to update all existing callers to use the new model rather
than the old.
***
Bug 1514594: Part 3b - Mass rewrite all JS code to use the new ChromeUtils.import API. rs=Gijs

This was done using the followng script:

https://bitbucket.org/kmaglione/m-c-rewrites/src/tip/processors/cu-import-exports.jsm
***
Bug 1514594: Part 3c - Update ESLint plugin for ChromeUtils.import API changes. r=Standard8

Differential Revision: https://phabricator.services.mozilla.com/D16747
***
Bug 1514594: Part 3d - Remove/fix hundreds of duplicate imports from sync tests. r=Gijs

Differential Revision: https://phabricator.services.mozilla.com/D16748
***
Bug 1514594: Part 3e - Remove no-op ChromeUtils.import() calls. r=Gijs

Differential Revision: https://phabricator.services.mozilla.com/D16749
***
Bug 1514594: Part 3f.1 - Cleanup various test corner cases after mass rewrite. r=Gijs
***
Bug 1514594: Part 3f.2 - Cleanup various non-test corner cases after mass rewrite. r=Gijs

Differential Revision: https://phabricator.services.mozilla.com/D16750

--HG--
extra : rebase_source : 359574ee3064c90f33bf36c2ebe3159a24cc8895
extra : histedit_source : b93c8f42808b1599f9122d7842d2c0b3e656a594%2C64a3a4e3359dc889e2ab2b49461bab9e27fc10a7
2019-01-17 10:18:31 -08:00

287 lines
6.5 KiB
JavaScript

/**
* Tests FormAutofillNameUtils object.
*/
"use strict";
var FormAutofillNameUtils;
add_task(async function() {
({FormAutofillNameUtils} = ChromeUtils.import("resource://formautofill/FormAutofillNameUtils.jsm"));
});
// Test cases initially copied from
// https://cs.chromium.org/chromium/src/components/autofill/core/browser/autofill_data_util_unittest.cc
const TESTCASES = [
{
description: "Full name including given, middle and family names",
fullName: "Homer Jay Simpson",
nameParts: {
given: "Homer",
middle: "Jay",
family: "Simpson",
},
},
{
description: "No middle name",
fullName: "Moe Szyslak",
nameParts: {
given: "Moe",
middle: "",
family: "Szyslak",
},
},
{
description: "Common name prefixes removed",
fullName: "Reverend Timothy Lovejoy",
nameParts: {
given: "Timothy",
middle: "",
family: "Lovejoy",
},
expectedFullName: "Timothy Lovejoy",
},
{
description: "Common name suffixes removed",
fullName: "John Frink Phd",
nameParts: {
given: "John",
middle: "",
family: "Frink",
},
expectedFullName: "John Frink",
},
{
description: "Exception to the name suffix removal",
fullName: "John Ma",
nameParts: {
given: "John",
middle: "",
family: "Ma",
},
},
{
description: "Common family name prefixes not considered a middle name",
fullName: "Milhouse Van Houten",
nameParts: {
given: "Milhouse",
middle: "",
family: "Van Houten",
},
},
// CJK names have reverse order (surname goes first, given name goes second).
{
description: "Chinese name, Unihan",
fullName: "孫 德明",
nameParts: {
given: "德明",
middle: "",
family: "孫",
},
expectedFullName: "孫德明",
},
{
description: "Chinese name, Unihan, \"IDEOGRAPHIC SPACE\"",
fullName: "孫 德明",
nameParts: {
given: "德明",
middle: "",
family: "孫",
},
expectedFullName: "孫德明",
},
{
description: "Korean name, Hangul",
fullName: "홍 길동",
nameParts: {
given: "길동",
middle: "",
family: "홍",
},
expectedFullName: "홍길동",
},
{
description: "Japanese name, Unihan",
fullName: "山田 貴洋",
nameParts: {
given: "貴洋",
middle: "",
family: "山田",
},
expectedFullName: "山田貴洋",
},
// In Japanese, foreign names use 'KATAKANA MIDDLE DOT' (U+30FB) as a
// separator. There is no consensus for the ordering. For now, we use the same
// ordering as regular Japanese names ("last・first").
{
description: "Foreign name in Japanese, Katakana",
fullName: "ゲイツ・ビル",
nameParts: {
given: "ビル",
middle: "",
family: "ゲイツ",
},
expectedFullName: "ゲイツビル",
},
// 'KATAKANA MIDDLE DOT' is occasionally typoed as 'MIDDLE DOT' (U+00B7).
{
description: "Foreign name in Japanese, Katakana",
fullName: "ゲイツ·ビル",
nameParts: {
given: "ビル",
middle: "",
family: "ゲイツ",
},
expectedFullName: "ゲイツビル",
},
// CJK names don't usually have a space in the middle, but most of the time,
// the surname is only one character (in Chinese & Korean).
{
description: "Korean name, Hangul",
fullName: "최성훈",
nameParts: {
given: "성훈",
middle: "",
family: "최",
},
},
{
description: "(Simplified) Chinese name, Unihan",
fullName: "刘翔",
nameParts: {
given: "翔",
middle: "",
family: "刘",
},
},
{
description: "(Traditional) Chinese name, Unihan",
fullName: "劉翔",
nameParts: {
given: "翔",
middle: "",
family: "劉",
},
},
// There are a few exceptions. Occasionally, the surname has two characters.
{
description: "Korean name, Hangul",
fullName: "남궁도",
nameParts: {
given: "도",
middle: "",
family: "남궁",
},
},
{
description: "Korean name, Hangul",
fullName: "황보혜정",
nameParts: {
given: "혜정",
middle: "",
family: "황보",
},
},
{
description: "(Traditional) Chinese name, Unihan",
fullName: "歐陽靖",
nameParts: {
given: "靖",
middle: "",
family: "歐陽",
},
},
// In Korean, some 2-character surnames are rare/ambiguous, like "강전": "강"
// is a common surname, and "전" can be part of a given name. In those cases,
// we assume it's 1/2 for 3-character names, or 2/2 for 4-character names.
{
description: "Korean name, Hangul",
fullName: "강전희",
nameParts: {
given: "전희",
middle: "",
family: "강",
},
},
{
description: "Korean name, Hangul",
fullName: "황목치승",
nameParts: {
given: "치승",
middle: "",
family: "황목",
},
},
// It occasionally happens that a full name is 2 characters, 1/1.
{
description: "Korean name, Hangul",
fullName: "이도",
nameParts: {
given: "도",
middle: "",
family: "이",
},
},
{
description: "Korean name, Hangul",
fullName: "孫文",
nameParts: {
given: "文",
middle: "",
family: "孫",
},
},
// These are no CJK names for us, they're just bogus.
{
description: "Bogus",
fullName: "Homer シンプソン",
nameParts: {
given: "Homer",
middle: "",
family: "シンプソン",
},
},
{
description: "Bogus",
fullName: "ホーマー Simpson",
nameParts: {
given: "ホーマー",
middle: "",
family: "Simpson",
},
},
{
description: "CJK has a middle-name, too unusual",
fullName: "반 기 문",
nameParts: {
given: "반",
middle: "기",
family: "문",
},
},
];
add_task(async function test_splitName() {
TESTCASES.forEach(testcase => {
if (testcase.fullName) {
info("Starting testcase: " + testcase.description);
let nameParts = FormAutofillNameUtils.splitName(testcase.fullName);
Assert.deepEqual(nameParts, testcase.nameParts);
}
});
});
add_task(async function test_joinName() {
TESTCASES.forEach(testcase => {
info("Starting testcase: " + testcase.description);
let name = FormAutofillNameUtils.joinNameParts(testcase.nameParts);
Assert.equal(name, testcase.expectedFullName || testcase.fullName);
});
});