Chromium Code Reviews| Index: content/browser/accessibility/browser_accessibility_win_unittest.cc |
| diff --git a/content/browser/accessibility/browser_accessibility_win_unittest.cc b/content/browser/accessibility/browser_accessibility_win_unittest.cc |
| index b81dc5771c23e3613a670678682243758e109ff4..a03a9a6ee3a46573595953f632d50d960802ef9e 100644 |
| --- a/content/browser/accessibility/browser_accessibility_win_unittest.cc |
| +++ b/content/browser/accessibility/browser_accessibility_win_unittest.cc |
| @@ -484,6 +484,7 @@ TEST_F(BrowserAccessibilityTest, TestTextBoundaries) { |
| TEST_F(BrowserAccessibilityTest, TestSimpleHypertext) { |
| const std::string text1_name = "One two three."; |
| const std::string text2_name = " Four five six."; |
| + const size_t text_name_len = text1_name.length() + text2_name.length(); |
| ui::AXNodeData text1; |
| text1.id = 11; |
| @@ -507,29 +508,29 @@ TEST_F(BrowserAccessibilityTest, TestSimpleHypertext) { |
| CountedBrowserAccessibility::reset(); |
| scoped_ptr<BrowserAccessibilityManager> manager( |
| BrowserAccessibilityManager::Create( |
| - MakeAXTreeUpdate(root, text1, text2), |
| - NULL, new CountedBrowserAccessibilityFactory())); |
| + MakeAXTreeUpdate(root, text1, text2), nullptr, |
| + new CountedBrowserAccessibilityFactory())); |
| ASSERT_EQ(3, CountedBrowserAccessibility::num_instances()); |
| BrowserAccessibilityWin* root_obj = |
| manager->GetRoot()->ToBrowserAccessibilityWin(); |
| long text_len; |
| - ASSERT_EQ(S_OK, root_obj->get_nCharacters(&text_len)); |
| + EXPECT_EQ(S_OK, root_obj->get_nCharacters(&text_len)); |
| + EXPECT_EQ(text_name_len, text_len); |
| base::win::ScopedBstr text; |
| - ASSERT_EQ(S_OK, root_obj->get_text(0, text_len, text.Receive())); |
| + EXPECT_EQ(S_OK, root_obj->get_text(0, text_name_len, text.Receive())); |
| EXPECT_EQ(text1_name + text2_name, base::UTF16ToUTF8(base::string16(text))); |
| long hyperlink_count; |
| - ASSERT_EQ(S_OK, root_obj->get_nHyperlinks(&hyperlink_count)); |
| + EXPECT_EQ(S_OK, root_obj->get_nHyperlinks(&hyperlink_count)); |
| EXPECT_EQ(0, hyperlink_count); |
| base::win::ScopedComPtr<IAccessibleHyperlink> hyperlink; |
| EXPECT_EQ(E_INVALIDARG, root_obj->get_hyperlink(-1, hyperlink.Receive())); |
| EXPECT_EQ(E_INVALIDARG, root_obj->get_hyperlink(0, hyperlink.Receive())); |
| EXPECT_EQ(E_INVALIDARG, root_obj->get_hyperlink(28, hyperlink.Receive())); |
| - EXPECT_EQ(E_INVALIDARG, root_obj->get_hyperlink(29, hyperlink.Receive())); |
|
aboxhall
2015/10/29 17:58:49
Where did this go?
|
| long hyperlink_index; |
| EXPECT_EQ(E_FAIL, root_obj->get_hyperlinkIndex(0, &hyperlink_index)); |
| @@ -541,108 +542,127 @@ TEST_F(BrowserAccessibilityTest, TestSimpleHypertext) { |
| EXPECT_EQ(E_INVALIDARG, root_obj->get_hyperlinkIndex(29, &hyperlink_index)); |
| EXPECT_EQ(-1, hyperlink_index); |
| - // Delete the manager and test that all BrowserAccessibility instances are |
| - // deleted. |
| manager.reset(); |
| ASSERT_EQ(0, CountedBrowserAccessibility::num_instances()); |
| } |
| TEST_F(BrowserAccessibilityTest, TestComplexHypertext) { |
| - const std::string text1_name = "One two three."; |
| - const std::string text2_name = " Four five six."; |
| - const std::string button1_text_name = "red"; |
| - const std::string link1_text_name = "blue"; |
| + const base::string16 text1_name = L"One two three."; |
| + const base::string16 combo_box_name = L"City:"; |
| + const base::string16 combo_box_value = L"Happyland"; |
| + const base::string16 text2_name = L" Four five six."; |
| + const base::string16 button_text_name = L"Red"; |
| + const base::string16 link_text_name = L"Blue"; |
|
aboxhall
2015/10/29 17:58:49
Maybe add a radio button or check box here as well
|
| + // Each control (combo box, button and link) will be represented by an |
| + // embedded object character. |
| + const base::string16 embed(1, BrowserAccessibilityWin::kEmbeddedCharacter); |
| + const base::string16 root_hypertext = |
| + text1_name + embed + text2_name + embed + embed; |
| + const size_t root_hypertext_len = root_hypertext.length(); |
| ui::AXNodeData text1; |
| text1.id = 11; |
| text1.role = ui::AX_ROLE_STATIC_TEXT; |
| text1.state = 1 << ui::AX_STATE_READ_ONLY; |
| - text1.SetName(text1_name); |
| + text1.SetName(base::UTF16ToUTF8(text1_name)); |
| + |
| + ui::AXNodeData combo_box; |
| + combo_box.id = 12; |
| + combo_box.role = ui::AX_ROLE_COMBO_BOX; |
| + combo_box.SetName(base::UTF16ToUTF8(combo_box_name)); |
| + combo_box.SetValue(base::UTF16ToUTF8(combo_box_value)); |
| ui::AXNodeData text2; |
| - text2.id = 12; |
| + text2.id = 13; |
| text2.role = ui::AX_ROLE_STATIC_TEXT; |
| text2.state = 1 << ui::AX_STATE_READ_ONLY; |
| - text2.SetName(text2_name); |
| + text2.SetName(base::UTF16ToUTF8(text2_name)); |
| - ui::AXNodeData button1, button1_text; |
| - button1.id = 13; |
| - button1_text.id = 15; |
| - button1_text.SetName(button1_text_name); |
| - button1.role = ui::AX_ROLE_BUTTON; |
| - button1_text.role = ui::AX_ROLE_STATIC_TEXT; |
| - button1.state = 1 << ui::AX_STATE_READ_ONLY; |
| - button1_text.state = 1 << ui::AX_STATE_READ_ONLY; |
| - button1.child_ids.push_back(15); |
| - |
| - ui::AXNodeData link1, link1_text; |
| - link1.id = 14; |
| - link1_text.id = 16; |
| - link1_text.SetName(link1_text_name); |
| - link1.role = ui::AX_ROLE_LINK; |
| - link1_text.role = ui::AX_ROLE_STATIC_TEXT; |
| - link1.state = 1 << ui::AX_STATE_READ_ONLY; |
| - link1_text.state = 1 << ui::AX_STATE_READ_ONLY; |
| - link1.child_ids.push_back(16); |
| + ui::AXNodeData button, button_text; |
| + button.id = 14; |
| + button_text.id = 16; |
| + button_text.SetName(base::UTF16ToUTF8(button_text_name)); |
| + button.role = ui::AX_ROLE_BUTTON; |
| + button_text.role = ui::AX_ROLE_STATIC_TEXT; |
| + button.state = 1 << ui::AX_STATE_READ_ONLY; |
| + button_text.state = 1 << ui::AX_STATE_READ_ONLY; |
| + button.child_ids.push_back(16); |
| + |
| + ui::AXNodeData link, link_text; |
| + link.id = 15; |
| + link_text.id = 17; |
| + link_text.SetName(base::UTF16ToUTF8(link_text_name)); |
| + link.role = ui::AX_ROLE_LINK; |
| + link_text.role = ui::AX_ROLE_STATIC_TEXT; |
| + link.state = 1 << ui::AX_STATE_READ_ONLY; |
| + link_text.state = 1 << ui::AX_STATE_READ_ONLY; |
| + link.child_ids.push_back(17); |
| ui::AXNodeData root; |
| root.id = 1; |
| root.role = ui::AX_ROLE_ROOT_WEB_AREA; |
| root.state = 1 << ui::AX_STATE_READ_ONLY; |
| root.child_ids.push_back(11); |
|
aboxhall
2015/10/29 17:58:49
suggestion only: this might be more readable if we
|
| - root.child_ids.push_back(13); |
| root.child_ids.push_back(12); |
| + root.child_ids.push_back(13); |
| root.child_ids.push_back(14); |
| + root.child_ids.push_back(15); |
| CountedBrowserAccessibility::reset(); |
| scoped_ptr<BrowserAccessibilityManager> manager( |
| BrowserAccessibilityManager::Create( |
| - MakeAXTreeUpdate(root, |
| - text1, button1, button1_text, |
| - text2, link1, link1_text), |
| - NULL, new CountedBrowserAccessibilityFactory())); |
| - ASSERT_EQ(7, CountedBrowserAccessibility::num_instances()); |
| + MakeAXTreeUpdate(root, text1, combo_box, text2, button, button_text, |
| + link, link_text), |
| + nullptr, new CountedBrowserAccessibilityFactory())); |
| + ASSERT_EQ(8, CountedBrowserAccessibility::num_instances()); |
| BrowserAccessibilityWin* root_obj = |
| manager->GetRoot()->ToBrowserAccessibilityWin(); |
| long text_len; |
| - ASSERT_EQ(S_OK, root_obj->get_nCharacters(&text_len)); |
| + EXPECT_EQ(S_OK, root_obj->get_nCharacters(&text_len)); |
| + EXPECT_EQ(root_hypertext_len, text_len); |
| base::win::ScopedBstr text; |
| - ASSERT_EQ(S_OK, root_obj->get_text(0, text_len, text.Receive())); |
| - const std::string embed = base::UTF16ToUTF8( |
| - base::string16(1, BrowserAccessibilityWin::kEmbeddedCharacter)); |
| - EXPECT_EQ(text1_name + embed + text2_name + embed, |
| - base::UTF16ToUTF8(base::string16(text))); |
| + EXPECT_EQ(S_OK, root_obj->get_text(0, root_hypertext_len, text.Receive())); |
| + EXPECT_STREQ(root_hypertext.c_str(), text); |
| text.Reset(); |
| long hyperlink_count; |
| - ASSERT_EQ(S_OK, root_obj->get_nHyperlinks(&hyperlink_count)); |
| - EXPECT_EQ(2, hyperlink_count); |
| + EXPECT_EQ(S_OK, root_obj->get_nHyperlinks(&hyperlink_count)); |
| + EXPECT_EQ(3, hyperlink_count); |
| base::win::ScopedComPtr<IAccessibleHyperlink> hyperlink; |
| base::win::ScopedComPtr<IAccessibleText> hypertext; |
| EXPECT_EQ(E_INVALIDARG, root_obj->get_hyperlink(-1, hyperlink.Receive())); |
| - EXPECT_EQ(E_INVALIDARG, root_obj->get_hyperlink(2, hyperlink.Receive())); |
| - EXPECT_EQ(E_INVALIDARG, root_obj->get_hyperlink(28, hyperlink.Receive())); |
| + EXPECT_EQ(E_INVALIDARG, root_obj->get_hyperlink(3, hyperlink.Receive())); |
| + // Get the text of the combo box. |
| + // It should be its value. |
| EXPECT_EQ(S_OK, root_obj->get_hyperlink(0, hyperlink.Receive())); |
| + EXPECT_EQ(S_OK, hyperlink.QueryInterface(hypertext.Receive())); |
| EXPECT_EQ(S_OK, |
| - hyperlink.QueryInterface<IAccessibleText>(hypertext.Receive())); |
| - EXPECT_EQ(S_OK, hypertext->get_text(0, 3, text.Receive())); |
| - EXPECT_STREQ(button1_text_name.c_str(), |
| - base::UTF16ToUTF8(base::string16(text)).c_str()); |
| + hypertext->get_text(0, IA2_TEXT_OFFSET_LENGTH, text.Receive())); |
| + EXPECT_STREQ(combo_box_value.c_str(), text); |
| text.Reset(); |
| hyperlink.Release(); |
| hypertext.Release(); |
| + // Get the text of the button. |
| EXPECT_EQ(S_OK, root_obj->get_hyperlink(1, hyperlink.Receive())); |
| + EXPECT_EQ(S_OK, hyperlink.QueryInterface(hypertext.Receive())); |
| EXPECT_EQ(S_OK, |
| - hyperlink.QueryInterface<IAccessibleText>(hypertext.Receive())); |
| + hypertext->get_text(0, IA2_TEXT_OFFSET_LENGTH, text.Receive())); |
| + EXPECT_STREQ(button_text_name.c_str(), text); |
| + text.Reset(); |
| + hyperlink.Release(); |
| + hypertext.Release(); |
| + |
| + // Get the text of the link. |
| + EXPECT_EQ(S_OK, root_obj->get_hyperlink(2, hyperlink.Receive())); |
| + EXPECT_EQ(S_OK, hyperlink.QueryInterface(hypertext.Receive())); |
| EXPECT_EQ(S_OK, hypertext->get_text(0, 4, text.Receive())); |
| - EXPECT_STREQ(link1_text_name.c_str(), |
| - base::UTF16ToUTF8(base::string16(text)).c_str()); |
| + EXPECT_STREQ(link_text_name.c_str(), text); |
| text.Reset(); |
| hyperlink.Release(); |
| hypertext.Release(); |
| @@ -656,9 +676,9 @@ TEST_F(BrowserAccessibilityTest, TestComplexHypertext) { |
| EXPECT_EQ(0, hyperlink_index); |
| EXPECT_EQ(S_OK, root_obj->get_hyperlinkIndex(30, &hyperlink_index)); |
| EXPECT_EQ(1, hyperlink_index); |
| + EXPECT_EQ(S_OK, root_obj->get_hyperlinkIndex(31, &hyperlink_index)); |
| + EXPECT_EQ(2, hyperlink_index); |
| - // Delete the manager and test that all BrowserAccessibility instances are |
| - // deleted. |
| manager.reset(); |
| ASSERT_EQ(0, CountedBrowserAccessibility::num_instances()); |
| } |