mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 1175347 - Add a JSAPI test for exposing availability of locales derived from the default locale. r=itsatest, rs=till over IRL
This commit is contained in:
parent
aeb8ced522
commit
f0731f7010
@ -47,6 +47,7 @@ UNIFIED_SOURCES += [
|
||||
'testHashTable.cpp',
|
||||
'testIndexToString.cpp',
|
||||
'testIntern.cpp',
|
||||
'testIntlAvailableLocales.cpp',
|
||||
'testIntString.cpp',
|
||||
'testIntTypesABI.cpp',
|
||||
'testIsInsideNursery.cpp',
|
||||
|
58
js/src/jsapi-tests/testIntlAvailableLocales.cpp
Normal file
58
js/src/jsapi-tests/testIntlAvailableLocales.cpp
Normal file
@ -0,0 +1,58 @@
|
||||
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
||||
* vim: set ts=8 sts=4 et sw=4 tw=99:
|
||||
*/
|
||||
/* 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/. */
|
||||
|
||||
#include "jsapi-tests/tests.h"
|
||||
|
||||
BEGIN_TEST(testIntlAvailableLocales)
|
||||
{
|
||||
// This test should only attempt to run if we have Intl support.
|
||||
JS::Rooted<JS::Value> haveIntl(cx);
|
||||
EVAL("typeof Intl !== 'undefined'", &haveIntl);
|
||||
if (!haveIntl.toBoolean())
|
||||
return true;
|
||||
|
||||
// Assumption: our Intl support always includes "de" (German) support,
|
||||
// and our Intl support *does not* natively support de-ZA-ghijk. :-)
|
||||
CHECK(JS_SetDefaultLocale(rt, "de-ZA-abcde-x-private"));
|
||||
|
||||
EXEC("if (Intl.Collator().resolvedOptions().locale !== 'de-ZA-abcde-x-private') \n"
|
||||
" throw 'unexpected default locale';");
|
||||
EXEC("var used = Intl.Collator('de-ZA-abcde').resolvedOptions().locale; \n"
|
||||
"if (used !== 'de-ZA-abcde') \n"
|
||||
" throw 'bad locale when using truncated default: ' + used;");
|
||||
EXEC("if (Intl.Collator('de-ZA').resolvedOptions().locale !== 'de-ZA') \n"
|
||||
" throw 'bad locale when using more-truncated default';");
|
||||
EXEC("if (Intl.Collator('de-ZA-ghijk').resolvedOptions().locale !== 'de-ZA') \n"
|
||||
" throw 'unexpected default locale';");
|
||||
|
||||
EXEC("if (Intl.Collator('de-ZA-abcde-x-private', { localeMatcher: 'lookup' }).resolvedOptions().locale !== \n"
|
||||
" 'de-ZA-abcde-x-private') \n"
|
||||
"{ \n"
|
||||
" throw 'unexpected default locale with lookup matcher'; \n"
|
||||
"}");
|
||||
EXEC("if (Intl.Collator('de-ZA-abcde').resolvedOptions().locale !== 'de-ZA-abcde') \n"
|
||||
" throw 'bad locale when using truncated default';");
|
||||
EXEC("if (Intl.Collator('de-ZA').resolvedOptions().locale !== 'de-ZA') \n"
|
||||
" throw 'bad locale when using more-truncated default';");
|
||||
EXEC("if (Intl.Collator('de').resolvedOptions().locale !== 'de') \n"
|
||||
" throw 'bad locale when using most-truncated default';");
|
||||
|
||||
CHECK(JS_SetDefaultLocale(rt, "en-US-u-co-phonebk"));
|
||||
EXEC("if (Intl.Collator().resolvedOptions().locale !== 'en-US') \n"
|
||||
" throw 'unexpected default locale where proposed default included a Unicode extension';");
|
||||
|
||||
CHECK(JS_SetDefaultLocale(rt, "this is not a language tag at all, yo"));
|
||||
|
||||
EXEC("if (Intl.Collator().resolvedOptions().locale !== 'en-GB') \n"
|
||||
" throw 'unexpected last-ditch locale';");
|
||||
EXEC("if (Intl.Collator('en-GB').resolvedOptions().locale !== 'en-GB') \n"
|
||||
" throw 'unexpected used locale when specified, with last-ditch locale as default';");
|
||||
|
||||
JS_ResetDefaultLocale(rt);
|
||||
return true;
|
||||
}
|
||||
END_TEST(testIntlAvailableLocales)
|
Loading…
Reference in New Issue
Block a user