Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2119)

Unified Diff: Source/web/tests/WebViewTest.cpp

Issue 939603002: Adding support for Smart GO NEXT feature in Android Chrome (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Fixed review comments in unit tests. Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: Source/web/tests/WebViewTest.cpp
diff --git a/Source/web/tests/WebViewTest.cpp b/Source/web/tests/WebViewTest.cpp
index 3c654c3750e2d071e855d8f66815e65620e0848d..d264f06190e472fb878e0f60219c740251c388ed 100644
--- a/Source/web/tests/WebViewTest.cpp
+++ b/Source/web/tests/WebViewTest.cpp
@@ -3049,4 +3049,122 @@ TEST_F(WebViewTest, TestRecordFrameTimingEvents)
}
}
+TEST_F(WebViewTest, MoveFocusToNextFocusableElementInForm)
+{
+ const std::string testFile = "advance_focus_in_form.html";
+ URLTestHelpers::registerMockedURLFromBaseURL(WebString::fromUTF8(m_baseURL.c_str()), WebString::fromUTF8(testFile.c_str()));
+ WebView* webViewImpl = m_webViewHelper.initializeAndLoad(m_baseURL + testFile, true, 0);
+ webViewImpl->setInitialFocus(false);
+ WebLocalFrameImpl* frame = toWebLocalFrameImpl(webViewImpl->mainFrame());
+ HTMLDocument* document = toHTMLDocument(frame->frame()->document());
+ const int defaultTextInputFlags = WebTextInputFlagAutocapitalizeSentences;
+
+ // Forward Navigation in form1 with NEXT
+ Element* input1 = document->getElementById("input1");
+ document->setFocusedElement(input1);
kochi 2015/07/03 04:10:34 You can also do this by "input1->focus();". Eleme
AKV 2015/07/26 15:56:34 Thanks Done.
+ WebTextInputInfo textInputInfo = webViewImpl->textInputInfo();
+ EXPECT_EQ(defaultTextInputFlags | WebTextInputFlagHaveNextFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+
+ Element* contenteditable1 = document->getElementById("contenteditable1");
+ EXPECT_EQ(contenteditable1, document->focusedElement());
+ textInputInfo = webViewImpl->textInputInfo();
+ EXPECT_EQ(WebTextInputFlagHaveNextFocusableElement | WebTextInputFlagHavePreviousFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+
+ Element* input2 = document->getElementById("input2");
+ EXPECT_EQ(input2, document->focusedElement());
+ textInputInfo = webViewImpl->textInputInfo();
+ EXPECT_EQ(defaultTextInputFlags | WebTextInputFlagHaveNextFocusableElement | WebTextInputFlagHavePreviousFocusableElement | WebTextInputFlagListeningToKeyboardEvents, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+
+ Element* textarea1 = document->getElementById("textarea1");
+ EXPECT_EQ(textarea1, document->focusedElement());
+ textInputInfo = webViewImpl->textInputInfo();
+ EXPECT_EQ(defaultTextInputFlags | WebTextInputFlagHaveNextFocusableElement | WebTextInputFlagHavePreviousFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+
+ Element* input3 = document->getElementById("input3");
+ EXPECT_EQ(input3, document->focusedElement());
+ textInputInfo = webViewImpl->textInputInfo();
+ EXPECT_EQ(defaultTextInputFlags | WebTextInputFlagHaveNextFocusableElement | WebTextInputFlagHavePreviousFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+
+ Element* textarea2 = document->getElementById("textarea2");
+ EXPECT_EQ(textarea2, document->focusedElement());
+ textInputInfo = webViewImpl->textInputInfo();
+ EXPECT_EQ(defaultTextInputFlags | WebTextInputFlagHavePreviousFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+ // No next element, hence focus will stay on same element.
+ EXPECT_EQ(textarea2, document->focusedElement());
+
+ // Backward Navigation in form1 with PREVIOUS
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ EXPECT_EQ(input3, document->focusedElement());
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ EXPECT_EQ(textarea1, document->focusedElement());
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ EXPECT_EQ(input2, document->focusedElement());
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ EXPECT_EQ(contenteditable1, document->focusedElement());
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ EXPECT_EQ(input1, document->focusedElement());
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ // No previous element, hence focus will stay on same element.
+ EXPECT_EQ(input1, document->focusedElement());
+
+ // Navigation of elements which is not part of any forms.
+ Element* contenteditable2 = document->getElementById("contenteditable2");
+ document->setFocusedElement(contenteditable2);
+ textInputInfo = webViewImpl->textInputInfo();
+ // No Next/Previous element for elements outside form.
+ EXPECT_NE(WebTextInputFlagHaveNextFocusableElement | WebTextInputFlagHavePreviousFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ EXPECT_EQ(contenteditable2, document->focusedElement());
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
kochi 2015/07/03 04:10:34 Could you add a comment here why you expect the fo
AKV 2015/07/26 15:56:34 Done.
+ EXPECT_EQ(contenteditable2, document->focusedElement());
+
+ Element* textarea3 = document->getElementById("textarea3");
+ document->setFocusedElement(textarea3);
+ textInputInfo = webViewImpl->textInputInfo();
+ // No Next/Previous element for elements outside form.
+ EXPECT_NE(defaultTextInputFlags | WebTextInputFlagHaveNextFocusableElement | WebTextInputFlagHavePreviousFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ EXPECT_EQ(textarea3, document->focusedElement());
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+ EXPECT_EQ(textarea3, document->focusedElement());
+
+ // Forward Navigation in form2 with NEXT
+ Element* textarea4 = document->getElementById("textarea4");
+ document->setFocusedElement(textarea4);
+ textInputInfo = webViewImpl->textInputInfo();
+ EXPECT_EQ(defaultTextInputFlags | WebTextInputFlagListeningToKeyboardEvents | WebTextInputFlagHaveNextFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+
+ Element* input4 = document->getElementById("input4");
+ EXPECT_EQ(input4, document->focusedElement());
+ textInputInfo = webViewImpl->textInputInfo();
+ EXPECT_EQ(defaultTextInputFlags | WebTextInputFlagListeningToKeyboardEvents | WebTextInputFlagHaveNextFocusableElement | WebTextInputFlagHavePreviousFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+
+ Element* contenteditable3 = document->getElementById("contenteditable3");
+ EXPECT_EQ(contenteditable3, document->focusedElement());
+ textInputInfo = webViewImpl->textInputInfo();
+ EXPECT_EQ(WebTextInputFlagListeningToKeyboardEvents | WebTextInputFlagHavePreviousFocusableElement, textInputInfo.flags);
+ webViewImpl->advanceFocusInForm(WebFocusTypeForward);
+ // No next element, hence focus will stay on same element.
+ EXPECT_EQ(contenteditable3, document->focusedElement());
+
+ // Backward Navigation in form2 with PREVIOUS
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ EXPECT_EQ(input4, document->focusedElement());
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ EXPECT_EQ(textarea4, document->focusedElement());
+ webViewImpl->advanceFocusInForm(WebFocusTypeBackward);
+ // No previous element, hence focus will stay on same element.
+ EXPECT_EQ(textarea4, document->focusedElement());
+
+ m_webViewHelper.reset();
+}
+
} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698