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

Side by Side Diff: Source/web/tests/FrameTestHelpers.cpp

Issue 271793007: Fix webkit_unit_tests to use the threaded parser and enable everywhere. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Add loadHistoryItem wrapper Created 6 years, 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2011 Google Inc. All rights reserved. 2 * Copyright (C) 2011 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 14 matching lines...) Expand all
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 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. 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */ 29 */
30 30
31 #include "config.h" 31 #include "config.h"
32 #include "web/tests/FrameTestHelpers.h" 32 #include "web/tests/FrameTestHelpers.h"
33 33
34 #include "public/platform/Platform.h" 34 #include "public/platform/Platform.h"
35 #include "public/platform/WebData.h"
35 #include "public/platform/WebString.h" 36 #include "public/platform/WebString.h"
36 #include "public/platform/WebThread.h" 37 #include "public/platform/WebThread.h"
37 #include "public/platform/WebURLRequest.h" 38 #include "public/platform/WebURLRequest.h"
38 #include "public/platform/WebURLResponse.h" 39 #include "public/platform/WebURLResponse.h"
39 #include "public/platform/WebUnitTestSupport.h" 40 #include "public/platform/WebUnitTestSupport.h"
40 #include "public/web/WebSettings.h" 41 #include "public/web/WebSettings.h"
41 #include "public/web/WebViewClient.h" 42 #include "public/web/WebViewClient.h"
42 #include "web/WebLocalFrameImpl.h" 43 #include "web/WebLocalFrameImpl.h"
43 #include "web/tests/URLTestHelpers.h" 44 #include "web/tests/URLTestHelpers.h"
44 #include "wtf/StdLibExtras.h" 45 #include "wtf/StdLibExtras.h"
45 46
46 namespace blink { 47 namespace blink {
47 namespace FrameTestHelpers { 48 namespace FrameTestHelpers {
48 49
49 namespace { 50 namespace {
50 51
52 // The frame test helpers coordinate frame loads in a carefully choreographed
53 // dance. Since the parser is threaded, simply spinning the run loop once is not
54 // enough to ensure completion of a load. Instead, the following pattern is
55 // used to ensure that tests see the final state:
56 // 1. Post a task to trigger a load (LoadTask/LoadHTMLStringTask/ReloadTask).
57 // 2. Enter the run loop.
58 // 3. Posted task triggers the load, and starts pumping pending resource
59 // requests using ServeAsyncRequestsTask.
60 // 4. TestWebFrameClient watches for didStartLoading/didStopLoading calls,
61 // keeping track of how many loads it thinks are in flight.
62 // 5. While ServeAsyncRequestsTask observes TestWebFrameClient to still have
63 // loads in progress, it posts itself back to the run loop.
64 // 6. When ServeAsyncRequestsTask notices there are no more loads in progress,
65 // it exits the run loop.
66 // 7. At this point, all parsing, resource loads, and layout should be finished.
67 TestWebFrameClient* testClientForFrame(WebFrame* frame)
68 {
69 return static_cast<TestWebFrameClient*>(toWebLocalFrameImpl(frame)->client() );
70 }
71
51 class QuitTask : public WebThread::Task { 72 class QuitTask : public WebThread::Task {
52 public: 73 public:
53 void PostThis(WebCore::Timer<QuitTask>*) 74 void PostThis(WebCore::Timer<QuitTask>*)
54 { 75 {
55 // We don't just quit here because the SharedTimer may be part-way 76 // We don't just quit here because the SharedTimer may be part-way
56 // through the current queue of tasks when runPendingTasks was called, 77 // through the current queue of tasks when runPendingTasks was called,
57 // and we can't miss the tasks that were behind it. 78 // and we can't miss the tasks that were behind it.
58 // Takes ownership of |this|. 79 // Takes ownership of |this|.
59 Platform::current()->currentThread()->postTask(this); 80 Platform::current()->currentThread()->postTask(this);
60 } 81 }
61 82
62 virtual void run() 83 virtual void run()
63 { 84 {
64 Platform::current()->currentThread()->exitRunLoop(); 85 Platform::current()->currentThread()->exitRunLoop();
65 } 86 }
66 }; 87 };
67 88
68 WebFrameClient* defaultWebFrameClient() 89 class ServeAsyncRequestsTask : public WebThread::Task {
90 public:
91 explicit ServeAsyncRequestsTask(TestWebFrameClient* client)
92 : m_client(client)
93 {
94 }
95
96 virtual void run() OVERRIDE
97 {
98 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests( );
99 if (m_client->isLoading())
100 Platform::current()->currentThread()->postTask(new ServeAsyncRequest sTask(m_client));
101 else
102 Platform::current()->currentThread()->exitRunLoop();
103 }
104
105 private:
106 TestWebFrameClient* const m_client;
107 };
108
109 void pumpPendingRequests(WebFrame* frame)
110 {
111 Platform::current()->currentThread()->postTask(new ServeAsyncRequestsTask(te stClientForFrame(frame)));
112 Platform::current()->currentThread()->enterRunLoop();
113 }
114
115 class LoadTask : public WebThread::Task {
116 public:
117 LoadTask(WebFrame* frame, const WebURLRequest& request)
118 : m_frame(frame)
119 , m_request(request)
120 {
121 }
122
123 virtual void run() OVERRIDE
124 {
125 m_frame->loadRequest(m_request);
126 }
127
128 private:
129 WebFrame* const m_frame;
130 const WebURLRequest m_request;
131 };
132
133 class LoadHTMLStringTask : public WebThread::Task {
134 public:
135 LoadHTMLStringTask(WebFrame* frame, const std::string& html, const WebURL& b aseURL)
136 : m_frame(frame)
137 , m_html(html)
138 , m_baseURL(baseURL)
139 {
140 }
141
142 virtual void run() OVERRIDE
143 {
144 m_frame->loadHTMLString(WebData(m_html.data(), m_html.size()), m_baseURL );
145 }
146
147 private:
148 WebFrame* const m_frame;
149 const std::string m_html;
150 const WebURL m_baseURL;
151 };
152
153 class LoadHistoryItemTask : public WebThread::Task {
154 public:
155 LoadHistoryItemTask(WebFrame* frame, const WebHistoryItem& item, WebHistoryL oadType loadType, WebURLRequest::CachePolicy cachePolicy)
156 : m_frame(frame)
157 , m_item(item)
158 , m_loadType(loadType)
159 , m_cachePolicy(cachePolicy)
160 {
161 }
162
163 virtual void run() OVERRIDE
164 {
165 m_frame->loadHistoryItem(m_item, m_loadType, m_cachePolicy);
166 }
167
168 private:
169 WebFrame* const m_frame;
170 const WebHistoryItem m_item;
171 const WebHistoryLoadType m_loadType;
172 const WebURLRequest::CachePolicy m_cachePolicy;
173 };
174
175 class ReloadTask : public WebThread::Task {
176 public:
177 ReloadTask(WebFrame* frame, bool ignoreCache)
178 : m_frame(frame)
179 , m_ignoreCache(ignoreCache)
180 {
181 }
182
183 virtual void run() OVERRIDE
184 {
185 m_frame->reload(m_ignoreCache);
186 }
187
188 private:
189 WebFrame* const m_frame;
190 const bool m_ignoreCache;
191 };
192
193 TestWebFrameClient* defaultWebFrameClient()
69 { 194 {
70 DEFINE_STATIC_LOCAL(TestWebFrameClient, client, ()); 195 DEFINE_STATIC_LOCAL(TestWebFrameClient, client, ());
71 return &client; 196 return &client;
72 } 197 }
73 198
74 WebViewClient* defaultWebViewClient() 199 WebViewClient* defaultWebViewClient()
75 { 200 {
76 DEFINE_STATIC_LOCAL(TestWebViewClient, client, ()); 201 DEFINE_STATIC_LOCAL(TestWebViewClient, client, ());
77 return &client; 202 return &client;
78 } 203 }
79 204
80 } // namespace 205 } // namespace
81 206
82 void loadFrame(WebFrame* frame, const std::string& url) 207 void loadFrame(WebFrame* frame, const std::string& url)
83 { 208 {
84 WebURLRequest urlRequest; 209 WebURLRequest urlRequest;
85 urlRequest.initialize(); 210 urlRequest.initialize();
86 urlRequest.setURL(URLTestHelpers::toKURL(url)); 211 urlRequest.setURL(URLTestHelpers::toKURL(url));
87 frame->loadRequest(urlRequest); 212
213 Platform::current()->currentThread()->postTask(new LoadTask(frame, urlReques t));
214 pumpPendingRequests(frame);
88 } 215 }
89 216
217 void loadHTMLString(WebFrame* frame, const std::string& html, const WebURL& base URL)
218 {
219 Platform::current()->currentThread()->postTask(new LoadHTMLStringTask(frame, html, baseURL));
220 pumpPendingRequests(frame);
221 }
222
223 void loadHistoryItem(WebFrame* frame, const WebHistoryItem& item, WebHistoryLoad Type loadType, WebURLRequest::CachePolicy cachePolicy)
224 {
225 Platform::current()->currentThread()->postTask(new LoadHistoryItemTask(frame , item, loadType, cachePolicy));
226 pumpPendingRequests(frame);
227 }
228
229 void reloadFrame(WebFrame* frame)
230 {
231 Platform::current()->currentThread()->postTask(new ReloadTask(frame, false)) ;
232 pumpPendingRequests(frame);
233 }
234
235 void reloadFrameIgnoringCache(WebFrame* frame)
236 {
237 Platform::current()->currentThread()->postTask(new ReloadTask(frame, true));
238 pumpPendingRequests(frame);
239 }
240
241 void pumpPendingRequestsDoNotUse(WebFrame* frame)
242 {
243 pumpPendingRequests(frame);
244 }
245
246 // FIXME: There's a duplicate implementation in UnitTestHelpers.cpp. Remove one.
90 void runPendingTasks() 247 void runPendingTasks()
91 { 248 {
92 // Pending tasks include Timers that have been scheduled. 249 // Pending tasks include Timers that have been scheduled.
93 WebCore::Timer<QuitTask> quitOnTimeout(new QuitTask, &QuitTask::PostThis); 250 WebCore::Timer<QuitTask> quitOnTimeout(new QuitTask, &QuitTask::PostThis);
94 quitOnTimeout.startOneShot(0, FROM_HERE); 251 quitOnTimeout.startOneShot(0, FROM_HERE);
95 Platform::current()->currentThread()->enterRunLoop(); 252 Platform::current()->currentThread()->enterRunLoop();
96 } 253 }
97 254
98 WebViewHelper::WebViewHelper() 255 WebViewHelper::WebViewHelper()
99 : m_webView(0) 256 : m_webView(0)
100 { 257 {
101 } 258 }
102 259
103 WebViewHelper::~WebViewHelper() 260 WebViewHelper::~WebViewHelper()
104 { 261 {
105 reset(); 262 reset();
106 } 263 }
107 264
108 WebViewImpl* WebViewHelper::initialize(bool enableJavascript, WebFrameClient* we bFrameClient, WebViewClient* webViewClient, void (*updateSettingsFunc)(WebSettin gs*)) 265 WebViewImpl* WebViewHelper::initialize(bool enableJavascript, TestWebFrameClient * webFrameClient, WebViewClient* webViewClient, void (*updateSettingsFunc)(WebSe ttings*))
109 { 266 {
110 reset(); 267 reset();
111 268
112 if (!webFrameClient) 269 if (!webFrameClient)
113 webFrameClient = defaultWebFrameClient(); 270 webFrameClient = defaultWebFrameClient();
114 if (!webViewClient) 271 if (!webViewClient)
115 webViewClient = defaultWebViewClient(); 272 webViewClient = defaultWebViewClient();
116 m_webView = WebViewImpl::create(webViewClient); 273 m_webView = WebViewImpl::create(webViewClient);
117 m_webView->settings()->setJavaScriptEnabled(enableJavascript); 274 m_webView->settings()->setJavaScriptEnabled(enableJavascript);
118 if (updateSettingsFunc) { 275 if (updateSettingsFunc) {
119 updateSettingsFunc(m_webView->settings()); 276 updateSettingsFunc(m_webView->settings());
120 } else { 277 } else {
121 m_webView->settings()->setDeviceSupportsMouse(false); 278 m_webView->settings()->setDeviceSupportsMouse(false);
122 m_webView->settings()->setForceCompositingMode(true); 279 m_webView->settings()->setForceCompositingMode(true);
123 } 280 }
124 281
125 m_webView->setMainFrame(WebLocalFrameImpl::create(webFrameClient)); 282 m_webView->setMainFrame(WebLocalFrameImpl::create(webFrameClient));
126 283
127 return m_webView; 284 return m_webView;
128 } 285 }
129 286
130 WebViewImpl* WebViewHelper::initializeAndLoad(const std::string& url, bool enabl eJavascript, WebFrameClient* webFrameClient, WebViewClient* webViewClient, void (*updateSettingsFunc)(WebSettings*)) 287 WebViewImpl* WebViewHelper::initializeAndLoad(const std::string& url, bool enabl eJavascript, TestWebFrameClient* webFrameClient, WebViewClient* webViewClient, v oid (*updateSettingsFunc)(WebSettings*))
131 { 288 {
132 initialize(enableJavascript, webFrameClient, webViewClient, updateSettingsFu nc); 289 initialize(enableJavascript, webFrameClient, webViewClient, updateSettingsFu nc);
133 290
134 loadFrame(webView()->mainFrame(), url); 291 loadFrame(webView()->mainFrame(), url);
135 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests();
136 292
137 return webViewImpl(); 293 return webViewImpl();
138 } 294 }
139 295
140 void WebViewHelper::reset() 296 void WebViewHelper::reset()
141 { 297 {
142 if (m_webView) { 298 if (m_webView) {
299 ASSERT(!testClientForFrame(m_webView->mainFrame())->isLoading());
143 m_webView->close(); 300 m_webView->close();
144 m_webView = 0; 301 m_webView = 0;
145 } 302 }
146 } 303 }
147 304
305 TestWebFrameClient::TestWebFrameClient() : m_loadsInProgress(0)
306 {
307 }
308
148 WebFrame* TestWebFrameClient::createChildFrame(WebLocalFrame* parent, const WebS tring& frameName) 309 WebFrame* TestWebFrameClient::createChildFrame(WebLocalFrame* parent, const WebS tring& frameName)
149 { 310 {
150 WebFrame* frame = WebLocalFrame::create(this); 311 WebFrame* frame = WebLocalFrame::create(this);
151 parent->appendChild(frame); 312 parent->appendChild(frame);
152 return frame; 313 return frame;
153 } 314 }
154 315
155 void TestWebFrameClient::frameDetached(WebFrame* frame) 316 void TestWebFrameClient::frameDetached(WebFrame* frame)
156 { 317 {
157 if (frame->parent()) 318 if (frame->parent())
158 frame->parent()->removeChild(frame); 319 frame->parent()->removeChild(frame);
159 frame->close(); 320 frame->close();
160 } 321 }
161 322
323 void TestWebFrameClient::didStartLoading(bool)
324 {
325 ++m_loadsInProgress;
326 }
327
328 void TestWebFrameClient::didStopLoading()
329 {
330 ASSERT(m_loadsInProgress > 0);
331 --m_loadsInProgress;
332 }
333
162 void TestWebViewClient::initializeLayerTreeView() 334 void TestWebViewClient::initializeLayerTreeView()
163 { 335 {
164 m_layerTreeView = adoptPtr(Platform::current()->unitTestSupport()->createLay erTreeViewForTesting(WebUnitTestSupport::TestViewTypeUnitTest)); 336 m_layerTreeView = adoptPtr(Platform::current()->unitTestSupport()->createLay erTreeViewForTesting(WebUnitTestSupport::TestViewTypeUnitTest));
165 ASSERT(m_layerTreeView); 337 ASSERT(m_layerTreeView);
166 } 338 }
167 339
168 } // namespace FrameTestHelpers 340 } // namespace FrameTestHelpers
169 } // namespace blink 341 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698