// Copyright 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CONTENT_TEST_ACCESSIBILITY_BROWSER_TEST_UTILS_H_ #define CONTENT_TEST_ACCESSIBILITY_BROWSER_TEST_UTILS_H_ #include "base/memory/weak_ptr.h" #include "content/common/accessibility_node_data.h" #include "content/common/view_message_enums.h" namespace content { class MessageLoopRunner; class RenderViewHostImpl; class Shell; // Create an instance of this class *before* doing any operation that // might generate an accessibility event (like a page navigation or // clicking on a button). Then call WaitForNotification // afterwards to block until the specified accessibility notification has been // received. class AccessibilityNotificationWaiter { public: AccessibilityNotificationWaiter( Shell* shell, AccessibilityMode accessibility_mode, blink::WebAXEvent event); ~AccessibilityNotificationWaiter(); // Blocks until the specific accessibility notification registered in // AccessibilityNotificationWaiter is received. Ignores notifications for // "about:blank". void WaitForNotification(); // After WaitForNotification has returned, this will retrieve // the tree of accessibility nodes received from the renderer process. const AccessibilityNodeDataTreeNode& GetAccessibilityNodeDataTree() const; private: // Callback from RenderViewHostImpl. void OnAccessibilityEvent(blink::WebAXEvent event); // Helper function to determine if the accessibility tree in // GetAccessibilityNodeDataTree() is about the page with the url // "about:blank". bool IsAboutBlank(); Shell* shell_; RenderViewHostImpl* view_host_; blink::WebAXEvent event_to_wait_for_; scoped_refptr<MessageLoopRunner> loop_runner_; base::WeakPtrFactory<AccessibilityNotificationWaiter> weak_factory_; DISALLOW_COPY_AND_ASSIGN(AccessibilityNotificationWaiter); }; } // namespace content #endif // CONTENT_TEST_ACCESSIBILITY_BROWSER_TEST_UTILS_H_