Commit 6ce17133 authored by Alexander Alekseev's avatar Alexander Alekseev Committed by Commit Bot

Chrome OS: Fix and re-enable OobeLocalizationTest

Bug: 633246
Change-Id: Id6c302696c955401a991c0235d86f05d03019036
Reviewed-on: https://chromium-review.googlesource.com/c/1355045Reviewed-by: default avatarJacob Dufault <jdufault@chromium.org>
Commit-Queue: Alexander Alekseev <alemate@chromium.org>
Cr-Commit-Position: refs/heads/master@{#612867}
parent 345667b0
...@@ -47,8 +47,13 @@ namespace { ...@@ -47,8 +47,13 @@ namespace {
const int kTimeoutSeconds = 2; const int kTimeoutSeconds = 2;
// OOBE constants. // OOBE constants.
const char kLocaleSelect[] = "language-select"; const char kLanguageSelect[] = "languageSelect";
const char kKeyboardSelect[] = "keyboard-select"; const char kKeyboardSelect[] = "keyboardSelect";
std::string GetGetSelectStatement(const std::string& selectId) {
return "document.getElementById('oobe-welcome-md').$." + selectId +
".$.select";
}
const char kUSLayout[] = "xkb:us::eng"; const char kUSLayout[] = "xkb:us::eng";
class TimedRunLoop { class TimedRunLoop {
...@@ -167,23 +172,21 @@ struct LocalizationTestParams { ...@@ -167,23 +172,21 @@ struct LocalizationTestParams {
{"ru,de", "xkb:ru::rus", "ru,de", kUSLayout, "xkb:us::eng"}, {"ru,de", "xkb:ru::rus", "ru,de", kUSLayout, "xkb:us::eng"},
// TODO(alemate/michaelpg): Figure out why these tests are failing
// and re-enable them. crbug.com/422702.
// ------------------ Regional Locales // ------------------ Regional Locales
// Syntetic example to test correct merging of different locales. // Syntetic example to test correct merging of different locales.
// {"fr-CH,it-CH,de-CH", {"fr-CH,it-CH,de-CH",
// "xkb:fr::fra,xkb:it::ita,xkb:de::ger", "xkb:fr::fra,xkb:it::ita,xkb:de::ger",
// "fr-CH,it-CH,de-CH", "fr-CH,it-CH,de-CH",
// "xkb:fr::fra", "xkb:fr::fra",
// "xkb:fr::fra,xkb:it::ita,xkb:de::ger,[xkb:be::fra,xkb:ca::fra," "xkb:fr::fra,xkb:it::ita,xkb:de::ger,[xkb:be::fra,xkb:ca::fra,"
// "xkb:ch:fr:fra,xkb:ca:multix:fra,xkb:us::eng]"}, "xkb:ch:fr:fra,xkb:ca:multix:fra,xkb:us::eng]"},
// Another syntetic example. Check that british keyboard is available. // Another syntetic example. Check that british keyboard is available.
// {"en-AU", {"en-AU",
// "xkb:us::eng", "xkb:us::eng",
// "en-AU", "en-AU",
// "xkb:us::eng", "xkb:us::eng",
// "xkb:us::eng,[xkb:gb:extd:eng,xkb:gb:dvorak:eng]"}, "xkb:us::eng,[xkb:gb:extd:eng,xkb:gb:dvorak:eng]"},
}; };
class OobeLocalizationTest class OobeLocalizationTest
...@@ -247,11 +250,11 @@ bool OobeLocalizationTest::VerifyInitialOptions(const char* select_id, ...@@ -247,11 +250,11 @@ bool OobeLocalizationTest::VerifyInitialOptions(const char* select_id,
bool check_separator) { bool check_separator) {
const std::string expression = base::StringPrintf( const std::string expression = base::StringPrintf(
"(function () {\n" "(function () {\n"
" var select = document.querySelector('#%s');\n" " let select = %s;\n"
" if (!select)\n" " if (!select)\n"
" return false;\n" " return false;\n"
" var values = '%s'.split(',');\n" " let values = '%s'.split(',');\n"
" var correct = select.selectedIndex == 0;\n" " let correct = select.selectedIndex == 0;\n"
" for (var i = 0; i < values.length && correct; i++) {\n" " for (var i = 0; i < values.length && correct; i++) {\n"
" if (select.options[i].value != values[i])\n" " if (select.options[i].value != values[i])\n"
" correct = false;\n" " correct = false;\n"
...@@ -260,7 +263,7 @@ bool OobeLocalizationTest::VerifyInitialOptions(const char* select_id, ...@@ -260,7 +263,7 @@ bool OobeLocalizationTest::VerifyInitialOptions(const char* select_id,
" correct = select.children[values.length].tagName === 'OPTGROUP';\n" " correct = select.children[values.length].tagName === 'OPTGROUP';\n"
" return correct;\n" " return correct;\n"
"})()", "})()",
select_id, values, check_separator); GetGetSelectStatement(select_id).c_str(), values, check_separator);
const bool execute_status = checker.GetBool(expression); const bool execute_status = checker.GetBool(expression);
EXPECT_TRUE(execute_status) << expression; EXPECT_TRUE(execute_status) << expression;
return execute_status; return execute_status;
...@@ -270,7 +273,7 @@ bool OobeLocalizationTest::VerifyOptionExists(const char* select_id, ...@@ -270,7 +273,7 @@ bool OobeLocalizationTest::VerifyOptionExists(const char* select_id,
const char* value) { const char* value) {
const std::string expression = base::StringPrintf( const std::string expression = base::StringPrintf(
"(function () {\n" "(function () {\n"
" var select = document.querySelector('#%s');\n" " var select = %s;\n"
" if (!select)\n" " if (!select)\n"
" return false;\n" " return false;\n"
" for (var i = 0; i < select.options.length; i++) {\n" " for (var i = 0; i < select.options.length; i++) {\n"
...@@ -279,7 +282,7 @@ bool OobeLocalizationTest::VerifyOptionExists(const char* select_id, ...@@ -279,7 +282,7 @@ bool OobeLocalizationTest::VerifyOptionExists(const char* select_id,
" }\n" " }\n"
" return false;\n" " return false;\n"
"})()", "})()",
select_id, value); GetGetSelectStatement(select_id).c_str(), value);
const bool execute_status = checker.GetBool(expression); const bool execute_status = checker.GetBool(expression);
EXPECT_TRUE(execute_status) << expression; EXPECT_TRUE(execute_status) << expression;
return execute_status; return execute_status;
...@@ -287,13 +290,11 @@ bool OobeLocalizationTest::VerifyOptionExists(const char* select_id, ...@@ -287,13 +290,11 @@ bool OobeLocalizationTest::VerifyOptionExists(const char* select_id,
std::string OobeLocalizationTest::DumpOptions(const char* select_id) { std::string OobeLocalizationTest::DumpOptions(const char* select_id) {
const std::string expression = base::StringPrintf( const std::string expression = base::StringPrintf(
"\n"
"(function () {\n" "(function () {\n"
" var selector = '#%s';\n" " var select = %s;\n"
" var divider = ',';\n" " var divider = ',';\n"
" var select = document.querySelector(selector);\n"
" if (!select)\n" " if (!select)\n"
" return 'document.querySelector(' + selector + ') failed.';\n" " return 'select statement for \"%s\" failed.';\n"
" var dumpOptgroup = function(group) {\n" " var dumpOptgroup = function(group) {\n"
" var result = '';\n" " var result = '';\n"
" for (var i = 0; i < group.children.length; i++) {\n" " for (var i = 0; i < group.children.length; i++) {\n"
...@@ -329,7 +330,7 @@ std::string OobeLocalizationTest::DumpOptions(const char* select_id) { ...@@ -329,7 +330,7 @@ std::string OobeLocalizationTest::DumpOptions(const char* select_id) {
" }\n" " }\n"
" return result;\n" " return result;\n"
"})()\n", "})()\n",
select_id); GetGetSelectStatement(select_id).c_str(), select_id);
return checker.GetString(expression); return checker.GetString(expression);
} }
...@@ -366,10 +367,11 @@ void OobeLocalizationTest::RunLocalizationTest() { ...@@ -366,10 +367,11 @@ void OobeLocalizationTest::RunLocalizationTest() {
const std::string first_language = const std::string first_language =
expected_locale.substr(0, expected_locale.find(',')); expected_locale.substr(0, expected_locale.find(','));
bool done = false; bool done = false;
const std::string get_select_statement =
GetGetSelectStatement(kLanguageSelect);
const std::string waiting_script = base::StringPrintf( const std::string waiting_script = base::StringPrintf(
"var screenElement = document.getElementById('language-select');"
"function SendReplyIfAcceptEnabled() {" "function SendReplyIfAcceptEnabled() {"
" if ($('language-select').value != '%s')" " if (%s.value != '%s')"
" return false;" " return false;"
" domAutomationController.send(true);" " domAutomationController.send(true);"
" observer.disconnect();" " observer.disconnect();"
...@@ -377,10 +379,11 @@ void OobeLocalizationTest::RunLocalizationTest() { ...@@ -377,10 +379,11 @@ void OobeLocalizationTest::RunLocalizationTest() {
"}" "}"
"var observer = new MutationObserver(SendReplyIfAcceptEnabled);" "var observer = new MutationObserver(SendReplyIfAcceptEnabled);"
"if (!SendReplyIfAcceptEnabled()) {" "if (!SendReplyIfAcceptEnabled()) {"
" var options = { attributes: true };" " let options = { attributes: true };"
" observer.observe(screenElement, options);" " observer.observe(%s, options);"
"}", "}",
first_language.c_str()); get_select_statement.c_str(), first_language.c_str(),
get_select_statement.c_str());
ASSERT_TRUE(content::ExecuteScriptAndExtractBool( ASSERT_TRUE(content::ExecuteScriptAndExtractBool(
LoginDisplayHost::default_host()->GetOobeUI()->web_ui()->GetWebContents(), LoginDisplayHost::default_host()->GetOobeUI()->web_ui()->GetWebContents(),
...@@ -391,15 +394,17 @@ void OobeLocalizationTest::RunLocalizationTest() { ...@@ -391,15 +394,17 @@ void OobeLocalizationTest::RunLocalizationTest() {
->web_ui() ->web_ui()
->GetWebContents()); ->GetWebContents());
if (!VerifyInitialOptions(kLocaleSelect, expected_locale.c_str(), true)) { if (!VerifyInitialOptions(kLanguageSelect, expected_locale.c_str(), true)) {
LOG(ERROR) << "Actual value of " << kLocaleSelect << ":\n" LOG(ERROR) << "Actual value of " << kLanguageSelect << ":\n"
<< DumpOptions(kLocaleSelect); << DumpOptions(kLanguageSelect);
EXPECT_TRUE(false);
} }
if (!VerifyInitialOptions( if (!VerifyInitialOptions(
kKeyboardSelect, kKeyboardSelect,
TranslateXKB2Extension(expected_keyboard_layout).c_str(), false)) { TranslateXKB2Extension(expected_keyboard_layout).c_str(), false)) {
LOG(ERROR) << "Actual value of " << kKeyboardSelect << ":\n" LOG(ERROR) << "Actual value of " << kKeyboardSelect << ":\n"
<< DumpOptions(kKeyboardSelect); << DumpOptions(kKeyboardSelect);
EXPECT_TRUE(false);
} }
// Make sure we have a fallback keyboard. // Make sure we have a fallback keyboard.
...@@ -408,6 +413,7 @@ void OobeLocalizationTest::RunLocalizationTest() { ...@@ -408,6 +413,7 @@ void OobeLocalizationTest::RunLocalizationTest() {
extension_ime_util::GetInputMethodIDByEngineID(kUSLayout).c_str())) { extension_ime_util::GetInputMethodIDByEngineID(kUSLayout).c_str())) {
LOG(ERROR) << "Actual value of " << kKeyboardSelect << ":\n" LOG(ERROR) << "Actual value of " << kKeyboardSelect << ":\n"
<< DumpOptions(kKeyboardSelect); << DumpOptions(kKeyboardSelect);
EXPECT_TRUE(false);
} }
// Note, that sort order is locale-specific, but is unlikely to change. // Note, that sort order is locale-specific, but is unlikely to change.
...@@ -423,7 +429,7 @@ void OobeLocalizationTest::RunLocalizationTest() { ...@@ -423,7 +429,7 @@ void OobeLocalizationTest::RunLocalizationTest() {
language::prefs::kApplicationLocale, std::string()); language::prefs::kApplicationLocale, std::string());
} }
IN_PROC_BROWSER_TEST_P(OobeLocalizationTest, DISABLED_LocalizationTest) { IN_PROC_BROWSER_TEST_P(OobeLocalizationTest, LocalizationTest) {
RunLocalizationTest(); RunLocalizationTest();
} }
......
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