-
Notifications
You must be signed in to change notification settings - Fork 64
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
G11n java client [BUG 754] Performance impact on the very first L3 fetch for a non-supported locale #823
G11n java client [BUG 754] Performance impact on the very first L3 fetch for a non-supported locale #823
Changes from 1 commit
f4c1214
1a4d95e
5e72b73
73d85ca
2a38107
c7f5d4f
056891a
a2ba98b
17978bd
6c69170
41a8aa1
dd2455d
e26d372
01ab69e
750c9d2
529e5cc
b40fcf9
fa123f9
30b2054
0c69787
ffc0a74
d8450e4
d7f7641
0dcd827
d06adb3
48c8558
4e45bed
6a40dc8
4c3c12d
7e0d939
baef0d0
02a96e9
78d88f7
655c223
8746915
897a03c
3a4e183
b08feb4
8f57e24
72c8799
92edfc8
2042554
ae707ff
82818d5
31d4ff6
c9f83d7
78dcc1c
9281c64
2657762
9e80f09
68467f3
d67c72e
8591973
22a5b29
ce2488b
1092963
35d1d97
ada17f1
fc60eef
3e70449
609d8e4
dd19b1c
7389f8b
5b92e44
dfb41b5
21a7105
84343d5
be8e443
b805d36
17bc16c
15da010
631de86
ffd9adb
c00f7ae
d0504c4
79b18d0
ec9f5db
2e8bd36
4e44a8c
de5c4ee
406cb2a
c80696a
79d111e
24d8d5d
23e62b6
369643f
4e67e25
636b5b4
71a87e5
b9a90e3
060666d
52e3695
2858ebc
bbe3047
fa56388
08cd96d
e89ff56
119aebd
e8a937d
9d95cd1
06b60bb
51b4dfa
778a7a1
077f19b
9424346
c25a676
db641b9
5cd06d6
6915f11
a64be3f
7128194
c4a388c
5ecea93
4c5b0a1
067d19d
711ce80
b7dabdb
d8543ec
e8094f4
9a5ef77
5011c38
33432b1
c9d3cae
adb40ec
7ab5c59
3c10089
76105b7
49c5648
d543e99
3ecf958
e6a07a1
89ff088
f1356ab
c63bc2d
beab148
2cd7713
e13b694
f1f70b3
fe535dc
0d22b9f
4870782
f451436
89d7b0d
ec6e693
65f1d08
60fb3b3
a698f20
eede3b5
2dbfc72
e63ab94
ae1dccd
6fbaab4
ff99a37
271ee08
230e21c
55764a7
e9214cb
beaa5ef
673b8fd
e8bb5b7
fe82e31
57aeb9b
a7f6d36
423090c
4723dbf
203dbb8
0a755b1
ed60327
b76346c
a6aa09e
550de8c
1599f5c
8f0a9dd
24b8e3a
22b2159
4247c99
88a0a4c
3d82802
444b0bf
d975d97
d7a9a44
534137a
7e540e9
8899bfe
5ce2453
c5e9620
d2905e3
8b1e4e9
303957e
f238d95
d5dffd6
f096330
ef3c67f
0c6f313
cfdc289
67d6c89
23d7ec8
7d51498
943bb14
3f488e0
680aab4
b10eec5
610ffd0
01e8222
e78a92e
ce6cd77
138e1f9
b1a824a
6c4bb64
a4ddbdd
a97ccfc
eb8b625
dd03ac8
f8ce5c1
c2b1fd9
6bbdfff
d8e70b7
7d8f943
b3bb30a
bdbae09
03bf400
71404e3
236ab56
7c2535c
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
@@ -146,9 +146,12 @@ public static Locale pickupLocaleFromList(Set<Locale> locales, | |||||||||||||||||||||||||
Locale preferredLocale) { | ||||||||||||||||||||||||||
Locale bestMatch = Locale.lookup(Arrays.asList(new Locale.LanguageRange(fmtToMappedLocale(preferredLocale).toLanguageTag())), locales); | ||||||||||||||||||||||||||
jessiejuachon marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
// For any Chinese locale (zh-*) that is not supported, use the fallback locale even if "zh" is supported. | ||||||||||||||||||||||||||
if (bestMatch != null && bestMatch.toLanguageTag().equals("zh") && !preferredLocale.toLanguageTag().equals("zh")) { | ||||||||||||||||||||||||||
return null; | ||||||||||||||||||||||||||
// For any Chinese locale (zh-*) that is not supported (except for zh-Hans and zh-Hant), use the fallback locale even if "zh" is supported. | ||||||||||||||||||||||||||
if (preferredLocale.getLanguage().equals("zh")) { | ||||||||||||||||||||||||||
Locale zhLocale = fmtToMappedLocale(preferredLocale); | ||||||||||||||||||||||||||
if (!locales.contains(zhLocale) && !zhLocale.toLanguageTag().equals("zh-Hans") && !zhLocale.toLanguageTag().equals("zh-Hant")) { | ||||||||||||||||||||||||||
return null; | ||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I understand you want it to be more readable. There is incorrect logic in your suggestion though. It should be |
||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||
return bestMatch; | ||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -87,17 +87,40 @@ public void testPickupLocaleFromListNotFound() { | |
Assert.assertNull(LocaleUtility.pickupLocaleFromList(new HashSet<>(Arrays.asList(supportedLocales)), Locale.forLanguageTag("fil"))); | ||
} | ||
|
||
@Test | ||
public void testPickupLocaleFromListZh() { | ||
Locale[] supportedLocales = { | ||
Locale.forLanguageTag("zh") | ||
}; | ||
Locale[] testLocales = { | ||
Locale.forLanguageTag("zh"), | ||
Locale.forLanguageTag("zh-CN"), | ||
Locale.forLanguageTag("zh-TW"), | ||
Locale.forLanguageTag("zh-HANS-CN"), | ||
Locale.forLanguageTag("zh-HANT-TW"), | ||
Locale.forLanguageTag("zh-HANS"), | ||
Locale.forLanguageTag("zh-HANT") }; | ||
|
||
String[] expectedLocales = {"zh" ,"zh", "zh", "zh", "zh", "zh", "zh"}; | ||
|
||
for (int i = 0; i < testLocales.length; i++) { | ||
String matchedLanguageTag = LocaleUtility.pickupLocaleFromList( | ||
new HashSet<>(Arrays.asList(supportedLocales)), testLocales[i]) | ||
.toLanguageTag(); | ||
|
||
logger.debug(matchedLanguageTag + "-----" + expectedLocales[i]); | ||
Assert.assertEquals(expectedLocales[i], matchedLanguageTag); | ||
} | ||
} | ||
|
||
/** | ||
* For any Chinese locale (zh-*) that is not supported, | ||
* return null so that fallback locale will be used even if "zh" is supported. | ||
* For any non-Chinese locale, return the best match (e.g. 'de' if 'de-DE' is not supported). | ||
*/ | ||
@Test | ||
public void testPickupLocaleFromList_special_case_zh_HK() { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Add one more test case: zh is supported, zh-Hans and zh-Hant aren't supported. Request zh-Hant will return null rather than zh. |
||
Locale[] supportedLocales = { Locale.forLanguageTag("de"), | ||
Locale.forLanguageTag("es"), Locale.forLanguageTag("fr"), | ||
Locale.forLanguageTag("fr-CA"), | ||
Locale.forLanguageTag("ja"), Locale.forLanguageTag("ko"), | ||
Locale[] supportedLocales = { | ||
Locale.forLanguageTag("zh"), | ||
Locale.forLanguageTag("zh-Hans"), | ||
Locale.forLanguageTag("zh-Hant") | ||
|
@@ -106,6 +129,10 @@ public void testPickupLocaleFromList_special_case_zh_HK() { | |
Assert.assertNull(LocaleUtility.pickupLocaleFromList(new HashSet<>(Arrays.asList(supportedLocales)), Locale.forLanguageTag("zh-HK"))); | ||
Assert.assertEquals("zh", LocaleUtility.pickupLocaleFromList(new HashSet<>(Arrays.asList(supportedLocales)), | ||
Locale.forLanguageTag("zh")).toLanguageTag()); | ||
Assert.assertEquals("zh-Hans", LocaleUtility.pickupLocaleFromList(new HashSet<>(Arrays.asList(supportedLocales)), | ||
Locale.forLanguageTag("zh-CN")).toLanguageTag()); | ||
Assert.assertEquals("zh-Hant", LocaleUtility.pickupLocaleFromList(new HashSet<>(Arrays.asList(supportedLocales)), | ||
Locale.forLanguageTag("zh-TW")).toLanguageTag()); | ||
} | ||
|
||
@Test | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is it necessary to judge dto locale is same as the fallback locale?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's not necessary, but it is an improvement. If we do not check for dto.getLocale == fallback and it happens, it will just try to fetch for the dto locale again and will fail again, and move on to the next item in the queue. Nonetheless, I have added the check for optimization.
Moreover, I hsve removed the following restriction to allow falling back to SOURCE messages:
!dto.getLocale().equals(ConstantsKeys.SOURCE)