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

Unified Diff: components/exo/shell_surface_unittest.cc

Issue 2640123004: Initial support for native accessibility in ARC (Closed)
Patch Set: address feedback Created 3 years, 11 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: components/exo/shell_surface_unittest.cc
diff --git a/components/exo/shell_surface_unittest.cc b/components/exo/shell_surface_unittest.cc
index 135395cc051e063517c46f47f707c4d7683e5d1d..91ffa60d7cfbbca3f3b933bbe1809de17cb525d9 100644
--- a/components/exo/shell_surface_unittest.cc
+++ b/components/exo/shell_surface_unittest.cc
@@ -11,6 +11,7 @@
#include "ash/wm/window_state_aura.h"
#include "base/message_loop/message_loop.h"
#include "base/strings/utf_string_conversions.h"
+#include "components/exo/ax_tree_source_surface.h"
#include "components/exo/buffer.h"
#include "components/exo/display.h"
#include "components/exo/shell_surface.h"
@@ -829,5 +830,80 @@ TEST_F(ShellSurfaceTest, SpokenFeedbackFullscreenBackground) {
EXPECT_EQ(shadow_bounds, shell_surface2.shadow_underlay()->bounds());
}
+class FakeAXTreeSource : public AXTreeSourceSurface {
+ public:
+ bool GetTreeData(ui::AXTreeData* data) const override {
+ // In a real implementation, the embedder would point to this tree with a
+ // child tree id.
+ return false;
+ }
+
+ ui::AXNode* GetRoot() const override { return nullptr; }
+
+ ui::AXNode* GetFromId(int32_t id) const override { return nullptr; }
+
+ int32_t GetId(ui::AXNode* node) const override { return 1; }
+
+ void GetChildren(ui::AXNode* node,
+ std::vector<ui::AXNode*>* out_children) const override {}
+
+ ui::AXNode* GetParent(ui::AXNode* node) const override { return nullptr; }
+
+ bool IsValid(ui::AXNode* node) const override { return false; }
+
+ bool IsEqual(ui::AXNode* node1, ui::AXNode* node2) const override {
+ return false;
+ }
+
+ ui::AXNode* GetNull() const override { return nullptr; }
+
+ void SerializeNode(ui::AXNode* node,
+ ui::AXNodeData* out_data) const override {}
+
+ protected:
+ void Reset() override {
+ // Reset indicates we should initialize or reinitialize tree data
+ // e.g. when new observers are added.
+ // For testing, fire an event.
+ NotifyAccessibilityEvent(2U, ui::AX_EVENT_FOCUS);
+ }
+};
+
+class FakeAXTreeSourceObserver : public AXTreeSourceSurface::Observer {
+ public:
+ void OnAccessibilityEvent(uint32_t node_id, ui::AXEvent event) override {
+ // A real implementation might send this event to an extension.
+ events.push_back(std::pair<uint32_t, ui::AXEvent>(node_id, event));
+ }
+
+ std::vector<std::pair<uint32_t, ui::AXEvent>> events;
+};
+
+TEST_F(ShellSurfaceTest, AccessibilityNodeData) {
+ gfx::Size buffer_size(256, 256);
+ Buffer buffer(exo_test_helper()->CreateGpuMemoryBuffer(buffer_size));
+ Surface surface;
+ ShellSurface shell_surface(&surface, nullptr, gfx::Rect(640, 480), true,
+ false, ash::kShellWindowId_DefaultContainer);
+
+ surface.Attach(&buffer);
+
+ FakeAXTreeSource tree_source;
+ FakeAXTreeSourceObserver tree_source_observer;
+
+ // An embedder might get here by tracking focused windows.
+ surface.set_ax_tree_source(&tree_source);
+
+ // At this point, the tree source is empty. Once an embedder sees a shell
+ // surface window, the embedder can observe the tree source at which point the
+ // source tree will fetch data and fire any initial events. The test simulates
+ // the steps expected.
+ tree_source.AddObserver(&tree_source_observer);
+
+ ASSERT_EQ(1U, tree_source_observer.events.size());
+ ASSERT_EQ(2U, tree_source_observer.events.front().first);
+ ASSERT_EQ(ui::AX_EVENT_FOCUS, tree_source_observer.events.front().second);
+}
+
} // namespace
} // namespace exo

Powered by Google App Engine
This is Rietveld 408576698