Home | History | Annotate | Download | only in tests
      1 /*
      2  * Copyright (C) 2011 Google Inc. All rights reserved.
      3  *
      4  * Redistribution and use in source and binary forms, with or without
      5  * modification, are permitted provided that the following conditions are
      6  * met:
      7  *
      8  *     * Redistributions of source code must retain the above copyright
      9  * notice, this list of conditions and the following disclaimer.
     10  *     * Redistributions in binary form must reproduce the above
     11  * copyright notice, this list of conditions and the following disclaimer
     12  * in the documentation and/or other materials provided with the
     13  * distribution.
     14  *     * Neither the name of Google Inc. nor the names of its
     15  * contributors may be used to endorse or promote products derived from
     16  * this software without specific prior written permission.
     17  *
     18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     19  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     20  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
     21  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     22  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
     23  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
     24  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     26  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     27  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
     28  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     29  */
     30 
     31 #ifndef FrameTestHelpers_h
     32 #define FrameTestHelpers_h
     33 
     34 #include "public/platform/WebURLRequest.h"
     35 #include "public/web/WebFrameClient.h"
     36 #include "public/web/WebHistoryItem.h"
     37 #include "public/web/WebRemoteFrameClient.h"
     38 #include "public/web/WebViewClient.h"
     39 #include "web/WebViewImpl.h"
     40 #include "wtf/PassOwnPtr.h"
     41 #include <string>
     42 
     43 namespace blink {
     44 
     45 class WebLocalFrameImpl;
     46 class WebSettings;
     47 
     48 namespace FrameTestHelpers {
     49 
     50 class TestWebFrameClient;
     51 
     52 // Loads a url into the specified WebFrame for testing purposes. Pumps any
     53 // pending resource requests, as well as waiting for the threaded parser to
     54 // finish, before returning.
     55 void loadFrame(WebFrame*, const std::string& url);
     56 // Same as above, but for WebFrame::loadHTMLString().
     57 void loadHTMLString(WebFrame*, const std::string& html, const WebURL& baseURL);
     58 // Same as above, but for WebFrame::loadHistoryItem().
     59 void loadHistoryItem(WebFrame*, const WebHistoryItem&, WebHistoryLoadType, WebURLRequest::CachePolicy);
     60 // Same as above, but for WebFrame::reload().
     61 void reloadFrame(WebFrame*);
     62 void reloadFrameIgnoringCache(WebFrame*);
     63 
     64 // Pumps pending resource requests while waiting for a frame to load. Don't use
     65 // this. Use one of the above helpers.
     66 void pumpPendingRequestsDoNotUse(WebFrame*);
     67 
     68 void runPendingTasks();
     69 
     70 // Convenience class for handling the lifetime of a WebView and its associated mainframe in tests.
     71 class WebViewHelper {
     72     WTF_MAKE_NONCOPYABLE(WebViewHelper);
     73 public:
     74     WebViewHelper();
     75     ~WebViewHelper();
     76 
     77     // Creates and initializes the WebView. Implicitly calls reset() first. IF a
     78     // WebFrameClient or a WebViewClient are passed in, they must outlive the
     79     // WebViewHelper.
     80     WebViewImpl* initialize(bool enableJavascript = false, TestWebFrameClient* = 0, WebViewClient* = 0, void (*updateSettingsFunc)(WebSettings*) = 0);
     81 
     82     // Same as initialize() but also performs the initial load of the url. Only
     83     // returns once the load is complete.
     84     WebViewImpl* initializeAndLoad(const std::string& url, bool enableJavascript = false, TestWebFrameClient* = 0, WebViewClient* = 0, void (*updateSettingsFunc)(WebSettings*) = 0);
     85 
     86     void reset();
     87 
     88     WebView* webView() const { return m_webView; }
     89     WebViewImpl* webViewImpl() const { return m_webView; }
     90 
     91 private:
     92     WebViewImpl* m_webView;
     93 };
     94 
     95 // Minimal implementation of WebFrameClient needed for unit tests that load frames. Tests that load
     96 // frames and need further specialization of WebFrameClient behavior should subclass this.
     97 class TestWebFrameClient : public WebFrameClient {
     98 public:
     99     TestWebFrameClient();
    100 
    101     virtual WebFrame* createChildFrame(WebLocalFrame* parent, const WebString& frameName) OVERRIDE;
    102     virtual void frameDetached(WebFrame*) OVERRIDE;
    103     virtual void didStartLoading(bool) OVERRIDE;
    104     virtual void didStopLoading() OVERRIDE;
    105 
    106     bool isLoading() { return m_loadsInProgress > 0; }
    107 
    108 private:
    109     int m_loadsInProgress;
    110 };
    111 
    112 // Minimal implementation of WebRemoteFrameClient needed for unit tests that load remote frames. Tests that load
    113 // frames and need further specialization of WebFrameClient behavior should subclass this.
    114 class TestWebRemoteFrameClient : public WebRemoteFrameClient {
    115 public:
    116     // Notifies the embedder that a postMessage was issued to a remote frame.
    117     virtual void postMessageEvent(
    118         WebLocalFrame* sourceFrame,
    119         WebRemoteFrame* targetFrame,
    120         WebSecurityOrigin targetOrigin,
    121         WebDOMMessageEvent) { }
    122 };
    123 
    124 class TestWebViewClient : public WebViewClient {
    125 public:
    126     virtual ~TestWebViewClient() { }
    127     virtual void initializeLayerTreeView() OVERRIDE;
    128     virtual WebLayerTreeView* layerTreeView() OVERRIDE { return m_layerTreeView.get(); }
    129 
    130 private:
    131     OwnPtr<WebLayerTreeView> m_layerTreeView;
    132 };
    133 
    134 } // namespace FrameTestHelpers
    135 } // namespace blink
    136 
    137 #endif // FrameTestHelpers_h
    138