Commit e6985866 authored by Changwan Ryu's avatar Changwan Ryu Committed by Commit Bot

Expand accept languages

Expand accept languages by adding base language from language-country
pair, using the same logic that Chrome is already using.
This aligns with this W3C doc:
https://www.w3.org/International/questions/qa-lang-priorities#langtagdetail

Currently not behind a feature, will be followed by a change to use a
feature.
Also slightly refactoring tests to improve readability.

Bug: 882587, 737232
Change-Id: I1e067bde4ae5b00b6b7c3be765a9cd97bbbb96df
Reviewed-on: https://chromium-review.googlesource.com/c/1286936
Commit-Queue: Changwan Ryu <changwan@chromium.org>
Reviewed-by: default avatarBo <boliu@chromium.org>
Reviewed-by: default avatarNate Fischer <ntfschr@chromium.org>
Cr-Commit-Position: refs/heads/master@{#601334}
parent 0e906366
...@@ -24,6 +24,8 @@ std::string AwHttpUserAgentSettings::GetAcceptLanguage() const { ...@@ -24,6 +24,8 @@ std::string AwHttpUserAgentSettings::GetAcceptLanguage() const {
std::string new_aw_accept_language = std::string new_aw_accept_language =
AwContentBrowserClient::GetAcceptLangsImpl(); AwContentBrowserClient::GetAcceptLangsImpl();
if (new_aw_accept_language != last_aw_accept_language_) { if (new_aw_accept_language != last_aw_accept_language_) {
new_aw_accept_language =
net::HttpUtil::ExpandLanguageList(new_aw_accept_language);
last_http_accept_language_ = last_http_accept_language_ =
net::HttpUtil::GenerateAcceptLanguageHeader(new_aw_accept_language); net::HttpUtil::GenerateAcceptLanguageHeader(new_aw_accept_language);
last_aw_accept_language_ = new_aw_accept_language; last_aw_accept_language_ = new_aw_accept_language;
......
...@@ -9,7 +9,6 @@ import android.os.Build; ...@@ -9,7 +9,6 @@ import android.os.Build;
import android.os.LocaleList; import android.os.LocaleList;
import android.support.test.InstrumentationRegistry; import android.support.test.InstrumentationRegistry;
import android.support.test.filters.SmallTest; import android.support.test.filters.SmallTest;
import android.text.TextUtils;
import org.junit.After; import org.junit.After;
import org.junit.Assert; import org.junit.Assert;
...@@ -20,12 +19,10 @@ import org.junit.runner.RunWith; ...@@ -20,12 +19,10 @@ import org.junit.runner.RunWith;
import org.chromium.android_webview.AwContents; import org.chromium.android_webview.AwContents;
import org.chromium.android_webview.test.util.JSUtils; import org.chromium.android_webview.test.util.JSUtils;
import org.chromium.base.LocaleUtils;
import org.chromium.base.test.util.Feature; import org.chromium.base.test.util.Feature;
import org.chromium.base.test.util.MinAndroidSdkLevel; import org.chromium.base.test.util.MinAndroidSdkLevel;
import org.chromium.net.test.EmbeddedTestServer; import org.chromium.net.test.EmbeddedTestServer;
import java.util.Arrays;
import java.util.Locale; import java.util.Locale;
import java.util.regex.Pattern; import java.util.regex.Pattern;
...@@ -80,6 +77,10 @@ public class AcceptLanguageTest { ...@@ -80,6 +77,10 @@ public class AcceptLanguageTest {
return COMMA_AND_OPTIONAL_Q_VALUE.split(mActivityTestRule.maybeStripDoubleQuotes(raw)); return COMMA_AND_OPTIONAL_Q_VALUE.split(mActivityTestRule.maybeStripDoubleQuotes(raw));
} }
private boolean isEnUsLocale() {
return "en-US".equals(Locale.getDefault().toLanguageTag());
}
/** /**
* Verify that the Accept Language string is correct. * Verify that the Accept Language string is correct.
*/ */
...@@ -87,6 +88,14 @@ public class AcceptLanguageTest { ...@@ -87,6 +88,14 @@ public class AcceptLanguageTest {
@SmallTest @SmallTest
@Feature({"AndroidWebView"}) @Feature({"AndroidWebView"})
public void testAcceptLanguage() throws Throwable { public void testAcceptLanguage() throws Throwable {
// Make sure that the current locale is en-US.
if (!isEnUsLocale()) {
Locale.setDefault(new Locale("en", "US"));
AwContents.updateDefaultLocale();
mAwContents.getSettings().updateAcceptLanguages();
}
Assert.assertTrue(isEnUsLocale());
mActivityTestRule.getAwSettingsOnUiThread(mAwContents).setJavaScriptEnabled(true); mActivityTestRule.getAwSettingsOnUiThread(mAwContents).setJavaScriptEnabled(true);
// This should yield a lightly formatted page with the contents of the Accept-Language // This should yield a lightly formatted page with the contents of the Accept-Language
...@@ -94,18 +103,18 @@ public class AcceptLanguageTest { ...@@ -94,18 +103,18 @@ public class AcceptLanguageTest {
String url = mTestServer.getURL("/echoheader?Accept-Language"); String url = mTestServer.getURL("/echoheader?Accept-Language");
mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url); mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url);
// Note that we extend the base language from language-region pair.
String[] acceptLanguages = getAcceptLanguages( String[] acceptLanguages = getAcceptLanguages(
mActivityTestRule.getJavaScriptResultBodyTextContent(mAwContents, mContentsClient)); mActivityTestRule.getJavaScriptResultBodyTextContent(mAwContents, mContentsClient));
Assert.assertEquals(LocaleUtils.getDefaultLocaleString(), acceptLanguages[0]); Assert.assertArrayEquals(new String[] {"en-US", "en"}, acceptLanguages);
// Our accept language list in user agent is different from navigator.languages, which is
// fine.
String[] acceptLanguagesJs = getAcceptLanguages(JSUtils.executeJavaScriptAndWaitForResult( String[] acceptLanguagesJs = getAcceptLanguages(JSUtils.executeJavaScriptAndWaitForResult(
InstrumentationRegistry.getInstrumentation(), mAwContents, InstrumentationRegistry.getInstrumentation(), mAwContents,
mContentsClient.getOnEvaluateJavaScriptResultHelper(), mContentsClient.getOnEvaluateJavaScriptResultHelper(),
"navigator.languages.join(',')")); "navigator.languages.join(',')"));
Assert.assertEquals(acceptLanguagesJs.length, acceptLanguages.length); Assert.assertArrayEquals(new String[] {"en-US"}, acceptLanguagesJs);
for (int i = 0; i < acceptLanguagesJs.length; ++i) {
Assert.assertEquals(acceptLanguagesJs[i], acceptLanguages[i]);
}
// Test locale change at run time // Test locale change at run time
Locale.setDefault(new Locale("de", "DE")); Locale.setDefault(new Locale("de", "DE"));
...@@ -116,7 +125,8 @@ public class AcceptLanguageTest { ...@@ -116,7 +125,8 @@ public class AcceptLanguageTest {
acceptLanguages = getAcceptLanguages( acceptLanguages = getAcceptLanguages(
mActivityTestRule.getJavaScriptResultBodyTextContent(mAwContents, mContentsClient)); mActivityTestRule.getJavaScriptResultBodyTextContent(mAwContents, mContentsClient));
Assert.assertEquals(LocaleUtils.getDefaultLocaleString(), acceptLanguages[0]); // Note that we extend the base language from language-region pair.
Assert.assertArrayEquals(new String[] {"de-DE", "de", "en-US", "en"}, acceptLanguages);
} }
/** /**
...@@ -130,26 +140,29 @@ public class AcceptLanguageTest { ...@@ -130,26 +140,29 @@ public class AcceptLanguageTest {
@SuppressLint("NewApi") @SuppressLint("NewApi")
@Feature({"AndroidWebView"}) @Feature({"AndroidWebView"})
public void testAcceptLanguagesWithenUS() throws Throwable { public void testAcceptLanguagesWithenUS() throws Throwable {
LocaleList.setDefault(new LocaleList(new Locale("ko", "KR")));
AwContents.updateDefaultLocale();
mAwContents.getSettings().updateAcceptLanguages();
mActivityTestRule.getAwSettingsOnUiThread(mAwContents).setJavaScriptEnabled(true); mActivityTestRule.getAwSettingsOnUiThread(mAwContents).setJavaScriptEnabled(true);
// This should yield a lightly formatted page with the contents of the Accept-Language // This should yield a lightly formatted page with the contents of the Accept-Language
// header, e.g. "en-US" or "de-DE,en-US;q=0.8", as the only text content. // header, e.g. "en-US,en" or "de-DE,de,en-US,en;q=0.8", as the only text content.
String url = mTestServer.getURL("/echoheader?Accept-Language"); String url = mTestServer.getURL("/echoheader?Accept-Language");
mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url); mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url);
String[] acceptLanguages = getAcceptLanguages( // Note that we extend accept languages.
mActivityTestRule.getJavaScriptResultBodyTextContent(mAwContents, mContentsClient)); Assert.assertArrayEquals(new String[] {"ko-KR", "ko", "en-US", "en"},
Assert.assertEquals( getAcceptLanguages(mActivityTestRule.getJavaScriptResultBodyTextContent(
LocaleUtils.getDefaultLocaleListString(), TextUtils.join(",", acceptLanguages)); mAwContents, mContentsClient)));
// Our accept language list in user agent is different from navigator.languages, which is
// fine.
String[] acceptLanguagesJs = getAcceptLanguages(JSUtils.executeJavaScriptAndWaitForResult( String[] acceptLanguagesJs = getAcceptLanguages(JSUtils.executeJavaScriptAndWaitForResult(
InstrumentationRegistry.getInstrumentation(), mAwContents, InstrumentationRegistry.getInstrumentation(), mAwContents,
mContentsClient.getOnEvaluateJavaScriptResultHelper(), mContentsClient.getOnEvaluateJavaScriptResultHelper(),
"navigator.languages.join(',')")); "navigator.languages.join(',')"));
Assert.assertEquals(acceptLanguagesJs.length, acceptLanguages.length); Assert.assertArrayEquals(new String[] {"ko-KR", "en-US"}, acceptLanguagesJs);
for (int i = 0; i < acceptLanguagesJs.length; ++i) {
Assert.assertEquals(acceptLanguagesJs[i], acceptLanguages[i]);
}
// Test locales that contain "en-US" change at run time // Test locales that contain "en-US" change at run time
LocaleList.setDefault(new LocaleList(new Locale("de", "DE"), new Locale("en", "US"))); LocaleList.setDefault(new LocaleList(new Locale("de", "DE"), new Locale("en", "US")));
...@@ -158,10 +171,11 @@ public class AcceptLanguageTest { ...@@ -158,10 +171,11 @@ public class AcceptLanguageTest {
mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url); mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url);
acceptLanguages = getAcceptLanguages( // Note that we extend the base language from language-region pair.
mActivityTestRule.getJavaScriptResultBodyTextContent(mAwContents, mContentsClient)); // Also, we put en-US at the lowest priority.
Assert.assertEquals( Assert.assertArrayEquals(new String[] {"de-DE", "de", "en-US", "en"},
LocaleUtils.getDefaultLocaleListString(), TextUtils.join(",", acceptLanguages)); getAcceptLanguages(mActivityTestRule.getJavaScriptResultBodyTextContent(
mAwContents, mContentsClient)));
// Test locales that contain "en-us" change at run time // Test locales that contain "en-us" change at run time
LocaleList.setDefault(new LocaleList(new Locale("de", "DE"), new Locale("en", "us"))); LocaleList.setDefault(new LocaleList(new Locale("de", "DE"), new Locale("en", "us")));
...@@ -170,10 +184,9 @@ public class AcceptLanguageTest { ...@@ -170,10 +184,9 @@ public class AcceptLanguageTest {
mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url); mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url);
acceptLanguages = getAcceptLanguages( Assert.assertArrayEquals(new String[] {"de-DE", "de", "en-US", "en"},
mActivityTestRule.getJavaScriptResultBodyTextContent(mAwContents, mContentsClient)); getAcceptLanguages(mActivityTestRule.getJavaScriptResultBodyTextContent(
Assert.assertEquals( mAwContents, mContentsClient)));
LocaleUtils.getDefaultLocaleListString(), TextUtils.join(",", acceptLanguages));
// Test locales that do not contain "en-us" or "en-US" change at run time // Test locales that do not contain "en-us" or "en-US" change at run time
LocaleList.setDefault(new LocaleList(new Locale("de", "DE"), new Locale("ja", "JP"))); LocaleList.setDefault(new LocaleList(new Locale("de", "DE"), new Locale("ja", "JP")));
...@@ -182,10 +195,8 @@ public class AcceptLanguageTest { ...@@ -182,10 +195,8 @@ public class AcceptLanguageTest {
mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url); mActivityTestRule.loadUrlSync(mAwContents, mContentsClient.getOnPageFinishedHelper(), url);
acceptLanguages = getAcceptLanguages( Assert.assertArrayEquals(new String[] {"de-DE", "de", "ja-JP", "ja", "en-US", "en"},
mActivityTestRule.getJavaScriptResultBodyTextContent(mAwContents, mContentsClient)); getAcceptLanguages(mActivityTestRule.getJavaScriptResultBodyTextContent(
String[] acceptLangs = Arrays.copyOfRange(acceptLanguages, 0, acceptLanguages.length - 1); mAwContents, mContentsClient)));
Assert.assertEquals(
LocaleUtils.getDefaultLocaleListString(), TextUtils.join(",", acceptLangs));
} }
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment