// Copyright 2014 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_WEB_CONTENTS_OBSERVER_SANITY_CHECKER_H_ #define CONTENT_TEST_WEB_CONTENTS_OBSERVER_SANITY_CHECKER_H_ #include #include #include "base/macros.h" #include "base/supports_user_data.h" #include "content/browser/loader/global_routing_id.h" #include "content/public/browser/web_contents_observer.h" namespace content { // If your test framework enables a ContentBrowserSanityChecker, this sanity // check is automatically installed on all WebContentses during your test. // // WebContentsObserverSanityChecker is a WebContentsObserver that sanity-checks // the sequence of observer calls, and CHECK()s if they are inconsistent. These // checks are test-only code designed to find bugs in the implementation of the // content layer by validating the contract between WebContents and its // observers. // // For example, WebContentsObserver::RenderFrameCreated announces the existence // of a new RenderFrameHost, so that method call must occur before the // RenderFrameHost is referenced by some other WebContentsObserver method. class WebContentsObserverSanityChecker : public WebContentsObserver, public base::SupportsUserData::Data { public: // Enables these checks on |web_contents|. Usually ContentBrowserSanityChecker // should call this for you. static void Enable(WebContents* web_contents); // WebContentsObserver implementation. void RenderFrameCreated(RenderFrameHost* render_frame_host) override; void RenderFrameDeleted(RenderFrameHost* render_frame_host) override; void RenderFrameForInterstitialPageCreated( RenderFrameHost* render_frame_host) override; void RenderFrameHostChanged(RenderFrameHost* old_host, RenderFrameHost* new_host) override; void FrameDeleted(RenderFrameHost* render_frame_host) override; void DidStartNavigation(NavigationHandle* navigation_handle) override; void DidRedirectNavigation(NavigationHandle* navigation_handle) override; void ReadyToCommitNavigation(NavigationHandle* navigation_handle) override; void DidFinishNavigation(NavigationHandle* navigation_handle) override; void DidStartProvisionalLoadForFrame(RenderFrameHost* render_frame_host, const GURL& validated_url, bool is_error_page, bool is_iframe_srcdoc) override; void DidCommitProvisionalLoadForFrame( RenderFrameHost* render_frame_host, const GURL& url, ui::PageTransition transition_type) override; void DidFailProvisionalLoad(RenderFrameHost* render_frame_host, const GURL& validated_url, int error_code, const base::string16& error_description, bool was_ignored_by_handler) override; void DidNavigateMainFrame(const LoadCommittedDetails& details, const FrameNavigateParams& params) override; void DidNavigateAnyFrame(RenderFrameHost* render_frame_host, const LoadCommittedDetails& details, const FrameNavigateParams& params) override; void DocumentAvailableInMainFrame() override; void DocumentOnLoadCompletedInMainFrame() override; void DocumentLoadedInFrame(RenderFrameHost* render_frame_host) override; void DidFinishLoad(RenderFrameHost* render_frame_host, const GURL& validated_url) override; void DidFailLoad(RenderFrameHost* render_frame_host, const GURL& validated_url, int error_code, const base::string16& error_description, bool was_ignored_by_handler) override; void DidGetRedirectForResourceRequest( RenderFrameHost* render_frame_host, const ResourceRedirectDetails& details) override; void DidOpenRequestedURL(WebContents* new_contents, RenderFrameHost* source_render_frame_host, const GURL& url, const Referrer& referrer, WindowOpenDisposition disposition, ui::PageTransition transition) override; void MediaStartedPlaying(const MediaPlayerId& id) override; void MediaStoppedPlaying(const MediaPlayerId& id) override; bool OnMessageReceived(const IPC::Message& message, RenderFrameHost* render_frame_host) override; void WebContentsDestroyed() override; void DidStartLoading() override; void DidStopLoading() override; private: explicit WebContentsObserverSanityChecker(WebContents* web_contents); ~WebContentsObserverSanityChecker() override; std::string Format(RenderFrameHost* render_frame_host); void AssertRenderFrameExists(RenderFrameHost* render_frame_host); void AssertMainFrameExists(); bool NavigationIsOngoing(NavigationHandle* navigation_handle); void EnsureStableParentValue(RenderFrameHost* render_frame_host); bool HasAnyChildren(RenderFrameHost* render_frame_host); std::set current_hosts_; std::set live_routes_; std::set deleted_routes_; std::set ongoing_navigations_; std::vector active_media_players_; // Remembers parents to make sure RenderFrameHost::GetParent() never changes. std::map parent_ids_; bool is_loading_; bool web_contents_destroyed_; DISALLOW_COPY_AND_ASSIGN(WebContentsObserverSanityChecker); }; } // namespace content #endif // CONTENT_TEST_WEB_CONTENTS_OBSERVER_SANITY_CHECKER_H_