OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2010 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 116 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
127 return m_layerTreeView.get(); | 127 return m_layerTreeView.get(); |
128 } | 128 } |
129 | 129 |
130 FakeWebFrameClient m_fakeWebFrameClient; | 130 FakeWebFrameClient m_fakeWebFrameClient; |
131 | 131 |
132 private: | 132 private: |
133 OwnPtr<WebLayerTreeView> m_layerTreeView; | 133 OwnPtr<WebLayerTreeView> m_layerTreeView; |
134 }; | 134 }; |
135 | 135 |
136 class WebFrameTest : public testing::Test { | 136 class WebFrameTest : public testing::Test { |
137 public: | 137 protected: |
138 WebFrameTest() | 138 WebFrameTest() |
139 : m_baseURL("http://www.test.com/") | 139 : m_baseURL("http://www.test.com/") |
140 , m_chromeURL("chrome://") | 140 , m_chromeURL("chrome://") |
141 , m_webView(0) | |
142 { | 141 { |
143 } | 142 } |
144 | 143 |
145 virtual ~WebFrameTest() | 144 virtual ~WebFrameTest() |
146 { | 145 { |
147 if (m_webView) | |
148 m_webView->close(); | |
149 } | |
150 | |
151 virtual void TearDown() | |
152 { | |
153 Platform::current()->unitTestSupport()->unregisterAllMockedURLs(); | 146 Platform::current()->unitTestSupport()->unregisterAllMockedURLs(); |
154 } | 147 } |
155 | 148 |
156 void registerMockedHttpURLLoad(const std::string& fileName) | 149 void registerMockedHttpURLLoad(const std::string& fileName) |
157 { | 150 { |
158 URLTestHelpers::registerMockedURLFromBaseURL(WebString::fromUTF8(m_baseU
RL.c_str()), WebString::fromUTF8(fileName.c_str())); | 151 URLTestHelpers::registerMockedURLFromBaseURL(WebString::fromUTF8(m_baseU
RL.c_str()), WebString::fromUTF8(fileName.c_str())); |
159 } | 152 } |
160 | 153 |
161 void registerMockedChromeURLLoad(const std::string& fileName) | 154 void registerMockedChromeURLLoad(const std::string& fileName) |
162 { | 155 { |
163 URLTestHelpers::registerMockedURLFromBaseURL(WebString::fromUTF8(m_chrom
eURL.c_str()), WebString::fromUTF8(fileName.c_str())); | 156 URLTestHelpers::registerMockedURLFromBaseURL(WebString::fromUTF8(m_chrom
eURL.c_str()), WebString::fromUTF8(fileName.c_str())); |
164 } | 157 } |
165 | 158 |
166 void createCompositingWebView() | 159 static void configueCompositingWebView(WebSettings* settings) |
167 { | 160 { |
168 m_fakeCompositingWebViewClient = adoptPtr(new FakeCompositingWebViewClie
nt()); | 161 settings->setForceCompositingMode(true); |
169 m_webView = WebView::create(m_fakeCompositingWebViewClient.get()); | 162 settings->setAcceleratedCompositingEnabled(true); |
170 m_webView->settings()->setJavaScriptEnabled(true); | 163 settings->setAcceleratedCompositingForFixedPositionEnabled(true); |
171 m_webView->settings()->setForceCompositingMode(true); | 164 settings->setAcceleratedCompositingForOverflowScrollEnabled(true); |
172 m_webView->settings()->setAcceleratedCompositingEnabled(true); | 165 settings->setAcceleratedCompositingForScrollableFramesEnabled(true); |
173 m_webView->settings()->setAcceleratedCompositingForFixedPositionEnabled(
true); | 166 settings->setCompositedScrollingForFramesEnabled(true); |
174 m_webView->settings()->setAcceleratedCompositingForOverflowScrollEnabled
(true); | 167 settings->setFixedPositionCreatesStackingContext(true); |
175 m_webView->settings()->setAcceleratedCompositingForScrollableFramesEnabl
ed(true); | |
176 m_webView->settings()->setCompositedScrollingForFramesEnabled(true); | |
177 m_webView->settings()->setFixedPositionCreatesStackingContext(true); | |
178 m_webView->initializeMainFrame(&m_fakeCompositingWebViewClient->m_fakeWe
bFrameClient); | |
179 } | 168 } |
180 | 169 |
181 protected: | 170 void initializeTextSelectionWebView(const std::string& url, FrameTestHelpers
::WebViewHelper* webViewHelper) |
182 WebViewImpl* webViewImpl() const { return toWebViewImpl(m_webView); } | 171 { |
| 172 webViewHelper->initializeAndLoad(url, true); |
| 173 webViewHelper->webView()->settings()->setDefaultFontSize(12); |
| 174 webViewHelper->webView()->enableFixedLayoutMode(false); |
| 175 webViewHelper->webView()->resize(WebSize(640, 480)); |
| 176 } |
183 | 177 |
184 std::string m_baseURL; | 178 std::string m_baseURL; |
185 std::string m_chromeURL; | 179 std::string m_chromeURL; |
186 OwnPtr<FakeCompositingWebViewClient> m_fakeCompositingWebViewClient; | |
187 | |
188 WebView* m_webView; | |
189 }; | 180 }; |
190 | 181 |
191 class UseMockScrollbarSettings { | 182 class UseMockScrollbarSettings { |
192 public: | 183 public: |
193 UseMockScrollbarSettings() | 184 UseMockScrollbarSettings() |
194 { | 185 { |
195 WebCore::Settings::setMockScrollbarsEnabled(true); | 186 WebCore::Settings::setMockScrollbarsEnabled(true); |
196 WebCore::RuntimeEnabledFeatures::setOverlayScrollbarsEnabled(true); | 187 WebCore::RuntimeEnabledFeatures::setOverlayScrollbarsEnabled(true); |
197 EXPECT_TRUE(WebCore::ScrollbarTheme::theme()->usesOverlayScrollbars()); | 188 EXPECT_TRUE(WebCore::ScrollbarTheme::theme()->usesOverlayScrollbars()); |
198 } | 189 } |
199 | 190 |
200 ~UseMockScrollbarSettings() | 191 ~UseMockScrollbarSettings() |
201 { | 192 { |
202 WebCore::Settings::setMockScrollbarsEnabled(false); | 193 WebCore::Settings::setMockScrollbarsEnabled(false); |
203 WebCore::RuntimeEnabledFeatures::setOverlayScrollbarsEnabled(false); | 194 WebCore::RuntimeEnabledFeatures::setOverlayScrollbarsEnabled(false); |
204 } | 195 } |
205 }; | 196 }; |
206 | 197 |
207 TEST_F(WebFrameTest, ContentText) | 198 TEST_F(WebFrameTest, ContentText) |
208 { | 199 { |
209 registerMockedHttpURLLoad("iframes_test.html"); | 200 registerMockedHttpURLLoad("iframes_test.html"); |
210 registerMockedHttpURLLoad("visible_iframe.html"); | 201 registerMockedHttpURLLoad("visible_iframe.html"); |
211 registerMockedHttpURLLoad("invisible_iframe.html"); | 202 registerMockedHttpURLLoad("invisible_iframe.html"); |
212 registerMockedHttpURLLoad("zero_sized_iframe.html"); | 203 registerMockedHttpURLLoad("zero_sized_iframe.html"); |
213 | 204 |
214 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "iframes_test
.html"); | 205 FrameTestHelpers::WebViewHelper webViewHelper; |
| 206 webViewHelper.initializeAndLoad(m_baseURL + "iframes_test.html"); |
215 | 207 |
216 // Now retrieve the frames text and test it only includes visible elements. | 208 // Now retrieve the frames text and test it only includes visible elements. |
217 std::string content = std::string(m_webView->mainFrame()->contentAsText(1024
).utf8().data()); | 209 std::string content = std::string(webViewHelper.webView()->mainFrame()->cont
entAsText(1024).utf8().data()); |
218 EXPECT_NE(std::string::npos, content.find(" visible paragraph")); | 210 EXPECT_NE(std::string::npos, content.find(" visible paragraph")); |
219 EXPECT_NE(std::string::npos, content.find(" visible iframe")); | 211 EXPECT_NE(std::string::npos, content.find(" visible iframe")); |
220 EXPECT_EQ(std::string::npos, content.find(" invisible pararaph")); | 212 EXPECT_EQ(std::string::npos, content.find(" invisible pararaph")); |
221 EXPECT_EQ(std::string::npos, content.find(" invisible iframe")); | 213 EXPECT_EQ(std::string::npos, content.find(" invisible iframe")); |
222 EXPECT_EQ(std::string::npos, content.find("iframe with zero size")); | 214 EXPECT_EQ(std::string::npos, content.find("iframe with zero size")); |
223 } | 215 } |
224 | 216 |
225 TEST_F(WebFrameTest, FrameForEnteredContext) | 217 TEST_F(WebFrameTest, FrameForEnteredContext) |
226 { | 218 { |
227 registerMockedHttpURLLoad("iframes_test.html"); | 219 registerMockedHttpURLLoad("iframes_test.html"); |
228 registerMockedHttpURLLoad("visible_iframe.html"); | 220 registerMockedHttpURLLoad("visible_iframe.html"); |
229 registerMockedHttpURLLoad("invisible_iframe.html"); | 221 registerMockedHttpURLLoad("invisible_iframe.html"); |
230 registerMockedHttpURLLoad("zero_sized_iframe.html"); | 222 registerMockedHttpURLLoad("zero_sized_iframe.html"); |
231 | 223 |
232 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "iframes_test
.html", true); | 224 FrameTestHelpers::WebViewHelper webViewHelper; |
| 225 webViewHelper.initializeAndLoad(m_baseURL + "iframes_test.html", true); |
233 | 226 |
234 v8::HandleScope scope(v8::Isolate::GetCurrent()); | 227 v8::HandleScope scope(v8::Isolate::GetCurrent()); |
235 EXPECT_EQ(m_webView->mainFrame(), | 228 EXPECT_EQ(webViewHelper.webView()->mainFrame(), WebFrame::frameForContext(we
bViewHelper.webView()->mainFrame()->mainWorldScriptContext())); |
236 WebFrame::frameForContext( | 229 EXPECT_EQ(webViewHelper.webView()->mainFrame()->firstChild(), WebFrame::fram
eForContext(webViewHelper.webView()->mainFrame()->firstChild()->mainWorldScriptC
ontext())); |
237 m_webView->mainFrame()->mainWorldScriptContext())); | |
238 EXPECT_EQ(m_webView->mainFrame()->firstChild(), | |
239 WebFrame::frameForContext( | |
240 m_webView->mainFrame()->firstChild()->mainWorldScriptContext()
)); | |
241 } | 230 } |
242 | 231 |
243 TEST_F(WebFrameTest, FormWithNullFrame) | 232 TEST_F(WebFrameTest, FormWithNullFrame) |
244 { | 233 { |
245 registerMockedHttpURLLoad("form.html"); | 234 registerMockedHttpURLLoad("form.html"); |
246 | 235 |
247 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "form.html"); | 236 FrameTestHelpers::WebViewHelper webViewHelper; |
| 237 webViewHelper.initializeAndLoad(m_baseURL + "form.html"); |
248 | 238 |
249 WebVector<WebFormElement> forms; | 239 WebVector<WebFormElement> forms; |
250 m_webView->mainFrame()->document().forms(forms); | 240 webViewHelper.webView()->mainFrame()->document().forms(forms); |
251 m_webView->close(); | 241 webViewHelper.reset(); |
252 m_webView = 0; | |
253 | 242 |
254 EXPECT_EQ(forms.size(), 1U); | 243 EXPECT_EQ(forms.size(), 1U); |
255 | 244 |
256 // This test passes if this doesn't crash. | 245 // This test passes if this doesn't crash. |
257 WebSearchableFormData searchableDataForm(forms[0]); | 246 WebSearchableFormData searchableDataForm(forms[0]); |
258 } | 247 } |
259 | 248 |
260 TEST_F(WebFrameTest, ChromePageJavascript) | 249 TEST_F(WebFrameTest, ChromePageJavascript) |
261 { | 250 { |
262 registerMockedChromeURLLoad("history.html"); | 251 registerMockedChromeURLLoad("history.html"); |
263 | 252 |
264 // Pass true to enable JavaScript. | 253 // Pass true to enable JavaScript. |
265 m_webView = FrameTestHelpers::createWebViewAndLoad(m_chromeURL + "history.ht
ml", true); | 254 FrameTestHelpers::WebViewHelper webViewHelper; |
| 255 webViewHelper.initializeAndLoad(m_chromeURL + "history.html", true); |
266 | 256 |
267 // Try to run JS against the chrome-style URL. | 257 // Try to run JS against the chrome-style URL. |
268 FrameTestHelpers::loadFrame(m_webView->mainFrame(), "javascript:document.bod
y.appendChild(document.createTextNode('Clobbered'))"); | 258 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.body.appendChild(document.createTextNode('Clobbered'))"); |
269 | 259 |
270 // Required to see any updates in contentAsText. | 260 // Required to see any updates in contentAsText. |
271 m_webView->layout(); | 261 webViewHelper.webView()->layout(); |
272 | 262 |
273 // Now retrieve the frame's text and ensure it was modified by running javas
cript. | 263 // Now retrieve the frame's text and ensure it was modified by running javas
cript. |
274 std::string content = std::string(m_webView->mainFrame()->contentAsText(1024
).utf8().data()); | 264 std::string content = std::string(webViewHelper.webView()->mainFrame()->cont
entAsText(1024).utf8().data()); |
275 EXPECT_NE(std::string::npos, content.find("Clobbered")); | 265 EXPECT_NE(std::string::npos, content.find("Clobbered")); |
276 } | 266 } |
277 | 267 |
278 TEST_F(WebFrameTest, ChromePageNoJavascript) | 268 TEST_F(WebFrameTest, ChromePageNoJavascript) |
279 { | 269 { |
280 registerMockedChromeURLLoad("history.html"); | 270 registerMockedChromeURLLoad("history.html"); |
281 | 271 |
282 /// Pass true to enable JavaScript. | 272 /// Pass true to enable JavaScript. |
283 m_webView = FrameTestHelpers::createWebViewAndLoad(m_chromeURL + "history.ht
ml", true); | 273 FrameTestHelpers::WebViewHelper webViewHelper; |
| 274 webViewHelper.initializeAndLoad(m_chromeURL + "history.html", true); |
284 | 275 |
285 // Try to run JS against the chrome-style URL after prohibiting it. | 276 // Try to run JS against the chrome-style URL after prohibiting it. |
286 WebSecurityPolicy::registerURLSchemeAsNotAllowingJavascriptURLs("chrome"); | 277 WebSecurityPolicy::registerURLSchemeAsNotAllowingJavascriptURLs("chrome"); |
287 FrameTestHelpers::loadFrame(m_webView->mainFrame(), "javascript:document.bod
y.appendChild(document.createTextNode('Clobbered'))"); | 278 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.body.appendChild(document.createTextNode('Clobbered'))"); |
288 | 279 |
289 // Required to see any updates in contentAsText. | 280 // Required to see any updates in contentAsText. |
290 m_webView->layout(); | 281 webViewHelper.webView()->layout(); |
291 | 282 |
292 // Now retrieve the frame's text and ensure it wasn't modified by running ja
vascript. | 283 // Now retrieve the frame's text and ensure it wasn't modified by running ja
vascript. |
293 std::string content = std::string(m_webView->mainFrame()->contentAsText(1024
).utf8().data()); | 284 std::string content = std::string(webViewHelper.webView()->mainFrame()->cont
entAsText(1024).utf8().data()); |
294 EXPECT_EQ(std::string::npos, content.find("Clobbered")); | 285 EXPECT_EQ(std::string::npos, content.find("Clobbered")); |
295 } | 286 } |
296 | 287 |
297 TEST_F(WebFrameTest, DispatchMessageEventWithOriginCheck) | 288 TEST_F(WebFrameTest, DispatchMessageEventWithOriginCheck) |
298 { | 289 { |
299 registerMockedHttpURLLoad("postmessage_test.html"); | 290 registerMockedHttpURLLoad("postmessage_test.html"); |
300 | 291 |
301 // Pass true to enable JavaScript. | 292 // Pass true to enable JavaScript. |
302 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "postmessage_
test.html", true); | 293 FrameTestHelpers::WebViewHelper webViewHelper; |
| 294 webViewHelper.initializeAndLoad(m_baseURL + "postmessage_test.html", true); |
303 | 295 |
304 // Send a message with the correct origin. | 296 // Send a message with the correct origin. |
305 WebSecurityOrigin correctOrigin(WebSecurityOrigin::create(toKURL(m_baseURL))
); | 297 WebSecurityOrigin correctOrigin(WebSecurityOrigin::create(toKURL(m_baseURL))
); |
306 WebDOMEvent event = m_webView->mainFrame()->document().createEvent("MessageE
vent"); | 298 WebDOMEvent event = webViewHelper.webView()->mainFrame()->document().createE
vent("MessageEvent"); |
307 WebDOMMessageEvent message = event.to<WebDOMMessageEvent>(); | 299 WebDOMMessageEvent message = event.to<WebDOMMessageEvent>(); |
308 WebSerializedScriptValue data(WebSerializedScriptValue::fromString("foo")); | 300 WebSerializedScriptValue data(WebSerializedScriptValue::fromString("foo")); |
309 message.initMessageEvent("message", false, false, data, "http://origin.com",
0, ""); | 301 message.initMessageEvent("message", false, false, data, "http://origin.com",
0, ""); |
310 m_webView->mainFrame()->dispatchMessageEventWithOriginCheck(correctOrigin, m
essage); | 302 webViewHelper.webView()->mainFrame()->dispatchMessageEventWithOriginCheck(co
rrectOrigin, message); |
311 | 303 |
312 // Send another message with incorrect origin. | 304 // Send another message with incorrect origin. |
313 WebSecurityOrigin incorrectOrigin(WebSecurityOrigin::create(toKURL(m_chromeU
RL))); | 305 WebSecurityOrigin incorrectOrigin(WebSecurityOrigin::create(toKURL(m_chromeU
RL))); |
314 m_webView->mainFrame()->dispatchMessageEventWithOriginCheck(incorrectOrigin,
message); | 306 webViewHelper.webView()->mainFrame()->dispatchMessageEventWithOriginCheck(in
correctOrigin, message); |
315 | 307 |
316 // Required to see any updates in contentAsText. | 308 // Required to see any updates in contentAsText. |
317 m_webView->layout(); | 309 webViewHelper.webView()->layout(); |
318 | 310 |
319 // Verify that only the first addition is in the body of the page. | 311 // Verify that only the first addition is in the body of the page. |
320 std::string content = std::string(m_webView->mainFrame()->contentAsText(1024
).utf8().data()); | 312 std::string content = std::string(webViewHelper.webView()->mainFrame()->cont
entAsText(1024).utf8().data()); |
321 EXPECT_NE(std::string::npos, content.find("Message 1.")); | 313 EXPECT_NE(std::string::npos, content.find("Message 1.")); |
322 EXPECT_EQ(std::string::npos, content.find("Message 2.")); | 314 EXPECT_EQ(std::string::npos, content.find("Message 2.")); |
323 } | 315 } |
324 | 316 |
325 class FixedLayoutTestWebViewClient : public WebViewClient { | 317 class FixedLayoutTestWebViewClient : public WebViewClient { |
326 public: | 318 public: |
327 virtual WebScreenInfo screenInfo() OVERRIDE { return m_screenInfo; } | 319 virtual WebScreenInfo screenInfo() OVERRIDE { return m_screenInfo; } |
328 | 320 |
329 WebScreenInfo m_screenInfo; | 321 WebScreenInfo m_screenInfo; |
330 }; | 322 }; |
331 | 323 |
332 TEST_F(WebFrameTest, FrameViewNeedsLayoutOnFixedLayoutResize) | 324 TEST_F(WebFrameTest, FrameViewNeedsLayoutOnFixedLayoutResize) |
333 { | 325 { |
334 registerMockedHttpURLLoad("fixed_layout.html"); | 326 registerMockedHttpURLLoad("fixed_layout.html"); |
335 | 327 |
336 FixedLayoutTestWebViewClient client; | 328 FixedLayoutTestWebViewClient client; |
337 int viewportWidth = 640; | 329 int viewportWidth = 640; |
338 int viewportHeight = 480; | 330 int viewportHeight = 480; |
339 | 331 |
340 // Make sure we initialize to minimum scale, even if the window size | 332 // Make sure we initialize to minimum scale, even if the window size |
341 // only becomes available after the load begins. | 333 // only becomes available after the load begins. |
342 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html", true, 0, &client); | 334 FrameTestHelpers::WebViewHelper webViewHelper; |
343 m_webView->enableFixedLayoutMode(true); | 335 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html", true, 0, &c
lient); |
344 m_webView->settings()->setViewportEnabled(true); | 336 webViewHelper.webView()->enableFixedLayoutMode(true); |
345 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 337 webViewHelper.webView()->settings()->setViewportEnabled(true); |
346 m_webView->layout(); | 338 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 339 webViewHelper.webView()->layout(); |
347 | 340 |
348 webViewImpl()->mainFrameImpl()->frameView()->setFixedLayoutSize(WebCore::Int
Size(100, 100)); | 341 webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->setFixedLayoutSiz
e(WebCore::IntSize(100, 100)); |
349 EXPECT_TRUE(webViewImpl()->mainFrameImpl()->frameView()->needsLayout()); | 342 EXPECT_TRUE(webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->needs
Layout()); |
350 | 343 |
351 int prevLayoutCount = webViewImpl()->mainFrameImpl()->frameView()->layoutCou
nt(); | 344 int prevLayoutCount = webViewHelper.webViewImpl()->mainFrameImpl()->frameVie
w()->layoutCount(); |
352 webViewImpl()->mainFrameImpl()->frameView()->setFrameRect(WebCore::IntRect(0
, 0, 641, 481)); | 345 webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->setFrameRect(WebC
ore::IntRect(0, 0, 641, 481)); |
353 EXPECT_EQ(prevLayoutCount, webViewImpl()->mainFrameImpl()->frameView()->layo
utCount()); | 346 EXPECT_EQ(prevLayoutCount, webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView()->layoutCount()); |
354 | 347 |
355 webViewImpl()->layout(); | 348 webViewHelper.webViewImpl()->layout(); |
356 } | 349 } |
357 | 350 |
358 TEST_F(WebFrameTest, ChangeInFixedLayoutTriggersTextAutosizingRecalculate) | 351 TEST_F(WebFrameTest, ChangeInFixedLayoutTriggersTextAutosizingRecalculate) |
359 { | 352 { |
360 registerMockedHttpURLLoad("fixed_layout.html"); | 353 registerMockedHttpURLLoad("fixed_layout.html"); |
361 | 354 |
362 FixedLayoutTestWebViewClient client; | 355 FixedLayoutTestWebViewClient client; |
363 int viewportWidth = 640; | 356 int viewportWidth = 640; |
364 int viewportHeight = 480; | 357 int viewportHeight = 480; |
365 | 358 |
366 // Make sure we initialize to minimum scale, even if the window size | 359 // Make sure we initialize to minimum scale, even if the window size |
367 // only becomes available after the load begins. | 360 // only becomes available after the load begins. |
368 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html", true, 0, &client); | 361 FrameTestHelpers::WebViewHelper webViewHelper; |
369 m_webView->enableFixedLayoutMode(true); | 362 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html", true, 0, &c
lient); |
370 m_webView->settings()->setViewportEnabled(true); | 363 webViewHelper.webView()->enableFixedLayoutMode(true); |
| 364 webViewHelper.webView()->settings()->setViewportEnabled(true); |
371 | 365 |
372 WebCore::Document* document = webViewImpl()->page()->mainFrame()->document()
; | 366 WebCore::Document* document = webViewHelper.webViewImpl()->page()->mainFrame
()->document(); |
373 document->settings()->setTextAutosizingEnabled(true); | 367 document->settings()->setTextAutosizingEnabled(true); |
374 EXPECT_TRUE(document->settings()->textAutosizingEnabled()); | 368 EXPECT_TRUE(document->settings()->textAutosizingEnabled()); |
375 webViewImpl()->resize(WebSize(viewportWidth, viewportHeight)); | 369 webViewHelper.webViewImpl()->resize(WebSize(viewportWidth, viewportHeight)); |
376 webViewImpl()->layout(); | 370 webViewHelper.webViewImpl()->layout(); |
377 | 371 |
378 WebCore::RenderObject* renderer = document->renderer(); | 372 WebCore::RenderObject* renderer = document->renderer(); |
379 bool multiplierSetAtLeastOnce = false; | 373 bool multiplierSetAtLeastOnce = false; |
380 while (renderer) { | 374 while (renderer) { |
381 if (renderer->style()) { | 375 if (renderer->style()) { |
382 renderer->style()->setTextAutosizingMultiplier(2); | 376 renderer->style()->setTextAutosizingMultiplier(2); |
383 EXPECT_EQ(2, renderer->style()->textAutosizingMultiplier()); | 377 EXPECT_EQ(2, renderer->style()->textAutosizingMultiplier()); |
384 multiplierSetAtLeastOnce = true; | 378 multiplierSetAtLeastOnce = true; |
385 } | 379 } |
386 renderer = renderer->nextInPreOrder(); | 380 renderer = renderer->nextInPreOrder(); |
387 } | 381 } |
388 EXPECT_TRUE(multiplierSetAtLeastOnce); | 382 EXPECT_TRUE(multiplierSetAtLeastOnce); |
389 | 383 |
390 WebCore::ViewportArguments arguments = document->viewportArguments(); | 384 WebCore::ViewportArguments arguments = document->viewportArguments(); |
391 // Choose a width that's not going match the viewport width of the loaded do
cument. | 385 // Choose a width that's not going match the viewport width of the loaded do
cument. |
392 arguments.minWidth = WebCore::Length(100, WebCore::Fixed); | 386 arguments.minWidth = WebCore::Length(100, WebCore::Fixed); |
393 arguments.maxWidth = WebCore::Length(100, WebCore::Fixed); | 387 arguments.maxWidth = WebCore::Length(100, WebCore::Fixed); |
394 webViewImpl()->updatePageDefinedPageScaleConstraints(arguments); | 388 webViewHelper.webViewImpl()->updatePageDefinedPageScaleConstraints(arguments
); |
395 | 389 |
396 bool multiplierCheckedAtLeastOnce = false; | 390 bool multiplierCheckedAtLeastOnce = false; |
397 renderer = document->renderer(); | 391 renderer = document->renderer(); |
398 while (renderer) { | 392 while (renderer) { |
399 if (renderer->style()) { | 393 if (renderer->style()) { |
400 EXPECT_EQ(1, renderer->style()->textAutosizingMultiplier()); | 394 EXPECT_EQ(1, renderer->style()->textAutosizingMultiplier()); |
401 multiplierCheckedAtLeastOnce = true; | 395 multiplierCheckedAtLeastOnce = true; |
402 } | 396 } |
403 renderer = renderer->nextInPreOrder(); | 397 renderer = renderer->nextInPreOrder(); |
404 } | 398 } |
405 EXPECT_TRUE(multiplierCheckedAtLeastOnce); | 399 EXPECT_TRUE(multiplierCheckedAtLeastOnce); |
406 } | 400 } |
407 | 401 |
408 TEST_F(WebFrameTest, FixedLayoutSizeStopsResizeFromChangingLayoutSize) | 402 TEST_F(WebFrameTest, FixedLayoutSizeStopsResizeFromChangingLayoutSize) |
409 { | 403 { |
410 registerMockedHttpURLLoad("fixed_layout.html"); | 404 registerMockedHttpURLLoad("fixed_layout.html"); |
411 | 405 |
412 int viewportWidth = 640; | 406 int viewportWidth = 640; |
413 int viewportHeight = 480; | 407 int viewportHeight = 480; |
414 | 408 |
415 int fixedLayoutWidth = viewportWidth / 2; | 409 int fixedLayoutWidth = viewportWidth / 2; |
416 int fixedLayoutHeight = viewportHeight / 2; | 410 int fixedLayoutHeight = viewportHeight / 2; |
417 | 411 |
418 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html"); | 412 FrameTestHelpers::WebViewHelper webViewHelper; |
419 m_webView->enableFixedLayoutMode(true); | 413 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html"); |
420 m_webView->settings()->setViewportEnabled(true); | 414 webViewHelper.webView()->enableFixedLayoutMode(true); |
421 m_webView->setFixedLayoutSize(WebSize(fixedLayoutWidth, fixedLayoutHeight)); | 415 webViewHelper.webView()->settings()->setViewportEnabled(true); |
422 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 416 webViewHelper.webView()->setFixedLayoutSize(WebSize(fixedLayoutWidth, fixedL
ayoutHeight)); |
423 m_webView->layout(); | 417 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 418 webViewHelper.webView()->layout(); |
424 | 419 |
425 EXPECT_EQ(fixedLayoutWidth, m_webView->fixedLayoutSize().width); | 420 EXPECT_EQ(fixedLayoutWidth, webViewHelper.webView()->fixedLayoutSize().width
); |
426 EXPECT_EQ(fixedLayoutHeight, m_webView->fixedLayoutSize().height); | 421 EXPECT_EQ(fixedLayoutHeight, webViewHelper.webView()->fixedLayoutSize().heig
ht); |
427 } | 422 } |
428 | 423 |
429 TEST_F(WebFrameTest, FixedLayoutSizePreventsResizeFromChangingPageScale) | 424 TEST_F(WebFrameTest, FixedLayoutSizePreventsResizeFromChangingPageScale) |
430 { | 425 { |
431 registerMockedHttpURLLoad("fixed_layout.html"); | 426 registerMockedHttpURLLoad("fixed_layout.html"); |
432 | 427 |
433 int viewportWidth = 640; | 428 int viewportWidth = 640; |
434 int viewportHeight = 480; | 429 int viewportHeight = 480; |
435 | 430 |
436 int fixedLayoutWidth = viewportWidth / 2; | 431 int fixedLayoutWidth = viewportWidth / 2; |
437 int fixedLayoutHeight = viewportHeight / 2; | 432 int fixedLayoutHeight = viewportHeight / 2; |
438 | 433 |
439 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html"); | 434 FrameTestHelpers::WebViewHelper webViewHelper; |
440 m_webView->enableFixedLayoutMode(true); | 435 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html"); |
441 m_webView->settings()->setViewportEnabled(true); | 436 webViewHelper.webView()->enableFixedLayoutMode(true); |
442 m_webView->setFixedLayoutSize(WebSize(fixedLayoutWidth, fixedLayoutHeight)); | 437 webViewHelper.webView()->settings()->setViewportEnabled(true); |
443 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 438 webViewHelper.webView()->setFixedLayoutSize(WebSize(fixedLayoutWidth, fixedL
ayoutHeight)); |
444 m_webView->layout(); | 439 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
445 float pageScaleFactor = m_webView->pageScaleFactor(); | 440 webViewHelper.webView()->layout(); |
| 441 float pageScaleFactor = webViewHelper.webView()->pageScaleFactor(); |
446 | 442 |
447 m_webView->resize(WebSize(viewportWidth * 2, viewportHeight * 2)); | 443 webViewHelper.webView()->resize(WebSize(viewportWidth * 2, viewportHeight *
2)); |
448 | 444 |
449 EXPECT_EQ(pageScaleFactor, m_webView->pageScaleFactor()); | 445 EXPECT_EQ(pageScaleFactor, webViewHelper.webView()->pageScaleFactor()); |
450 } | 446 } |
451 | 447 |
452 TEST_F(WebFrameTest, FixedLayoutSizePreventsLayoutFromChangingPageScale) | 448 TEST_F(WebFrameTest, FixedLayoutSizePreventsLayoutFromChangingPageScale) |
453 { | 449 { |
454 registerMockedHttpURLLoad("fixed_layout.html"); | 450 registerMockedHttpURLLoad("fixed_layout.html"); |
455 | 451 |
456 int viewportWidth = 640; | 452 int viewportWidth = 640; |
457 int viewportHeight = 480; | 453 int viewportHeight = 480; |
458 | 454 |
459 int fixedLayoutWidth = viewportWidth * 2; | 455 int fixedLayoutWidth = viewportWidth * 2; |
460 int fixedLayoutHeight = viewportHeight * 2; | 456 int fixedLayoutHeight = viewportHeight * 2; |
461 | 457 |
462 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html"); | 458 FrameTestHelpers::WebViewHelper webViewHelper; |
463 m_webView->enableFixedLayoutMode(true); | 459 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html"); |
464 m_webView->settings()->setViewportEnabled(true); | 460 webViewHelper.webView()->enableFixedLayoutMode(true); |
465 m_webView->setFixedLayoutSize(WebSize(viewportWidth, viewportHeight)); | 461 webViewHelper.webView()->settings()->setViewportEnabled(true); |
466 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 462 webViewHelper.webView()->setFixedLayoutSize(WebSize(viewportWidth, viewportH
eight)); |
467 m_webView->layout(); | 463 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
468 float pageScaleFactor = m_webView->pageScaleFactor(); | 464 webViewHelper.webView()->layout(); |
| 465 float pageScaleFactor = webViewHelper.webView()->pageScaleFactor(); |
469 | 466 |
470 m_webView->setFixedLayoutSize(WebSize(fixedLayoutWidth, fixedLayoutHeight)); | 467 webViewHelper.webView()->setFixedLayoutSize(WebSize(fixedLayoutWidth, fixedL
ayoutHeight)); |
471 m_webView->layout(); | 468 webViewHelper.webView()->layout(); |
472 | 469 |
473 EXPECT_EQ(pageScaleFactor, m_webView->pageScaleFactor()); | 470 EXPECT_EQ(pageScaleFactor, webViewHelper.webView()->pageScaleFactor()); |
474 } | 471 } |
475 | 472 |
476 TEST_F(WebFrameTest, PreferredSizeAndContentSizeReportedCorrectlyWithZeroHeightF
ixedLayout) | 473 TEST_F(WebFrameTest, PreferredSizeAndContentSizeReportedCorrectlyWithZeroHeightF
ixedLayout) |
477 { | 474 { |
478 registerMockedHttpURLLoad("200-by-300.html"); | 475 registerMockedHttpURLLoad("200-by-300.html"); |
479 | 476 |
480 int windowWidth = 100; | 477 int windowWidth = 100; |
481 int windowHeight = 100; | 478 int windowHeight = 100; |
482 int viewportWidth = 100; | 479 int viewportWidth = 100; |
483 int viewportHeight = 0; | 480 int viewportHeight = 0; |
484 int divWidth = 200; | 481 int divWidth = 200; |
485 int divHeight = 300; | 482 int divHeight = 300; |
486 | 483 |
487 FixedLayoutTestWebViewClient client; | 484 FixedLayoutTestWebViewClient client; |
488 client.m_screenInfo.deviceScaleFactor = 1; | 485 client.m_screenInfo.deviceScaleFactor = 1; |
489 | 486 |
490 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "200-by-300.h
tml", true, 0, &client); | 487 FrameTestHelpers::WebViewHelper webViewHelper; |
491 m_webView->enableFixedLayoutMode(true); | 488 webViewHelper.initializeAndLoad(m_baseURL + "200-by-300.html", true, 0, &cli
ent); |
492 m_webView->settings()->setViewportEnabled(true); | 489 webViewHelper.webView()->enableFixedLayoutMode(true); |
493 m_webView->resize(WebSize(windowWidth, windowHeight)); | 490 webViewHelper.webView()->settings()->setViewportEnabled(true); |
494 m_webView->setFixedLayoutSize(WebSize(viewportWidth, viewportHeight)); | 491 webViewHelper.webView()->resize(WebSize(windowWidth, windowHeight)); |
495 m_webView->layout(); | 492 webViewHelper.webView()->setFixedLayoutSize(WebSize(viewportWidth, viewportH
eight)); |
| 493 webViewHelper.webView()->layout(); |
496 | 494 |
497 EXPECT_EQ(divWidth, m_webView->mainFrame()->contentsSize().width); | 495 EXPECT_EQ(divWidth, webViewHelper.webView()->mainFrame()->contentsSize().wid
th); |
498 EXPECT_EQ(divHeight, m_webView->mainFrame()->contentsSize().height); | 496 EXPECT_EQ(divHeight, webViewHelper.webView()->mainFrame()->contentsSize().he
ight); |
499 | 497 |
500 EXPECT_EQ(divWidth, m_webView->contentsPreferredMinimumSize().width); | 498 EXPECT_EQ(divWidth, webViewHelper.webView()->contentsPreferredMinimumSize().
width); |
501 EXPECT_EQ(divHeight, m_webView->contentsPreferredMinimumSize().height); | 499 EXPECT_EQ(divHeight, webViewHelper.webView()->contentsPreferredMinimumSize()
.height); |
502 } | 500 } |
503 | 501 |
504 TEST_F(WebFrameTest, DisablingFixedLayoutSizeSetsCorrectLayoutSize) | 502 TEST_F(WebFrameTest, DisablingFixedLayoutSizeSetsCorrectLayoutSize) |
505 { | 503 { |
506 registerMockedHttpURLLoad("no_viewport_tag.html"); | 504 registerMockedHttpURLLoad("no_viewport_tag.html"); |
507 | 505 |
508 FixedLayoutTestWebViewClient client; | 506 FixedLayoutTestWebViewClient client; |
509 client.m_screenInfo.deviceScaleFactor = 1; | 507 client.m_screenInfo.deviceScaleFactor = 1; |
510 int viewportWidth = 640; | 508 int viewportWidth = 640; |
511 int viewportHeight = 480; | 509 int viewportHeight = 480; |
512 | 510 |
513 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "no_viewport_
tag.html", true, 0, &client); | 511 FrameTestHelpers::WebViewHelper webViewHelper; |
514 m_webView->settings()->setSupportDeprecatedTargetDensityDPI(true); | 512 webViewHelper.initializeAndLoad(m_baseURL + "no_viewport_tag.html", true, 0,
&client); |
515 m_webView->enableFixedLayoutMode(true); | 513 webViewHelper.webView()->settings()->setSupportDeprecatedTargetDensityDPI(tr
ue); |
516 m_webView->settings()->setUseWideViewport(true); | 514 webViewHelper.webView()->enableFixedLayoutMode(true); |
517 m_webView->settings()->setViewportEnabled(true); | 515 webViewHelper.webView()->settings()->setUseWideViewport(true); |
518 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 516 webViewHelper.webView()->settings()->setViewportEnabled(true); |
| 517 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
519 | 518 |
520 m_webView->setFixedLayoutSize(WebSize(viewportWidth, viewportHeight)); | 519 webViewHelper.webView()->setFixedLayoutSize(WebSize(viewportWidth, viewportH
eight)); |
521 EXPECT_TRUE(webViewImpl()->mainFrameImpl()->frameView()->needsLayout()); | 520 EXPECT_TRUE(webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->needs
Layout()); |
522 m_webView->layout(); | 521 webViewHelper.webView()->layout(); |
523 EXPECT_EQ(viewportWidth, webViewImpl()->mainFrameImpl()->frameView()->conten
tsSize().width()); | 522 EXPECT_EQ(viewportWidth, webViewHelper.webViewImpl()->mainFrameImpl()->frame
View()->contentsSize().width()); |
524 | 523 |
525 m_webView->setFixedLayoutSize(WebSize(0, 0)); | 524 webViewHelper.webView()->setFixedLayoutSize(WebSize(0, 0)); |
526 EXPECT_TRUE(webViewImpl()->mainFrameImpl()->frameView()->needsLayout()); | 525 EXPECT_TRUE(webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->needs
Layout()); |
527 m_webView->layout(); | 526 webViewHelper.webView()->layout(); |
528 EXPECT_EQ(980, webViewImpl()->mainFrameImpl()->frameView()->contentsSize().w
idth()); | 527 EXPECT_EQ(980, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->co
ntentsSize().width()); |
529 } | 528 } |
530 | 529 |
531 TEST_F(WebFrameTest, DeviceScaleFactorUsesDefaultWithoutViewportTag) | 530 TEST_F(WebFrameTest, DeviceScaleFactorUsesDefaultWithoutViewportTag) |
532 { | 531 { |
533 registerMockedHttpURLLoad("no_viewport_tag.html"); | 532 registerMockedHttpURLLoad("no_viewport_tag.html"); |
534 | 533 |
535 int viewportWidth = 640; | 534 int viewportWidth = 640; |
536 int viewportHeight = 480; | 535 int viewportHeight = 480; |
537 | 536 |
538 FixedLayoutTestWebViewClient client; | 537 FixedLayoutTestWebViewClient client; |
539 client.m_screenInfo.deviceScaleFactor = 2; | 538 client.m_screenInfo.deviceScaleFactor = 2; |
540 | 539 |
541 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "no_viewport_
tag.html", true, 0, &client); | 540 FrameTestHelpers::WebViewHelper webViewHelper; |
| 541 webViewHelper.initializeAndLoad(m_baseURL + "no_viewport_tag.html", true, 0,
&client); |
542 | 542 |
543 m_webView->settings()->setViewportEnabled(true); | 543 webViewHelper.webView()->settings()->setViewportEnabled(true); |
544 m_webView->enableFixedLayoutMode(true); | 544 webViewHelper.webView()->enableFixedLayoutMode(true); |
545 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 545 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
546 m_webView->layout(); | 546 webViewHelper.webView()->layout(); |
547 | 547 |
548 EXPECT_EQ(2, m_webView->deviceScaleFactor()); | 548 EXPECT_EQ(2, webViewHelper.webView()->deviceScaleFactor()); |
549 | 549 |
550 // Device scale factor should be independent of page scale. | 550 // Device scale factor should be independent of page scale. |
551 m_webView->setPageScaleFactorLimits(1, 2); | 551 webViewHelper.webView()->setPageScaleFactorLimits(1, 2); |
552 m_webView->setPageScaleFactorPreservingScrollOffset(0.5); | 552 webViewHelper.webView()->setPageScaleFactorPreservingScrollOffset(0.5); |
553 m_webView->layout(); | 553 webViewHelper.webView()->layout(); |
554 EXPECT_EQ(1, m_webView->pageScaleFactor()); | 554 EXPECT_EQ(1, webViewHelper.webView()->pageScaleFactor()); |
555 | 555 |
556 // Force the layout to happen before leaving the test. | 556 // Force the layout to happen before leaving the test. |
557 m_webView->mainFrame()->contentAsText(1024).utf8(); | 557 webViewHelper.webView()->mainFrame()->contentAsText(1024).utf8(); |
558 } | 558 } |
559 | 559 |
560 TEST_F(WebFrameTest, FixedLayoutInitializeAtMinimumScale) | 560 TEST_F(WebFrameTest, FixedLayoutInitializeAtMinimumScale) |
561 { | 561 { |
562 UseMockScrollbarSettings mockScrollbarSettings; | 562 UseMockScrollbarSettings mockScrollbarSettings; |
563 | 563 |
564 registerMockedHttpURLLoad("fixed_layout.html"); | 564 registerMockedHttpURLLoad("fixed_layout.html"); |
565 | 565 |
566 FixedLayoutTestWebViewClient client; | 566 FixedLayoutTestWebViewClient client; |
567 client.m_screenInfo.deviceScaleFactor = 1; | 567 client.m_screenInfo.deviceScaleFactor = 1; |
568 int viewportWidth = 640; | 568 int viewportWidth = 640; |
569 int viewportHeight = 480; | 569 int viewportHeight = 480; |
570 | 570 |
571 // Make sure we initialize to minimum scale, even if the window size | 571 // Make sure we initialize to minimum scale, even if the window size |
572 // only becomes available after the load begins. | 572 // only becomes available after the load begins. |
573 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html", true, 0, &client); | 573 FrameTestHelpers::WebViewHelper webViewHelper; |
574 m_webView->enableFixedLayoutMode(true); | 574 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html", true, 0, &c
lient); |
575 m_webView->settings()->setViewportEnabled(true); | 575 webViewHelper.webView()->enableFixedLayoutMode(true); |
576 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 576 webViewHelper.webView()->settings()->setViewportEnabled(true); |
| 577 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
577 | 578 |
578 int defaultFixedLayoutWidth = 980; | 579 int defaultFixedLayoutWidth = 980; |
579 float minimumPageScaleFactor = viewportWidth / (float) defaultFixedLayoutWid
th; | 580 float minimumPageScaleFactor = viewportWidth / (float) defaultFixedLayoutWid
th; |
580 EXPECT_EQ(minimumPageScaleFactor, m_webView->pageScaleFactor()); | 581 EXPECT_EQ(minimumPageScaleFactor, webViewHelper.webView()->pageScaleFactor()
); |
581 EXPECT_EQ(minimumPageScaleFactor, m_webView->minimumPageScaleFactor()); | 582 EXPECT_EQ(minimumPageScaleFactor, webViewHelper.webView()->minimumPageScaleF
actor()); |
582 | 583 |
583 // Assume the user has pinch zoomed to page scale factor 2. | 584 // Assume the user has pinch zoomed to page scale factor 2. |
584 float userPinchPageScaleFactor = 2; | 585 float userPinchPageScaleFactor = 2; |
585 m_webView->setPageScaleFactorPreservingScrollOffset(userPinchPageScaleFactor
); | 586 webViewHelper.webView()->setPageScaleFactorPreservingScrollOffset(userPinchP
ageScaleFactor); |
586 m_webView->layout(); | 587 webViewHelper.webView()->layout(); |
587 | 588 |
588 // Make sure we don't reset to initial scale if the page continues to load. | 589 // Make sure we don't reset to initial scale if the page continues to load. |
589 bool isNewNavigation; | 590 bool isNewNavigation; |
590 webViewImpl()->didCommitLoad(&isNewNavigation, false); | 591 webViewHelper.webViewImpl()->didCommitLoad(&isNewNavigation, false); |
591 webViewImpl()->didChangeContentsSize(); | 592 webViewHelper.webViewImpl()->didChangeContentsSize(); |
592 EXPECT_EQ(userPinchPageScaleFactor, m_webView->pageScaleFactor()); | 593 EXPECT_EQ(userPinchPageScaleFactor, webViewHelper.webView()->pageScaleFactor
()); |
593 | 594 |
594 // Make sure we don't reset to initial scale if the viewport size changes. | 595 // Make sure we don't reset to initial scale if the viewport size changes. |
595 m_webView->resize(WebSize(viewportWidth, viewportHeight + 100)); | 596 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight + 100)
); |
596 EXPECT_EQ(userPinchPageScaleFactor, m_webView->pageScaleFactor()); | 597 EXPECT_EQ(userPinchPageScaleFactor, webViewHelper.webView()->pageScaleFactor
()); |
597 } | 598 } |
598 | 599 |
599 TEST_F(WebFrameTest, WideDocumentInitializeAtMinimumScale) | 600 TEST_F(WebFrameTest, WideDocumentInitializeAtMinimumScale) |
600 { | 601 { |
601 UseMockScrollbarSettings mockScrollbarSettings; | 602 UseMockScrollbarSettings mockScrollbarSettings; |
602 | 603 |
603 registerMockedHttpURLLoad("wide_document.html"); | 604 registerMockedHttpURLLoad("wide_document.html"); |
604 | 605 |
605 FixedLayoutTestWebViewClient client; | 606 FixedLayoutTestWebViewClient client; |
606 client.m_screenInfo.deviceScaleFactor = 1; | 607 client.m_screenInfo.deviceScaleFactor = 1; |
607 int viewportWidth = 640; | 608 int viewportWidth = 640; |
608 int viewportHeight = 480; | 609 int viewportHeight = 480; |
609 | 610 |
610 // Make sure we initialize to minimum scale, even if the window size | 611 // Make sure we initialize to minimum scale, even if the window size |
611 // only becomes available after the load begins. | 612 // only becomes available after the load begins. |
612 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "wide_documen
t.html", true, 0, &client); | 613 FrameTestHelpers::WebViewHelper webViewHelper; |
613 m_webView->enableFixedLayoutMode(true); | 614 webViewHelper.initializeAndLoad(m_baseURL + "wide_document.html", true, 0, &
client); |
614 m_webView->settings()->setViewportEnabled(true); | 615 webViewHelper.webView()->enableFixedLayoutMode(true); |
615 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 616 webViewHelper.webView()->settings()->setViewportEnabled(true); |
| 617 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
616 | 618 |
617 int wideDocumentWidth = 1500; | 619 int wideDocumentWidth = 1500; |
618 float minimumPageScaleFactor = viewportWidth / (float) wideDocumentWidth; | 620 float minimumPageScaleFactor = viewportWidth / (float) wideDocumentWidth; |
619 EXPECT_EQ(minimumPageScaleFactor, m_webView->pageScaleFactor()); | 621 EXPECT_EQ(minimumPageScaleFactor, webViewHelper.webView()->pageScaleFactor()
); |
620 EXPECT_EQ(minimumPageScaleFactor, m_webView->minimumPageScaleFactor()); | 622 EXPECT_EQ(minimumPageScaleFactor, webViewHelper.webView()->minimumPageScaleF
actor()); |
621 | 623 |
622 // Assume the user has pinch zoomed to page scale factor 2. | 624 // Assume the user has pinch zoomed to page scale factor 2. |
623 float userPinchPageScaleFactor = 2; | 625 float userPinchPageScaleFactor = 2; |
624 m_webView->setPageScaleFactorPreservingScrollOffset(userPinchPageScaleFactor
); | 626 webViewHelper.webView()->setPageScaleFactorPreservingScrollOffset(userPinchP
ageScaleFactor); |
625 m_webView->layout(); | 627 webViewHelper.webView()->layout(); |
626 | 628 |
627 // Make sure we don't reset to initial scale if the page continues to load. | 629 // Make sure we don't reset to initial scale if the page continues to load. |
628 bool isNewNavigation; | 630 bool isNewNavigation; |
629 webViewImpl()->didCommitLoad(&isNewNavigation, false); | 631 webViewHelper.webViewImpl()->didCommitLoad(&isNewNavigation, false); |
630 webViewImpl()->didChangeContentsSize(); | 632 webViewHelper.webViewImpl()->didChangeContentsSize(); |
631 EXPECT_EQ(userPinchPageScaleFactor, m_webView->pageScaleFactor()); | 633 EXPECT_EQ(userPinchPageScaleFactor, webViewHelper.webView()->pageScaleFactor
()); |
632 | 634 |
633 // Make sure we don't reset to initial scale if the viewport size changes. | 635 // Make sure we don't reset to initial scale if the viewport size changes. |
634 m_webView->resize(WebSize(viewportWidth, viewportHeight + 100)); | 636 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight + 100)
); |
635 EXPECT_EQ(userPinchPageScaleFactor, m_webView->pageScaleFactor()); | 637 EXPECT_EQ(userPinchPageScaleFactor, webViewHelper.webView()->pageScaleFactor
()); |
636 } | 638 } |
637 | 639 |
638 TEST_F(WebFrameTest, setLoadWithOverviewModeToFalse) | 640 TEST_F(WebFrameTest, setLoadWithOverviewModeToFalse) |
639 { | 641 { |
640 registerMockedHttpURLLoad("viewport-auto-initial-scale.html"); | 642 registerMockedHttpURLLoad("viewport-auto-initial-scale.html"); |
641 | 643 |
642 FixedLayoutTestWebViewClient client; | 644 FixedLayoutTestWebViewClient client; |
643 client.m_screenInfo.deviceScaleFactor = 1; | 645 client.m_screenInfo.deviceScaleFactor = 1; |
644 int viewportWidth = 640; | 646 int viewportWidth = 640; |
645 int viewportHeight = 480; | 647 int viewportHeight = 480; |
646 | 648 |
647 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport-aut
o-initial-scale.html", true, 0, &client); | 649 FrameTestHelpers::WebViewHelper webViewHelper; |
648 m_webView->enableFixedLayoutMode(true); | 650 webViewHelper.initializeAndLoad(m_baseURL + "viewport-auto-initial-scale.htm
l", true, 0, &client); |
649 m_webView->settings()->setViewportEnabled(true); | 651 webViewHelper.webView()->enableFixedLayoutMode(true); |
650 m_webView->settings()->setWideViewportQuirkEnabled(true); | 652 webViewHelper.webView()->settings()->setViewportEnabled(true); |
651 m_webView->settings()->setLoadWithOverviewMode(false); | 653 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
652 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 654 webViewHelper.webView()->settings()->setLoadWithOverviewMode(false); |
| 655 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
653 | 656 |
654 // The page must be displayed at 100% zoom. | 657 // The page must be displayed at 100% zoom. |
655 EXPECT_EQ(1.0f, m_webView->pageScaleFactor()); | 658 EXPECT_EQ(1.0f, webViewHelper.webView()->pageScaleFactor()); |
656 } | 659 } |
657 | 660 |
658 TEST_F(WebFrameTest, SetLoadWithOverviewModeToFalseAndNoWideViewport) | 661 TEST_F(WebFrameTest, SetLoadWithOverviewModeToFalseAndNoWideViewport) |
659 { | 662 { |
660 registerMockedHttpURLLoad("large-div.html"); | 663 registerMockedHttpURLLoad("large-div.html"); |
661 | 664 |
662 FixedLayoutTestWebViewClient client; | 665 FixedLayoutTestWebViewClient client; |
663 client.m_screenInfo.deviceScaleFactor = 1; | 666 client.m_screenInfo.deviceScaleFactor = 1; |
664 int viewportWidth = 640; | 667 int viewportWidth = 640; |
665 int viewportHeight = 480; | 668 int viewportHeight = 480; |
666 | 669 |
667 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "large-div.ht
ml", true, 0, &client); | 670 FrameTestHelpers::WebViewHelper webViewHelper; |
668 m_webView->enableFixedLayoutMode(true); | 671 webViewHelper.initializeAndLoad(m_baseURL + "large-div.html", true, 0, &clie
nt); |
669 m_webView->settings()->setViewportEnabled(true); | 672 webViewHelper.webView()->enableFixedLayoutMode(true); |
670 m_webView->settings()->setLoadWithOverviewMode(false); | 673 webViewHelper.webView()->settings()->setViewportEnabled(true); |
671 m_webView->settings()->setWideViewportQuirkEnabled(true); | 674 webViewHelper.webView()->settings()->setLoadWithOverviewMode(false); |
672 m_webView->settings()->setUseWideViewport(false); | 675 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
673 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 676 webViewHelper.webView()->settings()->setUseWideViewport(false); |
| 677 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
674 | 678 |
675 // The page must be displayed at 100% zoom, despite that it hosts a wide div
element. | 679 // The page must be displayed at 100% zoom, despite that it hosts a wide div
element. |
676 EXPECT_EQ(1.0f, m_webView->pageScaleFactor()); | 680 EXPECT_EQ(1.0f, webViewHelper.webView()->pageScaleFactor()); |
677 } | 681 } |
678 | 682 |
679 TEST_F(WebFrameTest, NoWideViewportIgnoresPageViewportWidth) | 683 TEST_F(WebFrameTest, NoWideViewportIgnoresPageViewportWidth) |
680 { | 684 { |
681 registerMockedHttpURLLoad("viewport-auto-initial-scale.html"); | 685 registerMockedHttpURLLoad("viewport-auto-initial-scale.html"); |
682 | 686 |
683 FixedLayoutTestWebViewClient client; | 687 FixedLayoutTestWebViewClient client; |
684 client.m_screenInfo.deviceScaleFactor = 1; | 688 client.m_screenInfo.deviceScaleFactor = 1; |
685 int viewportWidth = 640; | 689 int viewportWidth = 640; |
686 int viewportHeight = 480; | 690 int viewportHeight = 480; |
687 | 691 |
688 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport-aut
o-initial-scale.html", true, 0, &client); | 692 FrameTestHelpers::WebViewHelper webViewHelper; |
689 m_webView->enableFixedLayoutMode(true); | 693 webViewHelper.initializeAndLoad(m_baseURL + "viewport-auto-initial-scale.htm
l", true, 0, &client); |
690 m_webView->settings()->setViewportEnabled(true); | 694 webViewHelper.webView()->enableFixedLayoutMode(true); |
691 m_webView->settings()->setWideViewportQuirkEnabled(true); | 695 webViewHelper.webView()->settings()->setViewportEnabled(true); |
692 m_webView->settings()->setUseWideViewport(false); | 696 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
693 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 697 webViewHelper.webView()->settings()->setUseWideViewport(false); |
| 698 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
694 | 699 |
695 // The page sets viewport width to 3000, but with UseWideViewport == false i
s must be ignored. | 700 // The page sets viewport width to 3000, but with UseWideViewport == false i
s must be ignored. |
696 EXPECT_EQ(viewportWidth, webViewImpl()->mainFrameImpl()->frameView()->conten
tsSize().width()); | 701 EXPECT_EQ(viewportWidth, webViewHelper.webViewImpl()->mainFrameImpl()->frame
View()->contentsSize().width()); |
697 EXPECT_EQ(viewportHeight, webViewImpl()->mainFrameImpl()->frameView()->conte
ntsSize().height()); | 702 EXPECT_EQ(viewportHeight, webViewHelper.webViewImpl()->mainFrameImpl()->fram
eView()->contentsSize().height()); |
698 } | 703 } |
699 | 704 |
700 TEST_F(WebFrameTest, NoWideViewportIgnoresPageViewportWidthButAccountsScale) | 705 TEST_F(WebFrameTest, NoWideViewportIgnoresPageViewportWidthButAccountsScale) |
701 { | 706 { |
702 registerMockedHttpURLLoad("viewport-wide-2x-initial-scale.html"); | 707 registerMockedHttpURLLoad("viewport-wide-2x-initial-scale.html"); |
703 | 708 |
704 FixedLayoutTestWebViewClient client; | 709 FixedLayoutTestWebViewClient client; |
705 client.m_screenInfo.deviceScaleFactor = 1; | 710 client.m_screenInfo.deviceScaleFactor = 1; |
706 int viewportWidth = 640; | 711 int viewportWidth = 640; |
707 int viewportHeight = 480; | 712 int viewportHeight = 480; |
708 | 713 |
709 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport-wid
e-2x-initial-scale.html", true, 0, &client); | 714 FrameTestHelpers::WebViewHelper webViewHelper; |
710 m_webView->enableFixedLayoutMode(true); | 715 webViewHelper.initializeAndLoad(m_baseURL + "viewport-wide-2x-initial-scale.
html", true, 0, &client); |
711 m_webView->settings()->setViewportEnabled(true); | 716 webViewHelper.webView()->enableFixedLayoutMode(true); |
712 m_webView->settings()->setWideViewportQuirkEnabled(true); | 717 webViewHelper.webView()->settings()->setViewportEnabled(true); |
713 m_webView->settings()->setUseWideViewport(false); | 718 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
714 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 719 webViewHelper.webView()->settings()->setUseWideViewport(false); |
| 720 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
715 | 721 |
716 // The page sets viewport width to 3000, but with UseWideViewport == false i
s must be ignored. | 722 // The page sets viewport width to 3000, but with UseWideViewport == false i
s must be ignored. |
717 // While the initial scale specified by the page must be accounted. | 723 // While the initial scale specified by the page must be accounted. |
718 EXPECT_EQ(viewportWidth / 2, webViewImpl()->mainFrameImpl()->frameView()->co
ntentsSize().width()); | 724 EXPECT_EQ(viewportWidth / 2, webViewHelper.webViewImpl()->mainFrameImpl()->f
rameView()->contentsSize().width()); |
719 EXPECT_EQ(viewportHeight / 2, webViewImpl()->mainFrameImpl()->frameView()->c
ontentsSize().height()); | 725 EXPECT_EQ(viewportHeight / 2, webViewHelper.webViewImpl()->mainFrameImpl()->
frameView()->contentsSize().height()); |
720 } | 726 } |
721 | 727 |
722 TEST_F(WebFrameTest, WideViewportSetsTo980WithoutViewportTag) | 728 TEST_F(WebFrameTest, WideViewportSetsTo980WithoutViewportTag) |
723 { | 729 { |
724 registerMockedHttpURLLoad("no_viewport_tag.html"); | 730 registerMockedHttpURLLoad("no_viewport_tag.html"); |
725 | 731 |
726 FixedLayoutTestWebViewClient client; | 732 FixedLayoutTestWebViewClient client; |
727 client.m_screenInfo.deviceScaleFactor = 1; | 733 client.m_screenInfo.deviceScaleFactor = 1; |
728 int viewportWidth = 640; | 734 int viewportWidth = 640; |
729 int viewportHeight = 480; | 735 int viewportHeight = 480; |
730 | 736 |
731 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "no_viewport_
tag.html", true, 0, &client); | 737 FrameTestHelpers::WebViewHelper webViewHelper; |
732 m_webView->enableFixedLayoutMode(true); | 738 webViewHelper.initializeAndLoad(m_baseURL + "no_viewport_tag.html", true, 0,
&client); |
733 m_webView->settings()->setWideViewportQuirkEnabled(true); | 739 webViewHelper.webView()->enableFixedLayoutMode(true); |
734 m_webView->settings()->setUseWideViewport(true); | 740 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
735 m_webView->settings()->setViewportEnabled(true); | 741 webViewHelper.webView()->settings()->setUseWideViewport(true); |
736 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 742 webViewHelper.webView()->settings()->setViewportEnabled(true); |
| 743 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
737 | 744 |
738 EXPECT_EQ(980, webViewImpl()->mainFrameImpl()->frameView()->contentsSize().w
idth()); | 745 EXPECT_EQ(980, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->co
ntentsSize().width()); |
739 EXPECT_EQ(980.0 / viewportWidth * viewportHeight, webViewImpl()->mainFrameIm
pl()->frameView()->contentsSize().height()); | 746 EXPECT_EQ(980.0 / viewportWidth * viewportHeight, webViewHelper.webViewImpl(
)->mainFrameImpl()->frameView()->contentsSize().height()); |
740 } | 747 } |
741 | 748 |
742 TEST_F(WebFrameTest, NoWideViewportAndHeightInMeta) | 749 TEST_F(WebFrameTest, NoWideViewportAndHeightInMeta) |
743 { | 750 { |
744 registerMockedHttpURLLoad("viewport-height-1000.html"); | 751 registerMockedHttpURLLoad("viewport-height-1000.html"); |
745 | 752 |
746 FixedLayoutTestWebViewClient client; | 753 FixedLayoutTestWebViewClient client; |
747 client.m_screenInfo.deviceScaleFactor = 1; | 754 client.m_screenInfo.deviceScaleFactor = 1; |
748 int viewportWidth = 640; | 755 int viewportWidth = 640; |
749 int viewportHeight = 480; | 756 int viewportHeight = 480; |
750 | 757 |
751 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport-hei
ght-1000.html", true, 0, &client); | 758 FrameTestHelpers::WebViewHelper webViewHelper; |
752 m_webView->enableFixedLayoutMode(true); | 759 webViewHelper.initializeAndLoad(m_baseURL + "viewport-height-1000.html", tru
e, 0, &client); |
753 m_webView->settings()->setWideViewportQuirkEnabled(true); | 760 webViewHelper.webView()->enableFixedLayoutMode(true); |
754 m_webView->settings()->setUseWideViewport(false); | 761 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
755 m_webView->settings()->setViewportEnabled(true); | 762 webViewHelper.webView()->settings()->setUseWideViewport(false); |
756 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 763 webViewHelper.webView()->settings()->setViewportEnabled(true); |
| 764 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
757 | 765 |
758 EXPECT_EQ(viewportWidth, webViewImpl()->mainFrameImpl()->frameView()->conten
tsSize().width()); | 766 EXPECT_EQ(viewportWidth, webViewHelper.webViewImpl()->mainFrameImpl()->frame
View()->contentsSize().width()); |
759 } | 767 } |
760 | 768 |
761 TEST_F(WebFrameTest, WideViewportSetsTo980WithAutoWidth) | 769 TEST_F(WebFrameTest, WideViewportSetsTo980WithAutoWidth) |
762 { | 770 { |
763 registerMockedHttpURLLoad("viewport-2x-initial-scale.html"); | 771 registerMockedHttpURLLoad("viewport-2x-initial-scale.html"); |
764 | 772 |
765 FixedLayoutTestWebViewClient client; | 773 FixedLayoutTestWebViewClient client; |
766 client.m_screenInfo.deviceScaleFactor = 1; | 774 client.m_screenInfo.deviceScaleFactor = 1; |
767 int viewportWidth = 640; | 775 int viewportWidth = 640; |
768 int viewportHeight = 480; | 776 int viewportHeight = 480; |
769 | 777 |
770 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport-2x-
initial-scale.html", true, 0, &client); | 778 FrameTestHelpers::WebViewHelper webViewHelper; |
771 m_webView->enableFixedLayoutMode(true); | 779 webViewHelper.initializeAndLoad(m_baseURL + "viewport-2x-initial-scale.html"
, true, 0, &client); |
772 m_webView->settings()->setWideViewportQuirkEnabled(true); | 780 webViewHelper.webView()->enableFixedLayoutMode(true); |
773 m_webView->settings()->setUseWideViewport(true); | 781 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
774 m_webView->settings()->setViewportEnabled(true); | 782 webViewHelper.webView()->settings()->setUseWideViewport(true); |
775 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 783 webViewHelper.webView()->settings()->setViewportEnabled(true); |
| 784 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
776 | 785 |
777 EXPECT_EQ(980, webViewImpl()->mainFrameImpl()->frameView()->contentsSize().w
idth()); | 786 EXPECT_EQ(980, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->co
ntentsSize().width()); |
778 EXPECT_EQ(980.0 / viewportWidth * viewportHeight, webViewImpl()->mainFrameIm
pl()->frameView()->contentsSize().height()); | 787 EXPECT_EQ(980.0 / viewportWidth * viewportHeight, webViewHelper.webViewImpl(
)->mainFrameImpl()->frameView()->contentsSize().height()); |
779 } | 788 } |
780 | 789 |
781 TEST_F(WebFrameTest, PageViewportInitialScaleOverridesLoadWithOverviewMode) | 790 TEST_F(WebFrameTest, PageViewportInitialScaleOverridesLoadWithOverviewMode) |
782 { | 791 { |
783 registerMockedHttpURLLoad("viewport-wide-2x-initial-scale.html"); | 792 registerMockedHttpURLLoad("viewport-wide-2x-initial-scale.html"); |
784 | 793 |
785 FixedLayoutTestWebViewClient client; | 794 FixedLayoutTestWebViewClient client; |
786 client.m_screenInfo.deviceScaleFactor = 1; | 795 client.m_screenInfo.deviceScaleFactor = 1; |
787 int viewportWidth = 640; | 796 int viewportWidth = 640; |
788 int viewportHeight = 480; | 797 int viewportHeight = 480; |
789 | 798 |
790 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport-wid
e-2x-initial-scale.html", true, 0, &client); | 799 FrameTestHelpers::WebViewHelper webViewHelper; |
791 m_webView->enableFixedLayoutMode(true); | 800 webViewHelper.initializeAndLoad(m_baseURL + "viewport-wide-2x-initial-scale.
html", true, 0, &client); |
792 m_webView->settings()->setViewportEnabled(true); | 801 webViewHelper.webView()->enableFixedLayoutMode(true); |
793 m_webView->settings()->setLoadWithOverviewMode(false); | 802 webViewHelper.webView()->settings()->setViewportEnabled(true); |
794 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 803 webViewHelper.webView()->settings()->setLoadWithOverviewMode(false); |
| 804 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
795 | 805 |
796 // The page must be displayed at 200% zoom, as specified in its viewport met
a tag. | 806 // The page must be displayed at 200% zoom, as specified in its viewport met
a tag. |
797 EXPECT_EQ(2.0f, m_webView->pageScaleFactor()); | 807 EXPECT_EQ(2.0f, webViewHelper.webView()->pageScaleFactor()); |
798 } | 808 } |
799 | 809 |
800 TEST_F(WebFrameTest, setInitialPageScaleFactorPermanently) | 810 TEST_F(WebFrameTest, setInitialPageScaleFactorPermanently) |
801 { | 811 { |
802 UseMockScrollbarSettings mockScrollbarSettings; | 812 UseMockScrollbarSettings mockScrollbarSettings; |
803 | 813 |
804 registerMockedHttpURLLoad("fixed_layout.html"); | 814 registerMockedHttpURLLoad("fixed_layout.html"); |
805 | 815 |
806 FixedLayoutTestWebViewClient client; | 816 FixedLayoutTestWebViewClient client; |
807 client.m_screenInfo.deviceScaleFactor = 1; | 817 client.m_screenInfo.deviceScaleFactor = 1; |
808 float enforcedPageScaleFactor = 2.0f; | 818 float enforcedPageScaleFactor = 2.0f; |
809 | 819 |
810 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html", true, 0, &client); | 820 FrameTestHelpers::WebViewHelper webViewHelper; |
811 m_webView->settings()->setWideViewportQuirkEnabled(true); | 821 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html", true, 0, &c
lient); |
812 m_webView->settings()->setLoadWithOverviewMode(false); | 822 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
813 m_webView->setInitialPageScaleOverride(enforcedPageScaleFactor); | 823 webViewHelper.webView()->settings()->setLoadWithOverviewMode(false); |
814 m_webView->enableFixedLayoutMode(true); | 824 webViewHelper.webView()->setInitialPageScaleOverride(enforcedPageScaleFactor
); |
815 m_webView->settings()->setViewportEnabled(true); | 825 webViewHelper.webView()->enableFixedLayoutMode(true); |
816 m_webView->layout(); | 826 webViewHelper.webView()->settings()->setViewportEnabled(true); |
| 827 webViewHelper.webView()->layout(); |
817 | 828 |
818 EXPECT_EQ(enforcedPageScaleFactor, m_webView->pageScaleFactor()); | 829 EXPECT_EQ(enforcedPageScaleFactor, webViewHelper.webView()->pageScaleFactor(
)); |
819 | 830 |
820 int viewportWidth = 640; | 831 int viewportWidth = 640; |
821 int viewportHeight = 480; | 832 int viewportHeight = 480; |
822 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 833 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
823 m_webView->layout(); | 834 webViewHelper.webView()->layout(); |
824 | 835 |
825 EXPECT_EQ(enforcedPageScaleFactor, m_webView->pageScaleFactor()); | 836 EXPECT_EQ(enforcedPageScaleFactor, webViewHelper.webView()->pageScaleFactor(
)); |
826 | 837 |
827 m_webView->setInitialPageScaleOverride(-1); | 838 webViewHelper.webView()->setInitialPageScaleOverride(-1); |
828 m_webView->layout(); | 839 webViewHelper.webView()->layout(); |
829 EXPECT_EQ(1.0, m_webView->pageScaleFactor()); | 840 EXPECT_EQ(1.0, webViewHelper.webView()->pageScaleFactor()); |
830 } | 841 } |
831 | 842 |
832 TEST_F(WebFrameTest, PermanentInitialPageScaleFactorOverridesLoadWithOverviewMod
e) | 843 TEST_F(WebFrameTest, PermanentInitialPageScaleFactorOverridesLoadWithOverviewMod
e) |
833 { | 844 { |
834 registerMockedHttpURLLoad("viewport-auto-initial-scale.html"); | 845 registerMockedHttpURLLoad("viewport-auto-initial-scale.html"); |
835 | 846 |
836 FixedLayoutTestWebViewClient client; | 847 FixedLayoutTestWebViewClient client; |
837 client.m_screenInfo.deviceScaleFactor = 1; | 848 client.m_screenInfo.deviceScaleFactor = 1; |
838 int viewportWidth = 640; | 849 int viewportWidth = 640; |
839 int viewportHeight = 480; | 850 int viewportHeight = 480; |
840 float enforcedPageScalePactor = 0.5f; | 851 float enforcedPageScalePactor = 0.5f; |
841 | 852 |
842 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport-aut
o-initial-scale.html", true, 0, &client); | 853 FrameTestHelpers::WebViewHelper webViewHelper; |
843 m_webView->enableFixedLayoutMode(true); | 854 webViewHelper.initializeAndLoad(m_baseURL + "viewport-auto-initial-scale.htm
l", true, 0, &client); |
844 m_webView->settings()->setViewportEnabled(true); | 855 webViewHelper.webView()->enableFixedLayoutMode(true); |
845 m_webView->settings()->setLoadWithOverviewMode(false); | 856 webViewHelper.webView()->settings()->setViewportEnabled(true); |
846 m_webView->setInitialPageScaleOverride(enforcedPageScalePactor); | 857 webViewHelper.webView()->settings()->setLoadWithOverviewMode(false); |
847 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 858 webViewHelper.webView()->setInitialPageScaleOverride(enforcedPageScalePactor
); |
| 859 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
848 | 860 |
849 EXPECT_EQ(enforcedPageScalePactor, m_webView->pageScaleFactor()); | 861 EXPECT_EQ(enforcedPageScalePactor, webViewHelper.webView()->pageScaleFactor(
)); |
850 } | 862 } |
851 | 863 |
852 TEST_F(WebFrameTest, PermanentInitialPageScaleFactorOverridesPageViewportInitial
Scale) | 864 TEST_F(WebFrameTest, PermanentInitialPageScaleFactorOverridesPageViewportInitial
Scale) |
853 { | 865 { |
854 registerMockedHttpURLLoad("viewport-wide-2x-initial-scale.html"); | 866 registerMockedHttpURLLoad("viewport-wide-2x-initial-scale.html"); |
855 | 867 |
856 FixedLayoutTestWebViewClient client; | 868 FixedLayoutTestWebViewClient client; |
857 client.m_screenInfo.deviceScaleFactor = 1; | 869 client.m_screenInfo.deviceScaleFactor = 1; |
858 int viewportWidth = 640; | 870 int viewportWidth = 640; |
859 int viewportHeight = 480; | 871 int viewportHeight = 480; |
860 float enforcedPageScalePactor = 0.5f; | 872 float enforcedPageScalePactor = 0.5f; |
861 | 873 |
862 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport-wid
e-2x-initial-scale.html", true, 0, &client); | 874 FrameTestHelpers::WebViewHelper webViewHelper; |
863 m_webView->enableFixedLayoutMode(true); | 875 webViewHelper.initializeAndLoad(m_baseURL + "viewport-wide-2x-initial-scale.
html", true, 0, &client); |
864 m_webView->settings()->setViewportEnabled(true); | 876 webViewHelper.webView()->enableFixedLayoutMode(true); |
865 m_webView->setInitialPageScaleOverride(enforcedPageScalePactor); | 877 webViewHelper.webView()->settings()->setViewportEnabled(true); |
866 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 878 webViewHelper.webView()->setInitialPageScaleOverride(enforcedPageScalePactor
); |
| 879 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
867 | 880 |
868 EXPECT_EQ(enforcedPageScalePactor, m_webView->pageScaleFactor()); | 881 EXPECT_EQ(enforcedPageScalePactor, webViewHelper.webView()->pageScaleFactor(
)); |
869 } | 882 } |
870 | 883 |
871 TEST_F(WebFrameTest, WideViewportInitialScaleDoesNotExpandFixedLayoutWidth) | 884 TEST_F(WebFrameTest, WideViewportInitialScaleDoesNotExpandFixedLayoutWidth) |
872 { | 885 { |
873 registerMockedHttpURLLoad("viewport-device-0.5x-initial-scale.html"); | 886 registerMockedHttpURLLoad("viewport-device-0.5x-initial-scale.html"); |
874 | 887 |
875 FixedLayoutTestWebViewClient client; | 888 FixedLayoutTestWebViewClient client; |
876 client.m_screenInfo.deviceScaleFactor = 1; | 889 client.m_screenInfo.deviceScaleFactor = 1; |
877 int viewportWidth = 640; | 890 int viewportWidth = 640; |
878 int viewportHeight = 480; | 891 int viewportHeight = 480; |
879 | 892 |
880 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport-dev
ice-0.5x-initial-scale.html", true, 0, &client); | 893 FrameTestHelpers::WebViewHelper webViewHelper; |
881 m_webView->enableFixedLayoutMode(true); | 894 webViewHelper.initializeAndLoad(m_baseURL + "viewport-device-0.5x-initial-sc
ale.html", true, 0, &client); |
882 m_webView->settings()->setViewportEnabled(true); | 895 webViewHelper.webView()->enableFixedLayoutMode(true); |
883 m_webView->settings()->setWideViewportQuirkEnabled(true); | 896 webViewHelper.webView()->settings()->setViewportEnabled(true); |
884 m_webView->settings()->setUseWideViewport(true); | 897 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
885 m_webView->settings()->setViewportMetaLayoutSizeQuirk(true); | 898 webViewHelper.webView()->settings()->setUseWideViewport(true); |
886 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 899 webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); |
| 900 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
887 | 901 |
888 WebViewImpl* webViewImpl = static_cast<WebViewImpl*>(m_webView); | 902 EXPECT_EQ(viewportWidth, webViewHelper.webViewImpl()->mainFrameImpl()->frame
View()->fixedLayoutSize().width()); |
889 EXPECT_EQ(viewportWidth, webViewImpl->mainFrameImpl()->frameView()->fixedLay
outSize().width()); | |
890 } | 903 } |
891 | 904 |
892 TEST_F(WebFrameTest, ZeroValuesQuirk) | 905 TEST_F(WebFrameTest, ZeroValuesQuirk) |
893 { | 906 { |
894 registerMockedHttpURLLoad("viewport-zero-values.html"); | 907 registerMockedHttpURLLoad("viewport-zero-values.html"); |
895 | 908 |
896 FixedLayoutTestWebViewClient client; | 909 FixedLayoutTestWebViewClient client; |
897 client.m_screenInfo.deviceScaleFactor = 1; | 910 client.m_screenInfo.deviceScaleFactor = 1; |
898 int viewportWidth = 640; | 911 int viewportWidth = 640; |
899 int viewportHeight = 480; | 912 int viewportHeight = 480; |
900 | 913 |
901 m_webView = FrameTestHelpers::createWebView(true, 0, &client); | 914 FrameTestHelpers::WebViewHelper webViewHelper; |
902 m_webView->enableFixedLayoutMode(true); | 915 webViewHelper.initialize(true, 0, &client); |
903 m_webView->settings()->setViewportEnabled(true); | 916 webViewHelper.webView()->enableFixedLayoutMode(true); |
904 m_webView->settings()->setViewportMetaZeroValuesQuirk(true); | 917 webViewHelper.webView()->settings()->setViewportEnabled(true); |
905 m_webView->settings()->setWideViewportQuirkEnabled(true); | 918 webViewHelper.webView()->settings()->setViewportMetaZeroValuesQuirk(true); |
906 FrameTestHelpers::loadFrame(m_webView->mainFrame(), m_baseURL + "viewport-ze
ro-values.html"); | 919 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
| 920 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "viewport-zero-values.html"); |
907 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 921 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
908 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 922 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
909 | 923 |
910 WebViewImpl* webViewImpl = static_cast<WebViewImpl*>(m_webView); | 924 WebViewImpl* webViewImpl = static_cast<WebViewImpl*>(webViewHelper.webView()
); |
911 EXPECT_EQ(viewportWidth, webViewImpl->mainFrameImpl()->frameView()->fixedLay
outSize().width()); | 925 EXPECT_EQ(viewportWidth, webViewImpl->mainFrameImpl()->frameView()->fixedLay
outSize().width()); |
912 EXPECT_EQ(1.0f, m_webView->pageScaleFactor()); | 926 EXPECT_EQ(1.0f, webViewHelper.webView()->pageScaleFactor()); |
913 | 927 |
914 m_webView->settings()->setUseWideViewport(true); | 928 webViewHelper.webView()->settings()->setUseWideViewport(true); |
915 m_webView->layout(); | 929 webViewHelper.webView()->layout(); |
916 EXPECT_EQ(viewportWidth, webViewImpl->mainFrameImpl()->frameView()->fixedLay
outSize().width()); | 930 EXPECT_EQ(viewportWidth, webViewImpl->mainFrameImpl()->frameView()->fixedLay
outSize().width()); |
917 EXPECT_EQ(1.0f, m_webView->pageScaleFactor()); | 931 EXPECT_EQ(1.0f, webViewHelper.webView()->pageScaleFactor()); |
918 } | 932 } |
919 | 933 |
920 TEST_F(WebFrameTest, ScaleFactorShouldNotOscillate) | 934 TEST_F(WebFrameTest, ScaleFactorShouldNotOscillate) |
921 { | 935 { |
922 registerMockedHttpURLLoad("scale_oscillate.html"); | 936 registerMockedHttpURLLoad("scale_oscillate.html"); |
923 | 937 |
924 FixedLayoutTestWebViewClient client; | 938 FixedLayoutTestWebViewClient client; |
925 client.m_screenInfo.deviceScaleFactor = static_cast<float>(1.325); | 939 client.m_screenInfo.deviceScaleFactor = static_cast<float>(1.325); |
926 int viewportWidth = 800; | 940 int viewportWidth = 800; |
927 int viewportHeight = 1057; | 941 int viewportHeight = 1057; |
928 | 942 |
929 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "scale_oscill
ate.html", true, 0, &client); | 943 FrameTestHelpers::WebViewHelper webViewHelper; |
930 m_webView->enableFixedLayoutMode(true); | 944 webViewHelper.initializeAndLoad(m_baseURL + "scale_oscillate.html", true, 0,
&client); |
931 m_webView->settings()->setViewportEnabled(true); | 945 webViewHelper.webView()->enableFixedLayoutMode(true); |
932 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 946 webViewHelper.webView()->settings()->setViewportEnabled(true); |
933 m_webView->layout(); | 947 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 948 webViewHelper.webView()->layout(); |
934 } | 949 } |
935 | 950 |
936 TEST_F(WebFrameTest, setPageScaleFactorDoesNotLayout) | 951 TEST_F(WebFrameTest, setPageScaleFactorDoesNotLayout) |
937 { | 952 { |
938 registerMockedHttpURLLoad("fixed_layout.html"); | 953 registerMockedHttpURLLoad("fixed_layout.html"); |
939 | 954 |
940 FixedLayoutTestWebViewClient client; | 955 FixedLayoutTestWebViewClient client; |
941 client.m_screenInfo.deviceScaleFactor = 1; | 956 client.m_screenInfo.deviceScaleFactor = 1; |
942 // Small viewport to ensure there are always scrollbars. | 957 // Small viewport to ensure there are always scrollbars. |
943 int viewportWidth = 64; | 958 int viewportWidth = 64; |
944 int viewportHeight = 48; | 959 int viewportHeight = 48; |
945 | 960 |
946 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html", true, 0, &client); | 961 FrameTestHelpers::WebViewHelper webViewHelper; |
947 m_webView->enableFixedLayoutMode(true); | 962 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html", true, 0, &c
lient); |
948 m_webView->settings()->setViewportEnabled(true); | 963 webViewHelper.webView()->enableFixedLayoutMode(true); |
949 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 964 webViewHelper.webView()->settings()->setViewportEnabled(true); |
950 m_webView->layout(); | 965 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 966 webViewHelper.webView()->layout(); |
951 | 967 |
952 int prevLayoutCount = webViewImpl()->mainFrameImpl()->frameView()->layoutCou
nt(); | 968 int prevLayoutCount = webViewHelper.webViewImpl()->mainFrameImpl()->frameVie
w()->layoutCount(); |
953 webViewImpl()->setPageScaleFactor(3, WebPoint()); | 969 webViewHelper.webViewImpl()->setPageScaleFactor(3, WebPoint()); |
954 EXPECT_FALSE(webViewImpl()->mainFrameImpl()->frameView()->needsLayout()); | 970 EXPECT_FALSE(webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->need
sLayout()); |
955 EXPECT_EQ(prevLayoutCount, webViewImpl()->mainFrameImpl()->frameView()->layo
utCount()); | 971 EXPECT_EQ(prevLayoutCount, webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView()->layoutCount()); |
956 } | 972 } |
957 | 973 |
958 TEST_F(WebFrameTest, setPageScaleFactorWithOverlayScrollbarsDoesNotLayout) | 974 TEST_F(WebFrameTest, setPageScaleFactorWithOverlayScrollbarsDoesNotLayout) |
959 { | 975 { |
960 UseMockScrollbarSettings mockScrollbarSettings; | 976 UseMockScrollbarSettings mockScrollbarSettings; |
961 | 977 |
962 registerMockedHttpURLLoad("fixed_layout.html"); | 978 registerMockedHttpURLLoad("fixed_layout.html"); |
963 | 979 |
964 FixedLayoutTestWebViewClient client; | 980 FixedLayoutTestWebViewClient client; |
965 client.m_screenInfo.deviceScaleFactor = 1; | 981 client.m_screenInfo.deviceScaleFactor = 1; |
966 int viewportWidth = 640; | 982 int viewportWidth = 640; |
967 int viewportHeight = 480; | 983 int viewportHeight = 480; |
968 | 984 |
969 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html", true, 0, &client); | 985 FrameTestHelpers::WebViewHelper webViewHelper; |
970 m_webView->enableFixedLayoutMode(true); | 986 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html", true, 0, &c
lient); |
971 m_webView->settings()->setViewportEnabled(true); | 987 webViewHelper.webView()->enableFixedLayoutMode(true); |
972 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 988 webViewHelper.webView()->settings()->setViewportEnabled(true); |
973 m_webView->layout(); | 989 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 990 webViewHelper.webView()->layout(); |
974 | 991 |
975 int prevLayoutCount = webViewImpl()->mainFrameImpl()->frameView()->layoutCou
nt(); | 992 int prevLayoutCount = webViewHelper.webViewImpl()->mainFrameImpl()->frameVie
w()->layoutCount(); |
976 webViewImpl()->setPageScaleFactor(30, WebPoint()); | 993 webViewHelper.webViewImpl()->setPageScaleFactor(30, WebPoint()); |
977 EXPECT_FALSE(webViewImpl()->mainFrameImpl()->frameView()->needsLayout()); | 994 EXPECT_FALSE(webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->need
sLayout()); |
978 EXPECT_EQ(prevLayoutCount, webViewImpl()->mainFrameImpl()->frameView()->layo
utCount()); | 995 EXPECT_EQ(prevLayoutCount, webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView()->layoutCount()); |
979 | 996 |
980 } | 997 } |
981 | 998 |
982 TEST_F(WebFrameTest, setPageScaleFactorBeforeFrameHasView) | 999 TEST_F(WebFrameTest, setPageScaleFactorBeforeFrameHasView) |
983 { | 1000 { |
984 registerMockedHttpURLLoad("fixed_layout.html"); | 1001 registerMockedHttpURLLoad("fixed_layout.html"); |
985 | 1002 |
986 float pageScaleFactor = 3; | 1003 float pageScaleFactor = 3; |
987 m_webView = FrameTestHelpers::createWebViewAndLoad("about:html", true, 0, 0)
; | 1004 FrameTestHelpers::WebViewHelper webViewHelper; |
988 m_webView->setPageScaleFactor(pageScaleFactor, WebPoint()); | 1005 webViewHelper.initializeAndLoad("about:html", true, 0, 0); |
| 1006 webViewHelper.webView()->setPageScaleFactor(pageScaleFactor, WebPoint()); |
989 | 1007 |
990 FrameTestHelpers::loadFrame(m_webView->mainFrame(), m_baseURL + "fixed_layou
t.html"); | 1008 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "fixed_layout.html"); |
991 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 1009 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
992 WebCore::FrameView* view = webViewImpl()->mainFrameImpl()->frameView(); | 1010 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); |
993 EXPECT_EQ(pageScaleFactor, view->visibleContentScaleFactor()); | 1011 EXPECT_EQ(pageScaleFactor, view->visibleContentScaleFactor()); |
994 } | 1012 } |
995 | 1013 |
996 TEST_F(WebFrameTest, pageScaleFactorWrittenToHistoryItem) | 1014 TEST_F(WebFrameTest, pageScaleFactorWrittenToHistoryItem) |
997 { | 1015 { |
998 registerMockedHttpURLLoad("fixed_layout.html"); | 1016 registerMockedHttpURLLoad("fixed_layout.html"); |
999 | 1017 |
1000 FixedLayoutTestWebViewClient client; | 1018 FixedLayoutTestWebViewClient client; |
1001 client.m_screenInfo.deviceScaleFactor = 1; | 1019 client.m_screenInfo.deviceScaleFactor = 1; |
1002 int viewportWidth = 640; | 1020 int viewportWidth = 640; |
1003 int viewportHeight = 480; | 1021 int viewportHeight = 480; |
1004 | 1022 |
1005 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html", true, 0, &client); | 1023 FrameTestHelpers::WebViewHelper webViewHelper; |
1006 m_webView->enableFixedLayoutMode(true); | 1024 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html", true, 0, &c
lient); |
1007 m_webView->settings()->setViewportEnabled(true); | 1025 webViewHelper.webView()->enableFixedLayoutMode(true); |
1008 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1026 webViewHelper.webView()->settings()->setViewportEnabled(true); |
1009 m_webView->layout(); | 1027 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 1028 webViewHelper.webView()->layout(); |
1010 | 1029 |
1011 m_webView->setPageScaleFactor(3, WebPoint()); | 1030 webViewHelper.webView()->setPageScaleFactor(3, WebPoint()); |
1012 webViewImpl()->page()->mainFrame()->loader()->history()->saveDocumentAndScro
llState(); | 1031 webViewHelper.webViewImpl()->page()->mainFrame()->loader()->history()->saveD
ocumentAndScrollState(); |
1013 m_webView->setPageScaleFactor(1, WebPoint()); | 1032 webViewHelper.webView()->setPageScaleFactor(1, WebPoint()); |
1014 webViewImpl()->page()->mainFrame()->loader()->history()->restoreScrollPositi
onAndViewState(); | 1033 webViewHelper.webViewImpl()->page()->mainFrame()->loader()->history()->resto
reScrollPositionAndViewState(); |
1015 EXPECT_EQ(3, m_webView->pageScaleFactor()); | 1034 EXPECT_EQ(3, webViewHelper.webView()->pageScaleFactor()); |
1016 } | 1035 } |
1017 | 1036 |
1018 TEST_F(WebFrameTest, pageScaleFactorShrinksViewport) | 1037 TEST_F(WebFrameTest, pageScaleFactorShrinksViewport) |
1019 { | 1038 { |
1020 registerMockedHttpURLLoad("large-div.html"); | 1039 registerMockedHttpURLLoad("large-div.html"); |
1021 | 1040 |
1022 FixedLayoutTestWebViewClient client; | 1041 FixedLayoutTestWebViewClient client; |
1023 client.m_screenInfo.deviceScaleFactor = 1; | 1042 client.m_screenInfo.deviceScaleFactor = 1; |
1024 // Small viewport to ensure there are always scrollbars. | 1043 // Small viewport to ensure there are always scrollbars. |
1025 int viewportWidth = 64; | 1044 int viewportWidth = 64; |
1026 int viewportHeight = 48; | 1045 int viewportHeight = 48; |
1027 | 1046 |
1028 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "large-div.ht
ml", true, 0, &client); | 1047 FrameTestHelpers::WebViewHelper webViewHelper; |
1029 m_webView->enableFixedLayoutMode(true); | 1048 webViewHelper.initializeAndLoad(m_baseURL + "large-div.html", true, 0, &clie
nt); |
1030 m_webView->settings()->setViewportEnabled(true); | 1049 webViewHelper.webView()->enableFixedLayoutMode(true); |
1031 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1050 webViewHelper.webView()->settings()->setViewportEnabled(true); |
1032 m_webView->layout(); | 1051 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 1052 webViewHelper.webView()->layout(); |
1033 | 1053 |
1034 WebCore::FrameView* view = webViewImpl()->mainFrameImpl()->frameView(); | 1054 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); |
1035 int viewportWidthMinusScrollbar = viewportWidth - (view->verticalScrollbar()
->isOverlayScrollbar() ? 0 : 15); | 1055 int viewportWidthMinusScrollbar = viewportWidth - (view->verticalScrollbar()
->isOverlayScrollbar() ? 0 : 15); |
1036 int viewportHeightMinusScrollbar = viewportHeight - (view->horizontalScrollb
ar()->isOverlayScrollbar() ? 0 : 15); | 1056 int viewportHeightMinusScrollbar = viewportHeight - (view->horizontalScrollb
ar()->isOverlayScrollbar() ? 0 : 15); |
1037 | 1057 |
1038 m_webView->setPageScaleFactor(2, WebPoint()); | 1058 webViewHelper.webView()->setPageScaleFactor(2, WebPoint()); |
1039 | 1059 |
1040 WebCore::IntSize unscaledSize = view->unscaledVisibleContentSize(WebCore::Sc
rollableArea::IncludeScrollbars); | 1060 WebCore::IntSize unscaledSize = view->unscaledVisibleContentSize(WebCore::Sc
rollableArea::IncludeScrollbars); |
1041 EXPECT_EQ(viewportWidth, unscaledSize.width()); | 1061 EXPECT_EQ(viewportWidth, unscaledSize.width()); |
1042 EXPECT_EQ(viewportHeight, unscaledSize.height()); | 1062 EXPECT_EQ(viewportHeight, unscaledSize.height()); |
1043 | 1063 |
1044 WebCore::IntSize unscaledSizeMinusScrollbar = view->unscaledVisibleContentSi
ze(WebCore::ScrollableArea::ExcludeScrollbars); | 1064 WebCore::IntSize unscaledSizeMinusScrollbar = view->unscaledVisibleContentSi
ze(WebCore::ScrollableArea::ExcludeScrollbars); |
1045 EXPECT_EQ(viewportWidthMinusScrollbar, unscaledSizeMinusScrollbar.width()); | 1065 EXPECT_EQ(viewportWidthMinusScrollbar, unscaledSizeMinusScrollbar.width()); |
1046 EXPECT_EQ(viewportHeightMinusScrollbar, unscaledSizeMinusScrollbar.height())
; | 1066 EXPECT_EQ(viewportHeightMinusScrollbar, unscaledSizeMinusScrollbar.height())
; |
1047 | 1067 |
1048 WebCore::IntSize scaledSize = view->visibleContentRect().size(); | 1068 WebCore::IntSize scaledSize = view->visibleContentRect().size(); |
1049 EXPECT_EQ(ceil(viewportWidthMinusScrollbar / 2.0), scaledSize.width()); | 1069 EXPECT_EQ(ceil(viewportWidthMinusScrollbar / 2.0), scaledSize.width()); |
1050 EXPECT_EQ(ceil(viewportHeightMinusScrollbar / 2.0), scaledSize.height()); | 1070 EXPECT_EQ(ceil(viewportHeightMinusScrollbar / 2.0), scaledSize.height()); |
1051 } | 1071 } |
1052 | 1072 |
1053 TEST_F(WebFrameTest, pageScaleFactorDoesNotApplyCssTransform) | 1073 TEST_F(WebFrameTest, pageScaleFactorDoesNotApplyCssTransform) |
1054 { | 1074 { |
1055 registerMockedHttpURLLoad("fixed_layout.html"); | 1075 registerMockedHttpURLLoad("fixed_layout.html"); |
1056 | 1076 |
1057 FixedLayoutTestWebViewClient client; | 1077 FixedLayoutTestWebViewClient client; |
1058 client.m_screenInfo.deviceScaleFactor = 1; | 1078 client.m_screenInfo.deviceScaleFactor = 1; |
1059 int viewportWidth = 640; | 1079 int viewportWidth = 640; |
1060 int viewportHeight = 480; | 1080 int viewportHeight = 480; |
1061 | 1081 |
1062 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html", true, 0, &client); | 1082 FrameTestHelpers::WebViewHelper webViewHelper; |
1063 m_webView->enableFixedLayoutMode(true); | 1083 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html", true, 0, &c
lient); |
1064 m_webView->settings()->setViewportEnabled(true); | 1084 webViewHelper.webView()->enableFixedLayoutMode(true); |
1065 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1085 webViewHelper.webView()->settings()->setViewportEnabled(true); |
1066 m_webView->layout(); | 1086 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 1087 webViewHelper.webView()->layout(); |
1067 | 1088 |
1068 m_webView->setPageScaleFactor(2, WebPoint()); | 1089 webViewHelper.webView()->setPageScaleFactor(2, WebPoint()); |
1069 | 1090 |
1070 EXPECT_EQ(980, webViewImpl()->page()->mainFrame()->contentRenderer()->unscal
edDocumentRect().width()); | 1091 EXPECT_EQ(980, webViewHelper.webViewImpl()->page()->mainFrame()->contentRend
erer()->unscaledDocumentRect().width()); |
1071 EXPECT_EQ(980, webViewImpl()->mainFrameImpl()->frameView()->contentsSize().w
idth()); | 1092 EXPECT_EQ(980, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->co
ntentsSize().width()); |
1072 } | 1093 } |
1073 | 1094 |
1074 TEST_F(WebFrameTest, targetDensityDpiHigh) | 1095 TEST_F(WebFrameTest, targetDensityDpiHigh) |
1075 { | 1096 { |
1076 UseMockScrollbarSettings mockScrollbarSettings; | 1097 UseMockScrollbarSettings mockScrollbarSettings; |
1077 registerMockedHttpURLLoad("viewport-target-densitydpi-high.html"); | 1098 registerMockedHttpURLLoad("viewport-target-densitydpi-high.html"); |
1078 | 1099 |
1079 FixedLayoutTestWebViewClient client; | 1100 FixedLayoutTestWebViewClient client; |
1080 // high-dpi = 240 | 1101 // high-dpi = 240 |
1081 float targetDpi = 240.0f; | 1102 float targetDpi = 240.0f; |
1082 float deviceScaleFactors[] = { 1.0f, 4.0f / 3.0f, 2.0f }; | 1103 float deviceScaleFactors[] = { 1.0f, 4.0f / 3.0f, 2.0f }; |
1083 int viewportWidth = 640; | 1104 int viewportWidth = 640; |
1084 int viewportHeight = 480; | 1105 int viewportHeight = 480; |
1085 | 1106 |
1086 for (size_t i = 0; i < ARRAY_SIZE(deviceScaleFactors); ++i) { | 1107 for (size_t i = 0; i < ARRAY_SIZE(deviceScaleFactors); ++i) { |
1087 float deviceScaleFactor = deviceScaleFactors[i]; | 1108 float deviceScaleFactor = deviceScaleFactors[i]; |
1088 float deviceDpi = deviceScaleFactor * 160.0f; | 1109 float deviceDpi = deviceScaleFactor * 160.0f; |
1089 client.m_screenInfo.deviceScaleFactor = deviceScaleFactor; | 1110 client.m_screenInfo.deviceScaleFactor = deviceScaleFactor; |
1090 | 1111 |
1091 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport
-target-densitydpi-high.html", true, 0, &client); | 1112 FrameTestHelpers::WebViewHelper webViewHelper; |
1092 m_webView->enableFixedLayoutMode(true); | 1113 webViewHelper.initializeAndLoad(m_baseURL + "viewport-target-densitydpi-high
.html", true, 0, &client); |
1093 m_webView->settings()->setViewportEnabled(true); | 1114 webViewHelper.webView()->enableFixedLayoutMode(true); |
1094 m_webView->settings()->setSupportDeprecatedTargetDensityDPI(true); | 1115 webViewHelper.webView()->settings()->setViewportEnabled(true); |
1095 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1116 webViewHelper.webView()->settings()->setSupportDeprecatedTargetDensityDP
I(true); |
| 1117 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1096 | 1118 |
1097 // We need to account for the fact that logical pixels are unconditional
ly multiplied by deviceScaleFactor to produce | 1119 // We need to account for the fact that logical pixels are unconditional
ly multiplied by deviceScaleFactor to produce |
1098 // physical pixels. | 1120 // physical pixels. |
1099 float densityDpiScaleRatio = deviceScaleFactor * targetDpi / deviceDpi; | 1121 float densityDpiScaleRatio = deviceScaleFactor * targetDpi / deviceDpi; |
1100 EXPECT_NEAR(viewportWidth * densityDpiScaleRatio, m_webView->fixedLayout
Size().width, 1.0f); | 1122 EXPECT_NEAR(viewportWidth * densityDpiScaleRatio, webViewHelper.webView(
)->fixedLayoutSize().width, 1.0f); |
1101 EXPECT_NEAR(viewportHeight * densityDpiScaleRatio, m_webView->fixedLayou
tSize().height, 1.0f); | 1123 EXPECT_NEAR(viewportHeight * densityDpiScaleRatio, webViewHelper.webView
()->fixedLayoutSize().height, 1.0f); |
1102 EXPECT_NEAR(1.0f / densityDpiScaleRatio, m_webView->pageScaleFactor(), 0
.01f); | 1124 EXPECT_NEAR(1.0f / densityDpiScaleRatio, webViewHelper.webView()->pageSc
aleFactor(), 0.01f); |
1103 | |
1104 m_webView->close(); | |
1105 m_webView = 0; | |
1106 } | 1125 } |
1107 } | 1126 } |
1108 | 1127 |
1109 TEST_F(WebFrameTest, targetDensityDpiDevice) | 1128 TEST_F(WebFrameTest, targetDensityDpiDevice) |
1110 { | 1129 { |
1111 UseMockScrollbarSettings mockScrollbarSettings; | 1130 UseMockScrollbarSettings mockScrollbarSettings; |
1112 registerMockedHttpURLLoad("viewport-target-densitydpi-device.html"); | 1131 registerMockedHttpURLLoad("viewport-target-densitydpi-device.html"); |
1113 | 1132 |
1114 float deviceScaleFactors[] = { 1.0f, 4.0f / 3.0f, 2.0f }; | 1133 float deviceScaleFactors[] = { 1.0f, 4.0f / 3.0f, 2.0f }; |
1115 | 1134 |
1116 FixedLayoutTestWebViewClient client; | 1135 FixedLayoutTestWebViewClient client; |
1117 int viewportWidth = 640; | 1136 int viewportWidth = 640; |
1118 int viewportHeight = 480; | 1137 int viewportHeight = 480; |
1119 | 1138 |
1120 for (size_t i = 0; i < ARRAY_SIZE(deviceScaleFactors); ++i) { | 1139 for (size_t i = 0; i < ARRAY_SIZE(deviceScaleFactors); ++i) { |
1121 client.m_screenInfo.deviceScaleFactor = deviceScaleFactors[i]; | 1140 client.m_screenInfo.deviceScaleFactor = deviceScaleFactors[i]; |
1122 | 1141 |
1123 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "viewport
-target-densitydpi-device.html", true, 0, &client); | 1142 FrameTestHelpers::WebViewHelper webViewHelper; |
1124 m_webView->enableFixedLayoutMode(true); | 1143 webViewHelper.initializeAndLoad(m_baseURL + "viewport-target-densitydpi-devi
ce.html", true, 0, &client); |
1125 m_webView->settings()->setViewportEnabled(true); | 1144 webViewHelper.webView()->enableFixedLayoutMode(true); |
1126 m_webView->settings()->setSupportDeprecatedTargetDensityDPI(true); | 1145 webViewHelper.webView()->settings()->setViewportEnabled(true); |
1127 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1146 webViewHelper.webView()->settings()->setSupportDeprecatedTargetDensityDP
I(true); |
| 1147 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1128 | 1148 |
1129 EXPECT_NEAR(viewportWidth * client.m_screenInfo.deviceScaleFactor, m_web
View->fixedLayoutSize().width, 1.0f); | 1149 EXPECT_NEAR(viewportWidth * client.m_screenInfo.deviceScaleFactor, webVi
ewHelper.webView()->fixedLayoutSize().width, 1.0f); |
1130 EXPECT_NEAR(viewportHeight * client.m_screenInfo.deviceScaleFactor, m_we
bView->fixedLayoutSize().height, 1.0f); | 1150 EXPECT_NEAR(viewportHeight * client.m_screenInfo.deviceScaleFactor, webV
iewHelper.webView()->fixedLayoutSize().height, 1.0f); |
1131 EXPECT_NEAR(1.0f / client.m_screenInfo.deviceScaleFactor, m_webView->pag
eScaleFactor(), 0.01f); | 1151 EXPECT_NEAR(1.0f / client.m_screenInfo.deviceScaleFactor, webViewHelper.
webView()->pageScaleFactor(), 0.01f); |
1132 | |
1133 m_webView->close(); | |
1134 m_webView = 0; | |
1135 } | 1152 } |
1136 } | 1153 } |
1137 | 1154 |
1138 class WebFrameResizeTest : public WebFrameTest { | 1155 class WebFrameResizeTest : public WebFrameTest { |
1139 protected: | 1156 protected: |
1140 | 1157 |
1141 static WebCore::FloatSize computeRelativeOffset(const WebCore::IntPoint& abs
oluteOffset, const WebCore::LayoutRect& rect) | 1158 static WebCore::FloatSize computeRelativeOffset(const WebCore::IntPoint& abs
oluteOffset, const WebCore::LayoutRect& rect) |
1142 { | 1159 { |
1143 WebCore::FloatSize relativeOffset = WebCore::FloatPoint(absoluteOffset)
- rect.location(); | 1160 WebCore::FloatSize relativeOffset = WebCore::FloatPoint(absoluteOffset)
- rect.location(); |
1144 relativeOffset.scale(1.f / rect.width(), 1.f / rect.height()); | 1161 relativeOffset.scale(1.f / rect.width(), 1.f / rect.height()); |
1145 return relativeOffset; | 1162 return relativeOffset; |
1146 } | 1163 } |
1147 | 1164 |
1148 void testResizeYieldsCorrectScrollAndScale(const char* url, | 1165 void testResizeYieldsCorrectScrollAndScale(const char* url, |
1149 const float initialPageScaleFacto
r, | 1166 const float initialPageScaleFacto
r, |
1150 const WebSize scrollOffset, | 1167 const WebSize scrollOffset, |
1151 const WebSize viewportSize, | 1168 const WebSize viewportSize, |
1152 const bool shouldScaleRelativeToV
iewportWidth) { | 1169 const bool shouldScaleRelativeToV
iewportWidth) { |
1153 registerMockedHttpURLLoad(url); | 1170 registerMockedHttpURLLoad(url); |
1154 | 1171 |
1155 const float aspectRatio = static_cast<float>(viewportSize.width) / viewp
ortSize.height; | 1172 const float aspectRatio = static_cast<float>(viewportSize.width) / viewp
ortSize.height; |
1156 | 1173 |
1157 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + url, true
); | 1174 FrameTestHelpers::WebViewHelper webViewHelper; |
1158 m_webView->settings()->setViewportEnabled(true); | 1175 webViewHelper.initializeAndLoad(m_baseURL + url, true); |
1159 m_webView->enableFixedLayoutMode(true); | 1176 webViewHelper.webView()->settings()->setViewportEnabled(true); |
| 1177 webViewHelper.webView()->enableFixedLayoutMode(true); |
1160 | 1178 |
1161 // Origin scrollOffsets preserved under resize. | 1179 // Origin scrollOffsets preserved under resize. |
1162 { | 1180 { |
1163 webViewImpl()->resize(WebSize(viewportSize.width, viewportSize.heigh
t)); | 1181 webViewHelper.webViewImpl()->resize(WebSize(viewportSize.width, view
portSize.height)); |
1164 webViewImpl()->setPageScaleFactor(initialPageScaleFactor, WebPoint()
); | 1182 webViewHelper.webViewImpl()->setPageScaleFactor(initialPageScaleFact
or, WebPoint()); |
1165 ASSERT_EQ(viewportSize, webViewImpl()->size()); | 1183 ASSERT_EQ(viewportSize, webViewHelper.webViewImpl()->size()); |
1166 ASSERT_EQ(initialPageScaleFactor, webViewImpl()->pageScaleFactor()); | 1184 ASSERT_EQ(initialPageScaleFactor, webViewHelper.webViewImpl()->pageS
caleFactor()); |
1167 webViewImpl()->resize(WebSize(viewportSize.height, viewportSize.widt
h)); | 1185 webViewHelper.webViewImpl()->resize(WebSize(viewportSize.height, vie
wportSize.width)); |
1168 float expectedPageScaleFactor = initialPageScaleFactor * (shouldScal
eRelativeToViewportWidth ? 1 / aspectRatio : 1); | 1186 float expectedPageScaleFactor = initialPageScaleFactor * (shouldScal
eRelativeToViewportWidth ? 1 / aspectRatio : 1); |
1169 EXPECT_NEAR(expectedPageScaleFactor, webViewImpl()->pageScaleFactor(
), 0.05f); | 1187 EXPECT_NEAR(expectedPageScaleFactor, webViewHelper.webViewImpl()->pa
geScaleFactor(), 0.05f); |
1170 EXPECT_EQ(WebSize(), webViewImpl()->mainFrame()->scrollOffset()); | 1188 EXPECT_EQ(WebSize(), webViewHelper.webViewImpl()->mainFrame()->scrol
lOffset()); |
1171 } | 1189 } |
1172 | 1190 |
1173 // Resizing just the height should not affect pageScaleFactor or scrollO
ffset. | 1191 // Resizing just the height should not affect pageScaleFactor or scrollO
ffset. |
1174 { | 1192 { |
1175 webViewImpl()->resize(WebSize(viewportSize.width, viewportSize.heigh
t)); | 1193 webViewHelper.webViewImpl()->resize(WebSize(viewportSize.width, view
portSize.height)); |
1176 webViewImpl()->setPageScaleFactor(initialPageScaleFactor, WebPoint(s
crollOffset.width, scrollOffset.height)); | 1194 webViewHelper.webViewImpl()->setPageScaleFactor(initialPageScaleFact
or, WebPoint(scrollOffset.width, scrollOffset.height)); |
1177 webViewImpl()->layout(); | 1195 webViewHelper.webViewImpl()->layout(); |
1178 const WebSize expectedScrollOffset = webViewImpl()->mainFrame()->scr
ollOffset(); | 1196 const WebSize expectedScrollOffset = webViewHelper.webViewImpl()->ma
inFrame()->scrollOffset(); |
1179 webViewImpl()->resize(WebSize(viewportSize.width, viewportSize.heigh
t * 0.8f)); | 1197 webViewHelper.webViewImpl()->resize(WebSize(viewportSize.width, view
portSize.height * 0.8f)); |
1180 EXPECT_EQ(initialPageScaleFactor, webViewImpl()->pageScaleFactor()); | 1198 EXPECT_EQ(initialPageScaleFactor, webViewHelper.webViewImpl()->pageS
caleFactor()); |
1181 EXPECT_EQ(expectedScrollOffset, webViewImpl()->mainFrame()->scrollOf
fset()); | 1199 EXPECT_EQ(expectedScrollOffset, webViewHelper.webViewImpl()->mainFra
me()->scrollOffset()); |
1182 webViewImpl()->resize(WebSize(viewportSize.width, viewportSize.heigh
t * 0.8f)); | 1200 webViewHelper.webViewImpl()->resize(WebSize(viewportSize.width, view
portSize.height * 0.8f)); |
1183 EXPECT_EQ(initialPageScaleFactor, webViewImpl()->pageScaleFactor()); | 1201 EXPECT_EQ(initialPageScaleFactor, webViewHelper.webViewImpl()->pageS
caleFactor()); |
1184 EXPECT_EQ(expectedScrollOffset, webViewImpl()->mainFrame()->scrollOf
fset()); | 1202 EXPECT_EQ(expectedScrollOffset, webViewHelper.webViewImpl()->mainFra
me()->scrollOffset()); |
1185 } | 1203 } |
1186 | 1204 |
1187 // Generic resize preserves scrollOffset relative to anchor node located | 1205 // Generic resize preserves scrollOffset relative to anchor node located |
1188 // the top center of the screen. | 1206 // the top center of the screen. |
1189 { | 1207 { |
1190 webViewImpl()->resize(WebSize(viewportSize.height, viewportSize.widt
h)); | 1208 webViewHelper.webViewImpl()->resize(WebSize(viewportSize.height, vie
wportSize.width)); |
1191 float pageScaleFactor = webViewImpl()->pageScaleFactor(); | 1209 float pageScaleFactor = webViewHelper.webViewImpl()->pageScaleFactor
(); |
1192 webViewImpl()->resize(WebSize(viewportSize.width, viewportSize.heigh
t)); | 1210 webViewHelper.webViewImpl()->resize(WebSize(viewportSize.width, view
portSize.height)); |
1193 float expectedPageScaleFactor = pageScaleFactor * (shouldScaleRelati
veToViewportWidth ? aspectRatio : 1); | 1211 float expectedPageScaleFactor = pageScaleFactor * (shouldScaleRelati
veToViewportWidth ? aspectRatio : 1); |
1194 EXPECT_NEAR(expectedPageScaleFactor, webViewImpl()->pageScaleFactor(
), 0.05f); | 1212 EXPECT_NEAR(expectedPageScaleFactor, webViewHelper.webViewImpl()->pa
geScaleFactor(), 0.05f); |
1195 webViewImpl()->mainFrame()->setScrollOffset(scrollOffset); | 1213 webViewHelper.webViewImpl()->mainFrame()->setScrollOffset(scrollOffs
et); |
1196 | 1214 |
1197 WebCore::IntPoint anchorPoint = WebCore::IntPoint(scrollOffset) + We
bCore::IntPoint(viewportSize.width / 2, 0); | 1215 WebCore::IntPoint anchorPoint = WebCore::IntPoint(scrollOffset) + We
bCore::IntPoint(viewportSize.width / 2, 0); |
1198 RefPtr<WebCore::Node> anchorNode = webViewImpl()->mainFrameImpl()->f
rame()->eventHandler()->hitTestResultAtPoint(anchorPoint, HitTestRequest::ReadOn
ly | HitTestRequest::Active | HitTestRequest::DisallowShadowContent).innerNode()
; | 1216 RefPtr<WebCore::Node> anchorNode = webViewHelper.webViewImpl()->main
FrameImpl()->frame()->eventHandler()->hitTestResultAtPoint(anchorPoint, HitTestR
equest::ReadOnly | HitTestRequest::Active | HitTestRequest::DisallowShadowConten
t).innerNode(); |
1199 ASSERT(anchorNode); | 1217 ASSERT(anchorNode); |
1200 | 1218 |
1201 pageScaleFactor = webViewImpl()->pageScaleFactor(); | 1219 pageScaleFactor = webViewHelper.webViewImpl()->pageScaleFactor(); |
1202 const WebCore::FloatSize preResizeRelativeOffset | 1220 const WebCore::FloatSize preResizeRelativeOffset |
1203 = computeRelativeOffset(anchorPoint, anchorNode->boundingBox()); | 1221 = computeRelativeOffset(anchorPoint, anchorNode->boundingBox()); |
1204 webViewImpl()->resize(WebSize(viewportSize.height, viewportSize.widt
h)); | 1222 webViewHelper.webViewImpl()->resize(WebSize(viewportSize.height, vie
wportSize.width)); |
1205 WebCore::IntPoint newAnchorPoint = WebCore::IntPoint(webViewImpl()->
mainFrame()->scrollOffset()) + WebCore::IntPoint(viewportSize.height / 2, 0); | 1223 WebCore::IntPoint newAnchorPoint = WebCore::IntPoint(webViewHelper.w
ebViewImpl()->mainFrame()->scrollOffset()) + WebCore::IntPoint(viewportSize.heig
ht / 2, 0); |
1206 const WebCore::FloatSize postResizeRelativeOffset | 1224 const WebCore::FloatSize postResizeRelativeOffset |
1207 = computeRelativeOffset(newAnchorPoint, anchorNode->boundingBox(
)); | 1225 = computeRelativeOffset(newAnchorPoint, anchorNode->boundingBox(
)); |
1208 EXPECT_NEAR(preResizeRelativeOffset.width(), postResizeRelativeOffse
t.width(), 0.15f); | 1226 EXPECT_NEAR(preResizeRelativeOffset.width(), postResizeRelativeOffse
t.width(), 0.15f); |
1209 expectedPageScaleFactor = pageScaleFactor * (shouldScaleRelativeToVi
ewportWidth ? 1 / aspectRatio : 1); | 1227 expectedPageScaleFactor = pageScaleFactor * (shouldScaleRelativeToVi
ewportWidth ? 1 / aspectRatio : 1); |
1210 EXPECT_NEAR(expectedPageScaleFactor, webViewImpl()->pageScaleFactor(
), 0.05f); | 1228 EXPECT_NEAR(expectedPageScaleFactor, webViewHelper.webViewImpl()->pa
geScaleFactor(), 0.05f); |
1211 } | 1229 } |
1212 } | 1230 } |
1213 }; | 1231 }; |
1214 | 1232 |
1215 TEST_F(WebFrameResizeTest, ResizeYieldsCorrectScrollAndScaleForWidthEqualsDevice
Width) | 1233 TEST_F(WebFrameResizeTest, ResizeYieldsCorrectScrollAndScaleForWidthEqualsDevice
Width) |
1216 { | 1234 { |
1217 // With width=device-width, pageScaleFactor is preserved across resizes as | 1235 // With width=device-width, pageScaleFactor is preserved across resizes as |
1218 // long as the content adjusts according to the device-width. | 1236 // long as the content adjusts according to the device-width. |
1219 const char* url = "resize_scroll_mobile.html"; | 1237 const char* url = "resize_scroll_mobile.html"; |
1220 const float initialPageScaleFactor = 1; | 1238 const float initialPageScaleFactor = 1; |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1255 TEST_F(WebFrameTest, pageScaleFactorScalesPaintClip) | 1273 TEST_F(WebFrameTest, pageScaleFactorScalesPaintClip) |
1256 { | 1274 { |
1257 UseMockScrollbarSettings mockScrollbarSettings; | 1275 UseMockScrollbarSettings mockScrollbarSettings; |
1258 registerMockedHttpURLLoad("large-div.html"); | 1276 registerMockedHttpURLLoad("large-div.html"); |
1259 | 1277 |
1260 FixedLayoutTestWebViewClient client; | 1278 FixedLayoutTestWebViewClient client; |
1261 client.m_screenInfo.deviceScaleFactor = 1; | 1279 client.m_screenInfo.deviceScaleFactor = 1; |
1262 int viewportWidth = 50; | 1280 int viewportWidth = 50; |
1263 int viewportHeight = 50; | 1281 int viewportHeight = 50; |
1264 | 1282 |
1265 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "large-div.ht
ml", true, 0, &client); | 1283 FrameTestHelpers::WebViewHelper webViewHelper; |
1266 m_webView->enableFixedLayoutMode(true); | 1284 webViewHelper.initializeAndLoad(m_baseURL + "large-div.html", true, 0, &clie
nt); |
1267 m_webView->settings()->setViewportEnabled(true); | 1285 webViewHelper.webView()->enableFixedLayoutMode(true); |
1268 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1286 webViewHelper.webView()->settings()->setViewportEnabled(true); |
1269 m_webView->layout(); | 1287 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 1288 webViewHelper.webView()->layout(); |
1270 | 1289 |
1271 // Set <1 page scale so that the clip rect should be larger than | 1290 // Set <1 page scale so that the clip rect should be larger than |
1272 // the viewport size as passed into resize(). | 1291 // the viewport size as passed into resize(). |
1273 m_webView->setPageScaleFactor(0.5, WebPoint()); | 1292 webViewHelper.webView()->setPageScaleFactor(0.5, WebPoint()); |
1274 | 1293 |
1275 SkBitmap bitmap; | 1294 SkBitmap bitmap; |
1276 bitmap.setConfig(SkBitmap::kARGB_8888_Config, 200, 200); | 1295 bitmap.setConfig(SkBitmap::kARGB_8888_Config, 200, 200); |
1277 bitmap.allocPixels(); | 1296 bitmap.allocPixels(); |
1278 bitmap.eraseColor(0); | 1297 bitmap.eraseColor(0); |
1279 SkCanvas canvas(bitmap); | 1298 SkCanvas canvas(bitmap); |
1280 | 1299 |
1281 WebCore::GraphicsContext context(&canvas); | 1300 WebCore::GraphicsContext context(&canvas); |
1282 context.setTrackOpaqueRegion(true); | 1301 context.setTrackOpaqueRegion(true); |
1283 | 1302 |
1284 EXPECT_EQ_RECT(WebCore::IntRect(0, 0, 0, 0), context.opaqueRegion().asRect()
); | 1303 EXPECT_EQ_RECT(WebCore::IntRect(0, 0, 0, 0), context.opaqueRegion().asRect()
); |
1285 | 1304 |
1286 WebCore::FrameView* view = webViewImpl()->mainFrameImpl()->frameView(); | 1305 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); |
1287 WebCore::IntRect paintRect(0, 0, 200, 200); | 1306 WebCore::IntRect paintRect(0, 0, 200, 200); |
1288 view->paint(&context, paintRect); | 1307 view->paint(&context, paintRect); |
1289 | 1308 |
1290 int viewportWidthMinusScrollbar = 50 - (view->verticalScrollbar()->isOverlay
Scrollbar() ? 0 : 15); | 1309 int viewportWidthMinusScrollbar = 50 - (view->verticalScrollbar()->isOverlay
Scrollbar() ? 0 : 15); |
1291 int viewportHeightMinusScrollbar = 50 - (view->horizontalScrollbar()->isOver
layScrollbar() ? 0 : 15); | 1310 int viewportHeightMinusScrollbar = 50 - (view->horizontalScrollbar()->isOver
layScrollbar() ? 0 : 15); |
1292 WebCore::IntRect clippedRect(0, 0, viewportWidthMinusScrollbar * 2, viewport
HeightMinusScrollbar * 2); | 1311 WebCore::IntRect clippedRect(0, 0, viewportWidthMinusScrollbar * 2, viewport
HeightMinusScrollbar * 2); |
1293 EXPECT_EQ_RECT(clippedRect, context.opaqueRegion().asRect()); | 1312 EXPECT_EQ_RECT(clippedRect, context.opaqueRegion().asRect()); |
1294 } | 1313 } |
1295 | 1314 |
1296 TEST_F(WebFrameTest, pageScaleFactorUpdatesScrollbars) | 1315 TEST_F(WebFrameTest, pageScaleFactorUpdatesScrollbars) |
1297 { | 1316 { |
1298 UseMockScrollbarSettings mockScrollbarSettings; | 1317 UseMockScrollbarSettings mockScrollbarSettings; |
1299 registerMockedHttpURLLoad("fixed_layout.html"); | 1318 registerMockedHttpURLLoad("fixed_layout.html"); |
1300 | 1319 |
1301 FixedLayoutTestWebViewClient client; | 1320 FixedLayoutTestWebViewClient client; |
1302 client.m_screenInfo.deviceScaleFactor = 1; | 1321 client.m_screenInfo.deviceScaleFactor = 1; |
1303 int viewportWidth = 640; | 1322 int viewportWidth = 640; |
1304 int viewportHeight = 480; | 1323 int viewportHeight = 480; |
1305 | 1324 |
1306 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fixed_layout
.html", true, 0, &client); | 1325 FrameTestHelpers::WebViewHelper webViewHelper; |
1307 m_webView->enableFixedLayoutMode(true); | 1326 webViewHelper.initializeAndLoad(m_baseURL + "fixed_layout.html", true, 0, &c
lient); |
1308 m_webView->settings()->setViewportEnabled(true); | 1327 webViewHelper.webView()->enableFixedLayoutMode(true); |
1309 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1328 webViewHelper.webView()->settings()->setViewportEnabled(true); |
1310 m_webView->layout(); | 1329 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 1330 webViewHelper.webView()->layout(); |
1311 | 1331 |
1312 WebCore::FrameView* view = webViewImpl()->mainFrameImpl()->frameView(); | 1332 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); |
1313 EXPECT_EQ(view->scrollSize(WebCore::HorizontalScrollbar), view->contentsSize
().width() - view->visibleContentRect().width()); | 1333 EXPECT_EQ(view->scrollSize(WebCore::HorizontalScrollbar), view->contentsSize
().width() - view->visibleContentRect().width()); |
1314 EXPECT_EQ(view->scrollSize(WebCore::VerticalScrollbar), view->contentsSize()
.height() - view->visibleContentRect().height()); | 1334 EXPECT_EQ(view->scrollSize(WebCore::VerticalScrollbar), view->contentsSize()
.height() - view->visibleContentRect().height()); |
1315 | 1335 |
1316 m_webView->setPageScaleFactor(10, WebPoint()); | 1336 webViewHelper.webView()->setPageScaleFactor(10, WebPoint()); |
1317 | 1337 |
1318 EXPECT_EQ(view->scrollSize(WebCore::HorizontalScrollbar), view->contentsSize
().width() - view->visibleContentRect().width()); | 1338 EXPECT_EQ(view->scrollSize(WebCore::HorizontalScrollbar), view->contentsSize
().width() - view->visibleContentRect().width()); |
1319 EXPECT_EQ(view->scrollSize(WebCore::VerticalScrollbar), view->contentsSize()
.height() - view->visibleContentRect().height()); | 1339 EXPECT_EQ(view->scrollSize(WebCore::VerticalScrollbar), view->contentsSize()
.height() - view->visibleContentRect().height()); |
1320 } | 1340 } |
1321 | 1341 |
1322 TEST_F(WebFrameTest, CanOverrideScaleLimits) | 1342 TEST_F(WebFrameTest, CanOverrideScaleLimits) |
1323 { | 1343 { |
1324 UseMockScrollbarSettings mockScrollbarSettings; | 1344 UseMockScrollbarSettings mockScrollbarSettings; |
1325 | 1345 |
1326 registerMockedHttpURLLoad("no_scale_for_you.html"); | 1346 registerMockedHttpURLLoad("no_scale_for_you.html"); |
1327 | 1347 |
1328 FixedLayoutTestWebViewClient client; | 1348 FixedLayoutTestWebViewClient client; |
1329 client.m_screenInfo.deviceScaleFactor = 1; | 1349 client.m_screenInfo.deviceScaleFactor = 1; |
1330 int viewportWidth = 640; | 1350 int viewportWidth = 640; |
1331 int viewportHeight = 480; | 1351 int viewportHeight = 480; |
1332 | 1352 |
1333 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "no_scale_for
_you.html", true, 0, &client); | 1353 FrameTestHelpers::WebViewHelper webViewHelper; |
1334 m_webView->enableFixedLayoutMode(true); | 1354 webViewHelper.initializeAndLoad(m_baseURL + "no_scale_for_you.html", true, 0
, &client); |
1335 m_webView->settings()->setViewportEnabled(true); | 1355 webViewHelper.webView()->enableFixedLayoutMode(true); |
1336 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1356 webViewHelper.webView()->settings()->setViewportEnabled(true); |
| 1357 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1337 | 1358 |
1338 EXPECT_EQ(2.0f, m_webView->minimumPageScaleFactor()); | 1359 EXPECT_EQ(2.0f, webViewHelper.webView()->minimumPageScaleFactor()); |
1339 EXPECT_EQ(2.0f, m_webView->maximumPageScaleFactor()); | 1360 EXPECT_EQ(2.0f, webViewHelper.webView()->maximumPageScaleFactor()); |
1340 | 1361 |
1341 m_webView->setIgnoreViewportTagScaleLimits(true); | 1362 webViewHelper.webView()->setIgnoreViewportTagScaleLimits(true); |
1342 m_webView->layout(); | 1363 webViewHelper.webView()->layout(); |
1343 | 1364 |
1344 EXPECT_EQ(1.0f, m_webView->minimumPageScaleFactor()); | 1365 EXPECT_EQ(1.0f, webViewHelper.webView()->minimumPageScaleFactor()); |
1345 EXPECT_EQ(5.0f, m_webView->maximumPageScaleFactor()); | 1366 EXPECT_EQ(5.0f, webViewHelper.webView()->maximumPageScaleFactor()); |
1346 | 1367 |
1347 m_webView->setIgnoreViewportTagScaleLimits(false); | 1368 webViewHelper.webView()->setIgnoreViewportTagScaleLimits(false); |
1348 m_webView->layout(); | 1369 webViewHelper.webView()->layout(); |
1349 | 1370 |
1350 EXPECT_EQ(2.0f, m_webView->minimumPageScaleFactor()); | 1371 EXPECT_EQ(2.0f, webViewHelper.webView()->minimumPageScaleFactor()); |
1351 EXPECT_EQ(2.0f, m_webView->maximumPageScaleFactor()); | 1372 EXPECT_EQ(2.0f, webViewHelper.webView()->maximumPageScaleFactor()); |
1352 } | 1373 } |
1353 | 1374 |
1354 TEST_F(WebFrameTest, updateOverlayScrollbarLayers) | 1375 TEST_F(WebFrameTest, updateOverlayScrollbarLayers) |
1355 { | 1376 { |
1356 UseMockScrollbarSettings mockScrollbarSettings; | 1377 UseMockScrollbarSettings mockScrollbarSettings; |
1357 | 1378 |
1358 registerMockedHttpURLLoad("large-div.html"); | 1379 registerMockedHttpURLLoad("large-div.html"); |
1359 | 1380 |
1360 int viewWidth = 500; | 1381 int viewWidth = 500; |
1361 int viewHeight = 500; | 1382 int viewHeight = 500; |
1362 | 1383 |
1363 createCompositingWebView(); | 1384 OwnPtr<FakeCompositingWebViewClient> fakeCompositingWebViewClient = adoptPtr
(new FakeCompositingWebViewClient()); |
1364 m_webView->resize(WebSize(viewWidth, viewHeight)); | 1385 FrameTestHelpers::WebViewHelper webViewHelper; |
1365 FrameTestHelpers::loadFrame(m_webView->mainFrame(), m_baseURL + "large-div.h
tml"); | 1386 webViewHelper.initialize(true, &fakeCompositingWebViewClient->m_fakeWebFrame
Client, fakeCompositingWebViewClient.get(), &configueCompositingWebView); |
| 1387 |
| 1388 webViewHelper.webView()->resize(WebSize(viewWidth, viewHeight)); |
| 1389 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "large-div.html"); |
1366 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 1390 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1367 m_webView->layout(); | 1391 webViewHelper.webView()->layout(); |
1368 | 1392 |
1369 WebCore::FrameView* view = webViewImpl()->mainFrameImpl()->frameView(); | 1393 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); |
1370 EXPECT_TRUE(view->renderView()->compositor()->layerForHorizontalScrollbar())
; | 1394 EXPECT_TRUE(view->renderView()->compositor()->layerForHorizontalScrollbar())
; |
1371 EXPECT_TRUE(view->renderView()->compositor()->layerForVerticalScrollbar()); | 1395 EXPECT_TRUE(view->renderView()->compositor()->layerForVerticalScrollbar()); |
1372 | 1396 |
1373 m_webView->resize(WebSize(viewWidth * 10, viewHeight * 10)); | 1397 webViewHelper.webView()->resize(WebSize(viewWidth * 10, viewHeight * 10)); |
1374 m_webView->layout(); | 1398 webViewHelper.webView()->layout(); |
1375 EXPECT_FALSE(view->renderView()->compositor()->layerForHorizontalScrollbar()
); | 1399 EXPECT_FALSE(view->renderView()->compositor()->layerForHorizontalScrollbar()
); |
1376 EXPECT_FALSE(view->renderView()->compositor()->layerForVerticalScrollbar()); | 1400 EXPECT_FALSE(view->renderView()->compositor()->layerForVerticalScrollbar()); |
1377 } | 1401 } |
1378 | 1402 |
1379 void setScaleAndScrollAndLayout(WebKit::WebView* webView, WebPoint scroll, float
scale) | 1403 void setScaleAndScrollAndLayout(WebKit::WebView* webView, WebPoint scroll, float
scale) |
1380 { | 1404 { |
1381 webView->setPageScaleFactor(scale, WebPoint(scroll.x, scroll.y)); | 1405 webView->setPageScaleFactor(scale, WebPoint(scroll.x, scroll.y)); |
1382 webView->layout(); | 1406 webView->layout(); |
1383 } | 1407 } |
1384 | 1408 |
1385 TEST_F(WebFrameTest, DivAutoZoomParamsTest) | 1409 TEST_F(WebFrameTest, DivAutoZoomParamsTest) |
1386 { | 1410 { |
1387 registerMockedHttpURLLoad("get_scale_for_auto_zoom_into_div_test.html"); | 1411 registerMockedHttpURLLoad("get_scale_for_auto_zoom_into_div_test.html"); |
1388 | 1412 |
1389 const float deviceScaleFactor = 2.0f; | 1413 const float deviceScaleFactor = 2.0f; |
1390 int viewportWidth = 640 / deviceScaleFactor; | 1414 int viewportWidth = 640 / deviceScaleFactor; |
1391 int viewportHeight = 1280 / deviceScaleFactor; | 1415 int viewportHeight = 1280 / deviceScaleFactor; |
1392 float doubleTapZoomAlreadyLegibleRatio = 1.2f; | 1416 float doubleTapZoomAlreadyLegibleRatio = 1.2f; |
1393 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "get_scale_fo
r_auto_zoom_into_div_test.html"); // | 1417 FrameTestHelpers::WebViewHelper webViewHelper; |
1394 m_webView->setDeviceScaleFactor(deviceScaleFactor); | 1418 webViewHelper.initializeAndLoad(m_baseURL + "get_scale_for_auto_zoom_into_di
v_test.html"); |
1395 m_webView->setPageScaleFactorLimits(0.01f, 4); | 1419 webViewHelper.webView()->setDeviceScaleFactor(deviceScaleFactor); |
1396 m_webView->setPageScaleFactor(0.5f, WebPoint(0, 0)); | 1420 webViewHelper.webView()->setPageScaleFactorLimits(0.01f, 4); |
1397 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1421 webViewHelper.webView()->setPageScaleFactor(0.5f, WebPoint(0, 0)); |
1398 m_webView->enableFixedLayoutMode(true); | 1422 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1399 m_webView->layout(); | 1423 webViewHelper.webView()->enableFixedLayoutMode(true); |
| 1424 webViewHelper.webView()->layout(); |
1400 | 1425 |
1401 WebRect wideDiv(200, 100, 400, 150); | 1426 WebRect wideDiv(200, 100, 400, 150); |
1402 WebRect tallDiv(200, 300, 400, 800); | 1427 WebRect tallDiv(200, 300, 400, 800); |
1403 WebRect doubleTapPointWide(wideDiv.x + 50, wideDiv.y + 50, touchPointPadding
, touchPointPadding); | 1428 WebRect doubleTapPointWide(wideDiv.x + 50, wideDiv.y + 50, touchPointPadding
, touchPointPadding); |
1404 WebRect doubleTapPointTall(tallDiv.x + 50, tallDiv.y + 50, touchPointPadding
, touchPointPadding); | 1429 WebRect doubleTapPointTall(tallDiv.x + 50, tallDiv.y + 50, touchPointPadding
, touchPointPadding); |
1405 WebRect wideBlockBounds; | 1430 WebRect wideBlockBounds; |
1406 WebRect tallBlockBounds; | 1431 WebRect tallBlockBounds; |
1407 float scale; | 1432 float scale; |
1408 WebPoint scroll; | 1433 WebPoint scroll; |
1409 | 1434 |
1410 float doubleTapZoomAlreadyLegibleScale = webViewImpl()->minimumPageScaleFact
or() * doubleTapZoomAlreadyLegibleRatio; | 1435 float doubleTapZoomAlreadyLegibleScale = webViewHelper.webViewImpl()->minimu
mPageScaleFactor() * doubleTapZoomAlreadyLegibleRatio; |
1411 | 1436 |
1412 // Test double-tap zooming into wide div. | 1437 // Test double-tap zooming into wide div. |
1413 wideBlockBounds = webViewImpl()->computeBlockBounds(doubleTapPointWide, fals
e); | 1438 wideBlockBounds = webViewHelper.webViewImpl()->computeBlockBounds(doubleTapP
ointWide, false); |
1414 webViewImpl()->computeScaleAndScrollForBlockRect(wideBlockBounds, touchPoint
Padding, doubleTapZoomAlreadyLegibleScale, scale, scroll); | 1439 webViewHelper.webViewImpl()->computeScaleAndScrollForBlockRect(wideBlockBoun
ds, touchPointPadding, doubleTapZoomAlreadyLegibleScale, scale, scroll); |
1415 // The div should horizontally fill the screen (modulo margins), and | 1440 // The div should horizontally fill the screen (modulo margins), and |
1416 // vertically centered (modulo integer rounding). | 1441 // vertically centered (modulo integer rounding). |
1417 EXPECT_NEAR(viewportWidth / (float) wideDiv.width, scale, 0.1); | 1442 EXPECT_NEAR(viewportWidth / (float) wideDiv.width, scale, 0.1); |
1418 EXPECT_NEAR(wideDiv.x, scroll.x, 20); | 1443 EXPECT_NEAR(wideDiv.x, scroll.x, 20); |
1419 EXPECT_EQ(0, scroll.y); | 1444 EXPECT_EQ(0, scroll.y); |
1420 | 1445 |
1421 setScaleAndScrollAndLayout(webViewImpl(), scroll, scale); | 1446 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), scroll, scale); |
1422 | 1447 |
1423 // Test zoom out back to minimum scale. | 1448 // Test zoom out back to minimum scale. |
1424 wideBlockBounds = webViewImpl()->computeBlockBounds(doubleTapPointWide, fals
e); | 1449 wideBlockBounds = webViewHelper.webViewImpl()->computeBlockBounds(doubleTapP
ointWide, false); |
1425 webViewImpl()->computeScaleAndScrollForBlockRect(wideBlockBounds, touchPoint
Padding, doubleTapZoomAlreadyLegibleScale, scale, scroll); | 1450 webViewHelper.webViewImpl()->computeScaleAndScrollForBlockRect(wideBlockBoun
ds, touchPointPadding, doubleTapZoomAlreadyLegibleScale, scale, scroll); |
1426 | 1451 |
1427 scale = webViewImpl()->minimumPageScaleFactor(); | 1452 scale = webViewHelper.webViewImpl()->minimumPageScaleFactor(); |
1428 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), scale); | 1453 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), scal
e); |
1429 | 1454 |
1430 // Test double-tap zooming into tall div. | 1455 // Test double-tap zooming into tall div. |
1431 tallBlockBounds = webViewImpl()->computeBlockBounds(doubleTapPointTall, fals
e); | 1456 tallBlockBounds = webViewHelper.webViewImpl()->computeBlockBounds(doubleTapP
ointTall, false); |
1432 webViewImpl()->computeScaleAndScrollForBlockRect(tallBlockBounds, touchPoint
Padding, doubleTapZoomAlreadyLegibleScale, scale, scroll); | 1457 webViewHelper.webViewImpl()->computeScaleAndScrollForBlockRect(tallBlockBoun
ds, touchPointPadding, doubleTapZoomAlreadyLegibleScale, scale, scroll); |
1433 // The div should start at the top left of the viewport. | 1458 // The div should start at the top left of the viewport. |
1434 EXPECT_NEAR(viewportWidth / (float) tallDiv.width, scale, 0.1); | 1459 EXPECT_NEAR(viewportWidth / (float) tallDiv.width, scale, 0.1); |
1435 EXPECT_NEAR(tallDiv.x, scroll.x, 20); | 1460 EXPECT_NEAR(tallDiv.x, scroll.x, 20); |
1436 EXPECT_NEAR(tallDiv.y, scroll.y, 20); | 1461 EXPECT_NEAR(tallDiv.y, scroll.y, 20); |
1437 | 1462 |
1438 // Test for Non-doubletap scaling | 1463 // Test for Non-doubletap scaling |
1439 // Test zooming into div. | 1464 // Test zooming into div. |
1440 webViewImpl()->computeScaleAndScrollForBlockRect(webViewImpl()->computeBlock
Bounds(WebRect(250, 250, 10, 10), true), 0, doubleTapZoomAlreadyLegibleScale, sc
ale, scroll); | 1465 webViewHelper.webViewImpl()->computeScaleAndScrollForBlockRect(webViewHelper
.webViewImpl()->computeBlockBounds(WebRect(250, 250, 10, 10), true), 0, doubleTa
pZoomAlreadyLegibleScale, scale, scroll); |
1441 EXPECT_NEAR(viewportWidth / (float) wideDiv.width, scale, 0.1); | 1466 EXPECT_NEAR(viewportWidth / (float) wideDiv.width, scale, 0.1); |
1442 } | 1467 } |
1443 | 1468 |
1444 void simulatePageScale(WebViewImpl* webViewImpl, float& scale) | 1469 void simulatePageScale(WebViewImpl* webViewImpl, float& scale) |
1445 { | 1470 { |
1446 WebCore::IntSize scrollDelta = webViewImpl->fakePageScaleAnimationTargetPosi
tionForTesting() - webViewImpl->mainFrameImpl()->frameView()->scrollPosition(); | 1471 WebCore::IntSize scrollDelta = webViewImpl->fakePageScaleAnimationTargetPosi
tionForTesting() - webViewImpl->mainFrameImpl()->frameView()->scrollPosition(); |
1447 float scaleDelta = webViewImpl->fakePageScaleAnimationPageScaleForTesting()
/ webViewImpl->pageScaleFactor(); | 1472 float scaleDelta = webViewImpl->fakePageScaleAnimationPageScaleForTesting()
/ webViewImpl->pageScaleFactor(); |
1448 webViewImpl->applyScrollAndScale(scrollDelta, scaleDelta); | 1473 webViewImpl->applyScrollAndScale(scrollDelta, scaleDelta); |
1449 scale = webViewImpl->pageScaleFactor(); | 1474 scale = webViewImpl->pageScaleFactor(); |
1450 } | 1475 } |
(...skipping 12 matching lines...) Expand all Loading... |
1463 } | 1488 } |
1464 | 1489 |
1465 TEST_F(WebFrameTest, DivAutoZoomWideDivTest) | 1490 TEST_F(WebFrameTest, DivAutoZoomWideDivTest) |
1466 { | 1491 { |
1467 registerMockedHttpURLLoad("get_wide_div_for_auto_zoom_test.html"); | 1492 registerMockedHttpURLLoad("get_wide_div_for_auto_zoom_test.html"); |
1468 | 1493 |
1469 const float deviceScaleFactor = 2.0f; | 1494 const float deviceScaleFactor = 2.0f; |
1470 int viewportWidth = 640 / deviceScaleFactor; | 1495 int viewportWidth = 640 / deviceScaleFactor; |
1471 int viewportHeight = 1280 / deviceScaleFactor; | 1496 int viewportHeight = 1280 / deviceScaleFactor; |
1472 float doubleTapZoomAlreadyLegibleRatio = 1.2f; | 1497 float doubleTapZoomAlreadyLegibleRatio = 1.2f; |
1473 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "get_wide_div
_for_auto_zoom_test.html"); | 1498 FrameTestHelpers::WebViewHelper webViewHelper; |
1474 m_webView->enableFixedLayoutMode(true); | 1499 webViewHelper.initializeAndLoad(m_baseURL + "get_wide_div_for_auto_zoom_test
.html"); |
1475 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1500 webViewHelper.webView()->enableFixedLayoutMode(true); |
1476 m_webView->setPageScaleFactorLimits(1.0f, 4); | 1501 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1477 m_webView->setDeviceScaleFactor(deviceScaleFactor); | 1502 webViewHelper.webView()->setPageScaleFactorLimits(1.0f, 4); |
1478 m_webView->setPageScaleFactor(1.0f, WebPoint(0, 0)); | 1503 webViewHelper.webView()->setDeviceScaleFactor(deviceScaleFactor); |
1479 m_webView->layout(); | 1504 webViewHelper.webView()->setPageScaleFactor(1.0f, WebPoint(0, 0)); |
| 1505 webViewHelper.webView()->layout(); |
1480 | 1506 |
1481 webViewImpl()->enableFakePageScaleAnimationForTesting(true); | 1507 webViewHelper.webViewImpl()->enableFakePageScaleAnimationForTesting(true); |
1482 | 1508 |
1483 float doubleTapZoomAlreadyLegibleScale = webViewImpl()->minimumPageScaleFact
or() * doubleTapZoomAlreadyLegibleRatio; | 1509 float doubleTapZoomAlreadyLegibleScale = webViewHelper.webViewImpl()->minimu
mPageScaleFactor() * doubleTapZoomAlreadyLegibleRatio; |
1484 | 1510 |
1485 WebRect div(0, 100, viewportWidth, 150); | 1511 WebRect div(0, 100, viewportWidth, 150); |
1486 WebPoint point(div.x + 50, div.y + 50); | 1512 WebPoint point(div.x + 50, div.y + 50); |
1487 float scale; | 1513 float scale; |
1488 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1514 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1489 | 1515 |
1490 simulateDoubleTap(webViewImpl(), point, scale); | 1516 simulateDoubleTap(webViewHelper.webViewImpl(), point, scale); |
1491 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); | 1517 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); |
1492 simulateDoubleTap(webViewImpl(), point, scale); | 1518 simulateDoubleTap(webViewHelper.webViewImpl(), point, scale); |
1493 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1519 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1494 } | 1520 } |
1495 | 1521 |
1496 TEST_F(WebFrameTest, DivAutoZoomMultipleDivsTest) | 1522 TEST_F(WebFrameTest, DivAutoZoomMultipleDivsTest) |
1497 { | 1523 { |
1498 registerMockedHttpURLLoad("get_multiple_divs_for_auto_zoom_test.html"); | 1524 registerMockedHttpURLLoad("get_multiple_divs_for_auto_zoom_test.html"); |
1499 | 1525 |
1500 const float deviceScaleFactor = 2.0f; | 1526 const float deviceScaleFactor = 2.0f; |
1501 int viewportWidth = 640 / deviceScaleFactor; | 1527 int viewportWidth = 640 / deviceScaleFactor; |
1502 int viewportHeight = 1280 / deviceScaleFactor; | 1528 int viewportHeight = 1280 / deviceScaleFactor; |
1503 float doubleTapZoomAlreadyLegibleRatio = 1.2f; | 1529 float doubleTapZoomAlreadyLegibleRatio = 1.2f; |
1504 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "get_multiple
_divs_for_auto_zoom_test.html"); | 1530 FrameTestHelpers::WebViewHelper webViewHelper; |
1505 m_webView->enableFixedLayoutMode(true); | 1531 webViewHelper.initializeAndLoad(m_baseURL + "get_multiple_divs_for_auto_zoom
_test.html"); |
1506 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1532 webViewHelper.webView()->enableFixedLayoutMode(true); |
1507 m_webView->setPageScaleFactorLimits(0.5f, 4); | 1533 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1508 m_webView->setDeviceScaleFactor(deviceScaleFactor); | 1534 webViewHelper.webView()->setPageScaleFactorLimits(0.5f, 4); |
1509 m_webView->setPageScaleFactor(0.5f, WebPoint(0, 0)); | 1535 webViewHelper.webView()->setDeviceScaleFactor(deviceScaleFactor); |
1510 m_webView->layout(); | 1536 webViewHelper.webView()->setPageScaleFactor(0.5f, WebPoint(0, 0)); |
| 1537 webViewHelper.webView()->layout(); |
1511 | 1538 |
1512 webViewImpl()->enableFakePageScaleAnimationForTesting(true); | 1539 webViewHelper.webViewImpl()->enableFakePageScaleAnimationForTesting(true); |
1513 | 1540 |
1514 WebRect topDiv(200, 100, 200, 150); | 1541 WebRect topDiv(200, 100, 200, 150); |
1515 WebRect bottomDiv(200, 300, 200, 150); | 1542 WebRect bottomDiv(200, 300, 200, 150); |
1516 WebPoint topPoint(topDiv.x + 50, topDiv.y + 50); | 1543 WebPoint topPoint(topDiv.x + 50, topDiv.y + 50); |
1517 WebPoint bottomPoint(bottomDiv.x + 50, bottomDiv.y + 50); | 1544 WebPoint bottomPoint(bottomDiv.x + 50, bottomDiv.y + 50); |
1518 float scale; | 1545 float scale; |
1519 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1546 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1520 | 1547 |
1521 // Test double tap on two different divs | 1548 // Test double tap on two different divs |
1522 // After first zoom, we should go back to minimum page scale with a second d
ouble tap. | 1549 // After first zoom, we should go back to minimum page scale with a second d
ouble tap. |
1523 simulateDoubleTap(webViewImpl(), topPoint, scale); | 1550 simulateDoubleTap(webViewHelper.webViewImpl(), topPoint, scale); |
1524 EXPECT_FLOAT_EQ(1, scale); | 1551 EXPECT_FLOAT_EQ(1, scale); |
1525 simulateDoubleTap(webViewImpl(), bottomPoint, scale); | 1552 simulateDoubleTap(webViewHelper.webViewImpl(), bottomPoint, scale); |
1526 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1553 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1527 | 1554 |
1528 // If the user pinch zooms after double tap, a second double tap should zoom
back to the div. | 1555 // If the user pinch zooms after double tap, a second double tap should zoom
back to the div. |
1529 simulateDoubleTap(webViewImpl(), topPoint, scale); | 1556 simulateDoubleTap(webViewHelper.webViewImpl(), topPoint, scale); |
1530 EXPECT_FLOAT_EQ(1, scale); | 1557 EXPECT_FLOAT_EQ(1, scale); |
1531 webViewImpl()->applyScrollAndScale(WebSize(), 0.6f); | 1558 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(), 0.6f); |
1532 simulateDoubleTap(webViewImpl(), bottomPoint, scale); | 1559 simulateDoubleTap(webViewHelper.webViewImpl(), bottomPoint, scale); |
1533 EXPECT_FLOAT_EQ(1, scale); | 1560 EXPECT_FLOAT_EQ(1, scale); |
1534 simulateDoubleTap(webViewImpl(), bottomPoint, scale); | 1561 simulateDoubleTap(webViewHelper.webViewImpl(), bottomPoint, scale); |
1535 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1562 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1536 | 1563 |
1537 // If we didn't yet get an auto-zoom update and a second double-tap arrives,
should go back to minimum scale. | 1564 // If we didn't yet get an auto-zoom update and a second double-tap arrives,
should go back to minimum scale. |
1538 webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); | 1565 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); |
1539 webViewImpl()->animateDoubleTapZoom(topPoint); | 1566 webViewHelper.webViewImpl()->animateDoubleTapZoom(topPoint); |
1540 EXPECT_TRUE(webViewImpl()->fakeDoubleTapAnimationPendingForTesting()); | 1567 EXPECT_TRUE(webViewHelper.webViewImpl()->fakeDoubleTapAnimationPendingForTes
ting()); |
1541 simulateDoubleTap(webViewImpl(), bottomPoint, scale); | 1568 simulateDoubleTap(webViewHelper.webViewImpl(), bottomPoint, scale); |
1542 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1569 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1543 } | 1570 } |
1544 | 1571 |
1545 TEST_F(WebFrameTest, DivAutoZoomScaleBoundsTest) | 1572 TEST_F(WebFrameTest, DivAutoZoomScaleBoundsTest) |
1546 { | 1573 { |
1547 registerMockedHttpURLLoad("get_scale_bounds_check_for_auto_zoom_test.html"); | 1574 registerMockedHttpURLLoad("get_scale_bounds_check_for_auto_zoom_test.html"); |
1548 | 1575 |
1549 int viewportWidth = 320; | 1576 int viewportWidth = 320; |
1550 int viewportHeight = 480; | 1577 int viewportHeight = 480; |
1551 float doubleTapZoomAlreadyLegibleRatio = 1.2f; | 1578 float doubleTapZoomAlreadyLegibleRatio = 1.2f; |
1552 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "get_scale_bo
unds_check_for_auto_zoom_test.html"); | 1579 FrameTestHelpers::WebViewHelper webViewHelper; |
1553 m_webView->enableFixedLayoutMode(true); | 1580 webViewHelper.initializeAndLoad(m_baseURL + "get_scale_bounds_check_for_auto
_zoom_test.html"); |
1554 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1581 webViewHelper.webView()->enableFixedLayoutMode(true); |
1555 m_webView->setDeviceScaleFactor(1.5f); | 1582 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1556 m_webView->layout(); | 1583 webViewHelper.webView()->setDeviceScaleFactor(1.5f); |
| 1584 webViewHelper.webView()->layout(); |
1557 | 1585 |
1558 webViewImpl()->enableFakePageScaleAnimationForTesting(true); | 1586 webViewHelper.webViewImpl()->enableFakePageScaleAnimationForTesting(true); |
1559 | 1587 |
1560 WebRect div(200, 100, 200, 150); | 1588 WebRect div(200, 100, 200, 150); |
1561 WebPoint doubleTapPoint(div.x + 50, div.y + 50); | 1589 WebPoint doubleTapPoint(div.x + 50, div.y + 50); |
1562 float scale; | 1590 float scale; |
1563 | 1591 |
1564 // Test double tap scale bounds. | 1592 // Test double tap scale bounds. |
1565 // minimumPageScale < doubleTapZoomAlreadyLegibleScale < 1 | 1593 // minimumPageScale < doubleTapZoomAlreadyLegibleScale < 1 |
1566 m_webView->setPageScaleFactorLimits(0.5f, 4); | 1594 webViewHelper.webView()->setPageScaleFactorLimits(0.5f, 4); |
1567 m_webView->layout(); | 1595 webViewHelper.webView()->layout(); |
1568 float doubleTapZoomAlreadyLegibleScale = webViewImpl()->minimumPageScaleFact
or() * doubleTapZoomAlreadyLegibleRatio; | 1596 float doubleTapZoomAlreadyLegibleScale = webViewHelper.webViewImpl()->minimu
mPageScaleFactor() * doubleTapZoomAlreadyLegibleRatio; |
1569 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1597 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1570 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1598 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1571 EXPECT_FLOAT_EQ(1, scale); | 1599 EXPECT_FLOAT_EQ(1, scale); |
1572 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1600 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1573 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1601 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1574 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1602 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1575 EXPECT_FLOAT_EQ(1, scale); | 1603 EXPECT_FLOAT_EQ(1, scale); |
1576 | 1604 |
1577 // Zoom in to reset double_tap_zoom_in_effect flag. | 1605 // Zoom in to reset double_tap_zoom_in_effect flag. |
1578 webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); | 1606 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); |
1579 // 1 < minimumPageScale < doubleTapZoomAlreadyLegibleScale | 1607 // 1 < minimumPageScale < doubleTapZoomAlreadyLegibleScale |
1580 m_webView->setPageScaleFactorLimits(1.1f, 4); | 1608 webViewHelper.webView()->setPageScaleFactorLimits(1.1f, 4); |
1581 m_webView->layout(); | 1609 webViewHelper.webView()->layout(); |
1582 doubleTapZoomAlreadyLegibleScale = webViewImpl()->minimumPageScaleFactor() *
doubleTapZoomAlreadyLegibleRatio; | 1610 doubleTapZoomAlreadyLegibleScale = webViewHelper.webViewImpl()->minimumPageS
caleFactor() * doubleTapZoomAlreadyLegibleRatio; |
1583 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1611 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1584 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1612 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1585 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); | 1613 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); |
1586 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1614 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1587 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1615 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1588 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1616 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1589 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); | 1617 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); |
1590 | 1618 |
1591 // Zoom in to reset double_tap_zoom_in_effect flag. | 1619 // Zoom in to reset double_tap_zoom_in_effect flag. |
1592 webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); | 1620 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); |
1593 // minimumPageScale < 1 < doubleTapZoomAlreadyLegibleScale | 1621 // minimumPageScale < 1 < doubleTapZoomAlreadyLegibleScale |
1594 m_webView->setPageScaleFactorLimits(0.95f, 4); | 1622 webViewHelper.webView()->setPageScaleFactorLimits(0.95f, 4); |
1595 m_webView->layout(); | 1623 webViewHelper.webView()->layout(); |
1596 doubleTapZoomAlreadyLegibleScale = webViewImpl()->minimumPageScaleFactor() *
doubleTapZoomAlreadyLegibleRatio; | 1624 doubleTapZoomAlreadyLegibleScale = webViewHelper.webViewImpl()->minimumPageS
caleFactor() * doubleTapZoomAlreadyLegibleRatio; |
1597 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1625 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1598 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1626 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1599 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); | 1627 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); |
1600 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1628 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1601 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1629 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1602 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1630 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1603 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); | 1631 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); |
1604 } | 1632 } |
1605 | 1633 |
1606 TEST_F(WebFrameTest, DivAutoZoomScaleFontScaleFactorTest) | 1634 TEST_F(WebFrameTest, DivAutoZoomScaleFontScaleFactorTest) |
1607 { | 1635 { |
1608 registerMockedHttpURLLoad("get_scale_bounds_check_for_auto_zoom_test.html"); | 1636 registerMockedHttpURLLoad("get_scale_bounds_check_for_auto_zoom_test.html"); |
1609 | 1637 |
1610 int viewportWidth = 320; | 1638 int viewportWidth = 320; |
1611 int viewportHeight = 480; | 1639 int viewportHeight = 480; |
1612 float doubleTapZoomAlreadyLegibleRatio = 1.2f; | 1640 float doubleTapZoomAlreadyLegibleRatio = 1.2f; |
1613 float textAutosizingFontScaleFactor = 1.13f; | 1641 float textAutosizingFontScaleFactor = 1.13f; |
1614 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "get_scale_bo
unds_check_for_auto_zoom_test.html"); | 1642 FrameTestHelpers::WebViewHelper webViewHelper; |
1615 m_webView->enableFixedLayoutMode(true); | 1643 webViewHelper.initializeAndLoad(m_baseURL + "get_scale_bounds_check_for_auto
_zoom_test.html"); |
1616 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1644 webViewHelper.webView()->enableFixedLayoutMode(true); |
1617 m_webView->layout(); | 1645 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 1646 webViewHelper.webView()->layout(); |
1618 | 1647 |
1619 webViewImpl()->enableFakePageScaleAnimationForTesting(true); | 1648 webViewHelper.webViewImpl()->enableFakePageScaleAnimationForTesting(true); |
1620 webViewImpl()->page()->settings().setTextAutosizingEnabled(true); | 1649 webViewHelper.webViewImpl()->page()->settings().setTextAutosizingEnabled(tru
e); |
1621 webViewImpl()->page()->settings().setTextAutosizingFontScaleFactor(textAutos
izingFontScaleFactor); | 1650 webViewHelper.webViewImpl()->page()->settings().setTextAutosizingFontScaleFa
ctor(textAutosizingFontScaleFactor); |
1622 | 1651 |
1623 WebRect div(200, 100, 200, 150); | 1652 WebRect div(200, 100, 200, 150); |
1624 WebPoint doubleTapPoint(div.x + 50, div.y + 50); | 1653 WebPoint doubleTapPoint(div.x + 50, div.y + 50); |
1625 float scale; | 1654 float scale; |
1626 | 1655 |
1627 // Test double tap scale bounds. | 1656 // Test double tap scale bounds. |
1628 // minimumPageScale < doubleTapZoomAlreadyLegibleScale < 1 < textAutosizingF
ontScaleFactor | 1657 // minimumPageScale < doubleTapZoomAlreadyLegibleScale < 1 < textAutosizingF
ontScaleFactor |
1629 float legibleScale = textAutosizingFontScaleFactor; | 1658 float legibleScale = textAutosizingFontScaleFactor; |
1630 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1659 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1631 float doubleTapZoomAlreadyLegibleScale = webViewImpl()->minimumPageScaleFact
or() * doubleTapZoomAlreadyLegibleRatio; | 1660 float doubleTapZoomAlreadyLegibleScale = webViewHelper.webViewImpl()->minimu
mPageScaleFactor() * doubleTapZoomAlreadyLegibleRatio; |
1632 m_webView->setPageScaleFactorLimits(0.5f, 4); | 1661 webViewHelper.webView()->setPageScaleFactorLimits(0.5f, 4); |
1633 m_webView->layout(); | 1662 webViewHelper.webView()->layout(); |
1634 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1663 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1635 EXPECT_FLOAT_EQ(legibleScale, scale); | 1664 EXPECT_FLOAT_EQ(legibleScale, scale); |
1636 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1665 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1637 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1666 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1638 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1667 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1639 EXPECT_FLOAT_EQ(legibleScale, scale); | 1668 EXPECT_FLOAT_EQ(legibleScale, scale); |
1640 | 1669 |
1641 // Zoom in to reset double_tap_zoom_in_effect flag. | 1670 // Zoom in to reset double_tap_zoom_in_effect flag. |
1642 webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); | 1671 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); |
1643 // 1 < textAutosizingFontScaleFactor < minimumPageScale < doubleTapZoomAlrea
dyLegibleScale | 1672 // 1 < textAutosizingFontScaleFactor < minimumPageScale < doubleTapZoomAlrea
dyLegibleScale |
1644 m_webView->setPageScaleFactorLimits(1.0f, 4); | 1673 webViewHelper.webView()->setPageScaleFactorLimits(1.0f, 4); |
1645 m_webView->layout(); | 1674 webViewHelper.webView()->layout(); |
1646 doubleTapZoomAlreadyLegibleScale = webViewImpl()->minimumPageScaleFactor() *
doubleTapZoomAlreadyLegibleRatio; | 1675 doubleTapZoomAlreadyLegibleScale = webViewHelper.webViewImpl()->minimumPageS
caleFactor() * doubleTapZoomAlreadyLegibleRatio; |
1647 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1676 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1648 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1677 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1649 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); | 1678 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); |
1650 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1679 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1651 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1680 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1652 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1681 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1653 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); | 1682 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); |
1654 | 1683 |
1655 // Zoom in to reset double_tap_zoom_in_effect flag. | 1684 // Zoom in to reset double_tap_zoom_in_effect flag. |
1656 webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); | 1685 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); |
1657 // minimumPageScale < 1 < textAutosizingFontScaleFactor < doubleTapZoomAlrea
dyLegibleScale | 1686 // minimumPageScale < 1 < textAutosizingFontScaleFactor < doubleTapZoomAlrea
dyLegibleScale |
1658 m_webView->setPageScaleFactorLimits(0.95f, 4); | 1687 webViewHelper.webView()->setPageScaleFactorLimits(0.95f, 4); |
1659 m_webView->layout(); | 1688 webViewHelper.webView()->layout(); |
1660 doubleTapZoomAlreadyLegibleScale = webViewImpl()->minimumPageScaleFactor() *
doubleTapZoomAlreadyLegibleRatio; | 1689 doubleTapZoomAlreadyLegibleScale = webViewHelper.webViewImpl()->minimumPageS
caleFactor() * doubleTapZoomAlreadyLegibleRatio; |
1661 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1690 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1662 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1691 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1663 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); | 1692 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); |
1664 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1693 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1665 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1694 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1666 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1695 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1667 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); | 1696 EXPECT_FLOAT_EQ(doubleTapZoomAlreadyLegibleScale, scale); |
1668 | 1697 |
1669 // Zoom in to reset double_tap_zoom_in_effect flag. | 1698 // Zoom in to reset double_tap_zoom_in_effect flag. |
1670 webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); | 1699 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(), 1.1f); |
1671 // minimumPageScale < 1 < doubleTapZoomAlreadyLegibleScale < textAutosizingF
ontScaleFactor | 1700 // minimumPageScale < 1 < doubleTapZoomAlreadyLegibleScale < textAutosizingF
ontScaleFactor |
1672 m_webView->setPageScaleFactorLimits(0.9f, 4); | 1701 webViewHelper.webView()->setPageScaleFactorLimits(0.9f, 4); |
1673 m_webView->layout(); | 1702 webViewHelper.webView()->layout(); |
1674 doubleTapZoomAlreadyLegibleScale = webViewImpl()->minimumPageScaleFactor() *
doubleTapZoomAlreadyLegibleRatio; | 1703 doubleTapZoomAlreadyLegibleScale = webViewHelper.webViewImpl()->minimumPageS
caleFactor() * doubleTapZoomAlreadyLegibleRatio; |
1675 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1704 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1676 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1705 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1677 EXPECT_FLOAT_EQ(legibleScale, scale); | 1706 EXPECT_FLOAT_EQ(legibleScale, scale); |
1678 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1707 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1679 EXPECT_FLOAT_EQ(webViewImpl()->minimumPageScaleFactor(), scale); | 1708 EXPECT_FLOAT_EQ(webViewHelper.webViewImpl()->minimumPageScaleFactor(), scale
); |
1680 simulateDoubleTap(webViewImpl(), doubleTapPoint, scale); | 1709 simulateDoubleTap(webViewHelper.webViewImpl(), doubleTapPoint, scale); |
1681 EXPECT_FLOAT_EQ(legibleScale, scale); | 1710 EXPECT_FLOAT_EQ(legibleScale, scale); |
1682 } | 1711 } |
1683 | 1712 |
1684 TEST_F(WebFrameTest, DivMultipleTargetZoomMultipleDivsTest) | 1713 TEST_F(WebFrameTest, DivMultipleTargetZoomMultipleDivsTest) |
1685 { | 1714 { |
1686 registerMockedHttpURLLoad("get_multiple_divs_for_auto_zoom_test.html"); | 1715 registerMockedHttpURLLoad("get_multiple_divs_for_auto_zoom_test.html"); |
1687 | 1716 |
1688 const float deviceScaleFactor = 2.0f; | 1717 const float deviceScaleFactor = 2.0f; |
1689 int viewportWidth = 640 / deviceScaleFactor; | 1718 int viewportWidth = 640 / deviceScaleFactor; |
1690 int viewportHeight = 1280 / deviceScaleFactor; | 1719 int viewportHeight = 1280 / deviceScaleFactor; |
1691 float doubleTapZoomAlreadyLegibleRatio = 1.2f; | 1720 float doubleTapZoomAlreadyLegibleRatio = 1.2f; |
1692 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "get_multiple
_divs_for_auto_zoom_test.html"); | 1721 FrameTestHelpers::WebViewHelper webViewHelper; |
1693 m_webView->enableFixedLayoutMode(true); | 1722 webViewHelper.initializeAndLoad(m_baseURL + "get_multiple_divs_for_auto_zoom
_test.html"); |
1694 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1723 webViewHelper.webView()->enableFixedLayoutMode(true); |
1695 m_webView->setPageScaleFactorLimits(0.5f, 4); | 1724 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1696 m_webView->setDeviceScaleFactor(deviceScaleFactor); | 1725 webViewHelper.webView()->setPageScaleFactorLimits(0.5f, 4); |
1697 m_webView->setPageScaleFactor(0.5f, WebPoint(0, 0)); | 1726 webViewHelper.webView()->setDeviceScaleFactor(deviceScaleFactor); |
1698 m_webView->layout(); | 1727 webViewHelper.webView()->setPageScaleFactor(0.5f, WebPoint(0, 0)); |
| 1728 webViewHelper.webView()->layout(); |
1699 | 1729 |
1700 webViewImpl()->enableFakePageScaleAnimationForTesting(true); | 1730 webViewHelper.webViewImpl()->enableFakePageScaleAnimationForTesting(true); |
1701 | 1731 |
1702 WebRect viewportRect(0, 0, viewportWidth, viewportHeight); | 1732 WebRect viewportRect(0, 0, viewportWidth, viewportHeight); |
1703 WebRect topDiv(200, 100, 200, 150); | 1733 WebRect topDiv(200, 100, 200, 150); |
1704 WebRect bottomDiv(200, 300, 200, 150); | 1734 WebRect bottomDiv(200, 300, 200, 150); |
1705 float scale; | 1735 float scale; |
1706 setScaleAndScrollAndLayout(webViewImpl(), WebPoint(0, 0), (webViewImpl()->mi
nimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyLegibleRatio) / 2); | 1736 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), WebPoint(0, 0), (web
ViewHelper.webViewImpl()->minimumPageScaleFactor()) * (1 + doubleTapZoomAlreadyL
egibleRatio) / 2); |
1707 | 1737 |
1708 simulateMultiTargetZoom(webViewImpl(), topDiv, scale); | 1738 simulateMultiTargetZoom(webViewHelper.webViewImpl(), topDiv, scale); |
1709 EXPECT_FLOAT_EQ(1, scale); | 1739 EXPECT_FLOAT_EQ(1, scale); |
1710 simulateMultiTargetZoom(webViewImpl(), bottomDiv, scale); | 1740 simulateMultiTargetZoom(webViewHelper.webViewImpl(), bottomDiv, scale); |
1711 EXPECT_FLOAT_EQ(1, scale); | 1741 EXPECT_FLOAT_EQ(1, scale); |
1712 simulateMultiTargetZoom(webViewImpl(), viewportRect, scale); | 1742 simulateMultiTargetZoom(webViewHelper.webViewImpl(), viewportRect, scale); |
1713 EXPECT_FLOAT_EQ(1, scale); | 1743 EXPECT_FLOAT_EQ(1, scale); |
1714 webViewImpl()->setPageScaleFactor(webViewImpl()->minimumPageScaleFactor(), W
ebPoint(0, 0)); | 1744 webViewHelper.webViewImpl()->setPageScaleFactor(webViewHelper.webViewImpl()-
>minimumPageScaleFactor(), WebPoint(0, 0)); |
1715 simulateMultiTargetZoom(webViewImpl(), topDiv, scale); | 1745 simulateMultiTargetZoom(webViewHelper.webViewImpl(), topDiv, scale); |
1716 EXPECT_FLOAT_EQ(1, scale); | 1746 EXPECT_FLOAT_EQ(1, scale); |
1717 } | 1747 } |
1718 | 1748 |
1719 TEST_F(WebFrameTest, DivScrollIntoEditableTest) | 1749 TEST_F(WebFrameTest, DivScrollIntoEditableTest) |
1720 { | 1750 { |
1721 registerMockedHttpURLLoad("get_scale_for_zoom_into_editable_test.html"); | 1751 registerMockedHttpURLLoad("get_scale_for_zoom_into_editable_test.html"); |
1722 | 1752 |
1723 int viewportWidth = 450; | 1753 int viewportWidth = 450; |
1724 int viewportHeight = 300; | 1754 int viewportHeight = 300; |
1725 float leftBoxRatio = 0.3f; | 1755 float leftBoxRatio = 0.3f; |
1726 int caretPadding = 10; | 1756 int caretPadding = 10; |
1727 float minReadableCaretHeight = 18.0f; | 1757 float minReadableCaretHeight = 18.0f; |
1728 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "get_scale_fo
r_zoom_into_editable_test.html"); | 1758 FrameTestHelpers::WebViewHelper webViewHelper; |
1729 m_webView->enableFixedLayoutMode(true); | 1759 webViewHelper.initializeAndLoad(m_baseURL + "get_scale_for_zoom_into_editabl
e_test.html"); |
1730 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1760 webViewHelper.webView()->enableFixedLayoutMode(true); |
1731 m_webView->setPageScaleFactorLimits(1, 4); | 1761 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1732 m_webView->layout(); | 1762 webViewHelper.webView()->setPageScaleFactorLimits(1, 4); |
1733 m_webView->setDeviceScaleFactor(1.5f); | 1763 webViewHelper.webView()->layout(); |
1734 m_webView->settings()->setAutoZoomFocusedNodeToLegibleScale(true); | 1764 webViewHelper.webView()->setDeviceScaleFactor(1.5f); |
| 1765 webViewHelper.webView()->settings()->setAutoZoomFocusedNodeToLegibleScale(tr
ue); |
1735 | 1766 |
1736 webViewImpl()->enableFakePageScaleAnimationForTesting(true); | 1767 webViewHelper.webViewImpl()->enableFakePageScaleAnimationForTesting(true); |
1737 | 1768 |
1738 WebRect editBoxWithText(200, 200, 250, 20); | 1769 WebRect editBoxWithText(200, 200, 250, 20); |
1739 WebRect editBoxWithNoText(200, 250, 250, 20); | 1770 WebRect editBoxWithNoText(200, 250, 250, 20); |
1740 | 1771 |
1741 // Test scrolling the focused node | 1772 // Test scrolling the focused node |
1742 // The edit box is shorter and narrower than the viewport when legible. | 1773 // The edit box is shorter and narrower than the viewport when legible. |
1743 m_webView->advanceFocus(false); | 1774 webViewHelper.webView()->advanceFocus(false); |
1744 // Set the caret to the end of the input box. | 1775 // Set the caret to the end of the input box. |
1745 m_webView->mainFrame()->document().getElementById("EditBoxWithText").to<WebI
nputElement>().setSelectionRange(1000, 1000); | 1776 webViewHelper.webView()->mainFrame()->document().getElementById("EditBoxWith
Text").to<WebInputElement>().setSelectionRange(1000, 1000); |
1746 setScaleAndScrollAndLayout(m_webView, WebPoint(0, 0), 1); | 1777 setScaleAndScrollAndLayout(webViewHelper.webView(), WebPoint(0, 0), 1); |
1747 WebRect rect, caret; | 1778 WebRect rect, caret; |
1748 webViewImpl()->selectionBounds(caret, rect); | 1779 webViewHelper.webViewImpl()->selectionBounds(caret, rect); |
1749 | 1780 |
1750 float scale; | 1781 float scale; |
1751 WebCore::IntPoint scroll; | 1782 WebCore::IntPoint scroll; |
1752 bool needAnimation; | 1783 bool needAnimation; |
1753 webViewImpl()->computeScaleAndScrollForFocusedNode(webViewImpl()->focusedEle
ment(), scale, scroll, needAnimation); | 1784 webViewHelper.webViewImpl()->computeScaleAndScrollForFocusedNode(webViewHelp
er.webViewImpl()->focusedElement(), scale, scroll, needAnimation); |
1754 EXPECT_TRUE(needAnimation); | 1785 EXPECT_TRUE(needAnimation); |
1755 // The edit box should be left aligned with a margin for possible label. | 1786 // The edit box should be left aligned with a margin for possible label. |
1756 int hScroll = editBoxWithText.x - leftBoxRatio * viewportWidth / scale; | 1787 int hScroll = editBoxWithText.x - leftBoxRatio * viewportWidth / scale; |
1757 EXPECT_NEAR(hScroll, scroll.x(), 1); | 1788 EXPECT_NEAR(hScroll, scroll.x(), 1); |
1758 int vScroll = editBoxWithText.y - (viewportHeight / scale - editBoxWithText.
height) / 2; | 1789 int vScroll = editBoxWithText.y - (viewportHeight / scale - editBoxWithText.
height) / 2; |
1759 EXPECT_NEAR(vScroll, scroll.y(), 1); | 1790 EXPECT_NEAR(vScroll, scroll.y(), 1); |
1760 EXPECT_NEAR(minReadableCaretHeight / caret.height, scale, 0.1); | 1791 EXPECT_NEAR(minReadableCaretHeight / caret.height, scale, 0.1); |
1761 | 1792 |
1762 // The edit box is wider than the viewport when legible. | 1793 // The edit box is wider than the viewport when legible. |
1763 viewportWidth = 200; | 1794 viewportWidth = 200; |
1764 viewportHeight = 150; | 1795 viewportHeight = 150; |
1765 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 1796 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1766 setScaleAndScrollAndLayout(m_webView, WebPoint(0, 0), 1); | 1797 setScaleAndScrollAndLayout(webViewHelper.webView(), WebPoint(0, 0), 1); |
1767 webViewImpl()->selectionBounds(caret, rect); | 1798 webViewHelper.webViewImpl()->selectionBounds(caret, rect); |
1768 webViewImpl()->computeScaleAndScrollForFocusedNode(webViewImpl()->focusedEle
ment(), scale, scroll, needAnimation); | 1799 webViewHelper.webViewImpl()->computeScaleAndScrollForFocusedNode(webViewHelp
er.webViewImpl()->focusedElement(), scale, scroll, needAnimation); |
1769 EXPECT_TRUE(needAnimation); | 1800 EXPECT_TRUE(needAnimation); |
1770 // The caret should be right aligned since the caret would be offscreen when
the edit box is left aligned. | 1801 // The caret should be right aligned since the caret would be offscreen when
the edit box is left aligned. |
1771 hScroll = caret.x + caret.width + caretPadding - viewportWidth / scale; | 1802 hScroll = caret.x + caret.width + caretPadding - viewportWidth / scale; |
1772 EXPECT_NEAR(hScroll, scroll.x(), 1); | 1803 EXPECT_NEAR(hScroll, scroll.x(), 1); |
1773 EXPECT_NEAR(minReadableCaretHeight / caret.height, scale, 0.1); | 1804 EXPECT_NEAR(minReadableCaretHeight / caret.height, scale, 0.1); |
1774 | 1805 |
1775 setScaleAndScrollAndLayout(m_webView, WebPoint(0, 0), 1); | 1806 setScaleAndScrollAndLayout(webViewHelper.webView(), WebPoint(0, 0), 1); |
1776 // Move focus to edit box with text. | 1807 // Move focus to edit box with text. |
1777 m_webView->advanceFocus(false); | 1808 webViewHelper.webView()->advanceFocus(false); |
1778 webViewImpl()->selectionBounds(caret, rect); | 1809 webViewHelper.webViewImpl()->selectionBounds(caret, rect); |
1779 webViewImpl()->computeScaleAndScrollForFocusedNode(webViewImpl()->focusedEle
ment(), scale, scroll, needAnimation); | 1810 webViewHelper.webViewImpl()->computeScaleAndScrollForFocusedNode(webViewHelp
er.webViewImpl()->focusedElement(), scale, scroll, needAnimation); |
1780 EXPECT_TRUE(needAnimation); | 1811 EXPECT_TRUE(needAnimation); |
1781 // The edit box should be left aligned. | 1812 // The edit box should be left aligned. |
1782 hScroll = editBoxWithNoText.x; | 1813 hScroll = editBoxWithNoText.x; |
1783 EXPECT_NEAR(hScroll, scroll.x(), 1); | 1814 EXPECT_NEAR(hScroll, scroll.x(), 1); |
1784 vScroll = editBoxWithNoText.y - (viewportHeight / scale - editBoxWithNoText.
height) / 2; | 1815 vScroll = editBoxWithNoText.y - (viewportHeight / scale - editBoxWithNoText.
height) / 2; |
1785 EXPECT_NEAR(vScroll, scroll.y(), 1); | 1816 EXPECT_NEAR(vScroll, scroll.y(), 1); |
1786 EXPECT_NEAR(minReadableCaretHeight / caret.height, scale, 0.1); | 1817 EXPECT_NEAR(minReadableCaretHeight / caret.height, scale, 0.1); |
1787 | 1818 |
1788 setScaleAndScrollAndLayout(webViewImpl(), scroll, scale); | 1819 setScaleAndScrollAndLayout(webViewHelper.webViewImpl(), scroll, scale); |
1789 | 1820 |
1790 // Move focus back to the first edit box. | 1821 // Move focus back to the first edit box. |
1791 m_webView->advanceFocus(true); | 1822 webViewHelper.webView()->advanceFocus(true); |
1792 webViewImpl()->computeScaleAndScrollForFocusedNode(webViewImpl()->focusedEle
ment(), scale, scroll, needAnimation); | 1823 webViewHelper.webViewImpl()->computeScaleAndScrollForFocusedNode(webViewHelp
er.webViewImpl()->focusedElement(), scale, scroll, needAnimation); |
1793 // The position should have stayed the same since this box was already on sc
reen with the right scale. | 1824 // The position should have stayed the same since this box was already on sc
reen with the right scale. |
1794 EXPECT_FALSE(needAnimation); | 1825 EXPECT_FALSE(needAnimation); |
1795 } | 1826 } |
1796 | 1827 |
1797 class TestReloadDoesntRedirectWebFrameClient : public WebFrameClient { | 1828 class TestReloadDoesntRedirectWebFrameClient : public WebFrameClient { |
1798 public: | 1829 public: |
1799 virtual WebNavigationPolicy decidePolicyForNavigation( | 1830 virtual WebNavigationPolicy decidePolicyForNavigation( |
1800 WebFrame*, WebDataSource::ExtraData*, const WebURLRequest&, WebNavigatio
nType, | 1831 WebFrame*, WebDataSource::ExtraData*, const WebURLRequest&, WebNavigatio
nType, |
1801 WebNavigationPolicy defaultPolicy, bool isRedirect) OVERRIDE | 1832 WebNavigationPolicy defaultPolicy, bool isRedirect) OVERRIDE |
1802 { | 1833 { |
1803 EXPECT_FALSE(isRedirect); | 1834 EXPECT_FALSE(isRedirect); |
1804 return WebNavigationPolicyCurrentTab; | 1835 return WebNavigationPolicyCurrentTab; |
1805 } | 1836 } |
1806 }; | 1837 }; |
1807 | 1838 |
1808 TEST_F(WebFrameTest, ReloadDoesntSetRedirect) | 1839 TEST_F(WebFrameTest, ReloadDoesntSetRedirect) |
1809 { | 1840 { |
1810 // Test for case in http://crbug.com/73104. Reloading a frame very quickly | 1841 // Test for case in http://crbug.com/73104. Reloading a frame very quickly |
1811 // would sometimes call decidePolicyForNavigation with isRedirect=true | 1842 // would sometimes call decidePolicyForNavigation with isRedirect=true |
1812 registerMockedHttpURLLoad("form.html"); | 1843 registerMockedHttpURLLoad("form.html"); |
1813 | 1844 |
1814 TestReloadDoesntRedirectWebFrameClient webFrameClient; | 1845 TestReloadDoesntRedirectWebFrameClient webFrameClient; |
1815 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "form.html",
false, &webFrameClient); | 1846 FrameTestHelpers::WebViewHelper webViewHelper; |
| 1847 webViewHelper.initializeAndLoad(m_baseURL + "form.html", false, &webFrameCli
ent); |
1816 | 1848 |
1817 m_webView->mainFrame()->reload(true); | 1849 webViewHelper.webView()->mainFrame()->reload(true); |
1818 // start reload before request is delivered. | 1850 // start reload before request is delivered. |
1819 m_webView->mainFrame()->reload(true); | 1851 webViewHelper.webView()->mainFrame()->reload(true); |
1820 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 1852 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1821 | |
1822 m_webView->close(); | |
1823 m_webView = 0; | |
1824 } | 1853 } |
1825 | 1854 |
1826 TEST_F(WebFrameTest, ReloadWithOverrideURLPreservesState) | 1855 TEST_F(WebFrameTest, ReloadWithOverrideURLPreservesState) |
1827 { | 1856 { |
1828 const std::string firstURL = "find.html"; | 1857 const std::string firstURL = "find.html"; |
1829 const std::string secondURL = "form.html"; | 1858 const std::string secondURL = "form.html"; |
1830 const std::string thirdURL = "history.html"; | 1859 const std::string thirdURL = "history.html"; |
1831 const float pageScaleFactor = 1.1684f; | 1860 const float pageScaleFactor = 1.1684f; |
1832 const int pageWidth = 640; | 1861 const int pageWidth = 640; |
1833 const int pageHeight = 480; | 1862 const int pageHeight = 480; |
1834 | 1863 |
1835 registerMockedHttpURLLoad(firstURL); | 1864 registerMockedHttpURLLoad(firstURL); |
1836 registerMockedHttpURLLoad(secondURL); | 1865 registerMockedHttpURLLoad(secondURL); |
1837 registerMockedHttpURLLoad(thirdURL); | 1866 registerMockedHttpURLLoad(thirdURL); |
1838 | 1867 |
1839 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + firstURL, tru
e); | 1868 FrameTestHelpers::WebViewHelper webViewHelper; |
1840 webViewImpl()->resize(WebSize(pageWidth, pageHeight)); | 1869 webViewHelper.initializeAndLoad(m_baseURL + firstURL, true); |
1841 webViewImpl()->mainFrame()->setScrollOffset(WebSize(pageWidth / 4, pageHeigh
t / 4)); | 1870 webViewHelper.webViewImpl()->resize(WebSize(pageWidth, pageHeight)); |
1842 webViewImpl()->setPageScaleFactorPreservingScrollOffset(pageScaleFactor); | 1871 webViewHelper.webViewImpl()->mainFrame()->setScrollOffset(WebSize(pageWidth
/ 4, pageHeight / 4)); |
| 1872 webViewHelper.webViewImpl()->setPageScaleFactorPreservingScrollOffset(pageSc
aleFactor); |
1843 | 1873 |
1844 WebSize previousOffset = webViewImpl()->mainFrame()->scrollOffset(); | 1874 WebSize previousOffset = webViewHelper.webViewImpl()->mainFrame()->scrollOff
set(); |
1845 float previousScale = webViewImpl()->pageScaleFactor(); | 1875 float previousScale = webViewHelper.webViewImpl()->pageScaleFactor(); |
1846 | 1876 |
1847 // Reload the page using the cache. | 1877 // Reload the page using the cache. |
1848 webViewImpl()->mainFrame()->reloadWithOverrideURL(toKURL(m_baseURL + secondU
RL), false); | 1878 webViewHelper.webViewImpl()->mainFrame()->reloadWithOverrideURL(toKURL(m_bas
eURL + secondURL), false); |
1849 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 1879 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1850 ASSERT_EQ(previousOffset, webViewImpl()->mainFrame()->scrollOffset()); | 1880 ASSERT_EQ(previousOffset, webViewHelper.webViewImpl()->mainFrame()->scrollOf
fset()); |
1851 ASSERT_EQ(previousScale, webViewImpl()->pageScaleFactor()); | 1881 ASSERT_EQ(previousScale, webViewHelper.webViewImpl()->pageScaleFactor()); |
1852 | 1882 |
1853 // Reload the page while ignoring the cache. | 1883 // Reload the page while ignoring the cache. |
1854 webViewImpl()->mainFrame()->reloadWithOverrideURL(toKURL(m_baseURL + thirdUR
L), true); | 1884 webViewHelper.webViewImpl()->mainFrame()->reloadWithOverrideURL(toKURL(m_bas
eURL + thirdURL), true); |
1855 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 1885 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1856 ASSERT_EQ(previousOffset, webViewImpl()->mainFrame()->scrollOffset()); | 1886 ASSERT_EQ(previousOffset, webViewHelper.webViewImpl()->mainFrame()->scrollOf
fset()); |
1857 ASSERT_EQ(previousScale, webViewImpl()->pageScaleFactor()); | 1887 ASSERT_EQ(previousScale, webViewHelper.webViewImpl()->pageScaleFactor()); |
1858 } | 1888 } |
1859 | 1889 |
1860 class TestReloadWhileProvisionalFrameClient : public WebFrameClient { | 1890 class TestReloadWhileProvisionalFrameClient : public WebFrameClient { |
1861 }; | 1891 }; |
1862 | 1892 |
1863 TEST_F(WebFrameTest, ReloadWhileProvisional) | 1893 TEST_F(WebFrameTest, ReloadWhileProvisional) |
1864 { | 1894 { |
1865 // Test that reloading while the previous load is still pending does not cau
se the initial | 1895 // Test that reloading while the previous load is still pending does not cau
se the initial |
1866 // request to get lost. | 1896 // request to get lost. |
1867 registerMockedHttpURLLoad("fixed_layout.html"); | 1897 registerMockedHttpURLLoad("fixed_layout.html"); |
1868 | 1898 |
1869 TestReloadWhileProvisionalFrameClient webFrameClient; | 1899 TestReloadWhileProvisionalFrameClient webFrameClient; |
1870 m_webView = FrameTestHelpers::createWebView(false, &webFrameClient); | 1900 FrameTestHelpers::WebViewHelper webViewHelper; |
1871 FrameTestHelpers::loadFrame(m_webView->mainFrame(), m_baseURL + "fixed_layou
t.html"); | 1901 webViewHelper.initialize(false, &webFrameClient); |
| 1902 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "fixed_layout.html"); |
1872 // start reload before first request is delivered. | 1903 // start reload before first request is delivered. |
1873 m_webView->mainFrame()->reload(true); | 1904 webViewHelper.webView()->mainFrame()->reload(true); |
1874 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 1905 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1875 ASSERT_EQ(WebURL(toKURL(m_baseURL + "fixed_layout.html")), | 1906 ASSERT_EQ(WebURL(toKURL(m_baseURL + "fixed_layout.html")), |
1876 m_webView->mainFrame()->dataSource()->request().url()); | 1907 webViewHelper.webView()->mainFrame()->dataSource()->request().url()); |
1877 | |
1878 m_webView->close(); | |
1879 m_webView = 0; | |
1880 } | 1908 } |
1881 | 1909 |
1882 TEST_F(WebFrameTest, IframeRedirect) | 1910 TEST_F(WebFrameTest, IframeRedirect) |
1883 { | 1911 { |
1884 registerMockedHttpURLLoad("iframe_redirect.html"); | 1912 registerMockedHttpURLLoad("iframe_redirect.html"); |
1885 registerMockedHttpURLLoad("visible_iframe.html"); | 1913 registerMockedHttpURLLoad("visible_iframe.html"); |
1886 | 1914 |
1887 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "iframe_redir
ect.html", true); | 1915 FrameTestHelpers::WebViewHelper webViewHelper; |
| 1916 webViewHelper.initializeAndLoad(m_baseURL + "iframe_redirect.html", true); |
1888 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); /
/ Load the iframe. | 1917 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); /
/ Load the iframe. |
1889 | 1918 |
1890 WebFrame* iframe = m_webView->findFrameByName(WebString::fromUTF8("ifr")); | 1919 WebFrame* iframe = webViewHelper.webView()->findFrameByName(WebString::fromU
TF8("ifr")); |
1891 ASSERT_TRUE(iframe); | 1920 ASSERT_TRUE(iframe); |
1892 WebDataSource* iframeDataSource = iframe->dataSource(); | 1921 WebDataSource* iframeDataSource = iframe->dataSource(); |
1893 ASSERT_TRUE(iframeDataSource); | 1922 ASSERT_TRUE(iframeDataSource); |
1894 WebVector<WebURL> redirects; | 1923 WebVector<WebURL> redirects; |
1895 iframeDataSource->redirectChain(redirects); | 1924 iframeDataSource->redirectChain(redirects); |
1896 ASSERT_EQ(2U, redirects.size()); | 1925 ASSERT_EQ(2U, redirects.size()); |
1897 EXPECT_EQ(toKURL("about:blank"), toKURL(redirects[0].spec().data())); | 1926 EXPECT_EQ(toKURL("about:blank"), toKURL(redirects[0].spec().data())); |
1898 EXPECT_EQ(toKURL("http://www.test.com/visible_iframe.html"), toKURL(redirect
s[1].spec().data())); | 1927 EXPECT_EQ(toKURL("http://www.test.com/visible_iframe.html"), toKURL(redirect
s[1].spec().data())); |
1899 } | 1928 } |
1900 | 1929 |
1901 TEST_F(WebFrameTest, ClearFocusedNodeTest) | 1930 TEST_F(WebFrameTest, ClearFocusedNodeTest) |
1902 { | 1931 { |
1903 registerMockedHttpURLLoad("iframe_clear_focused_node_test.html"); | 1932 registerMockedHttpURLLoad("iframe_clear_focused_node_test.html"); |
1904 registerMockedHttpURLLoad("autofocus_input_field_iframe.html"); | 1933 registerMockedHttpURLLoad("autofocus_input_field_iframe.html"); |
1905 | 1934 |
1906 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "iframe_clear
_focused_node_test.html", true); | 1935 FrameTestHelpers::WebViewHelper webViewHelper; |
| 1936 webViewHelper.initializeAndLoad(m_baseURL + "iframe_clear_focused_node_test.
html", true); |
1907 | 1937 |
1908 // Clear the focused node. | 1938 // Clear the focused node. |
1909 m_webView->clearFocusedNode(); | 1939 webViewHelper.webView()->clearFocusedNode(); |
1910 | 1940 |
1911 // Now retrieve the FocusedNode and test it should be null. | 1941 // Now retrieve the FocusedNode and test it should be null. |
1912 EXPECT_EQ(0, webViewImpl()->focusedElement()); | 1942 EXPECT_EQ(0, webViewHelper.webViewImpl()->focusedElement()); |
1913 } | 1943 } |
1914 | 1944 |
1915 // Implementation of WebFrameClient that tracks the v8 contexts that are created | 1945 // Implementation of WebFrameClient that tracks the v8 contexts that are created |
1916 // and destroyed for verification. | 1946 // and destroyed for verification. |
1917 class ContextLifetimeTestWebFrameClient : public WebFrameClient { | 1947 class ContextLifetimeTestWebFrameClient : public WebFrameClient { |
1918 public: | 1948 public: |
1919 struct Notification { | 1949 struct Notification { |
1920 public: | 1950 public: |
1921 Notification(WebFrame* frame, v8::Handle<v8::Context> context, int world
Id) | 1951 Notification(WebFrame* frame, v8::Handle<v8::Context> context, int world
Id) |
1922 : frame(frame) | 1952 : frame(frame) |
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1975 // TODO(aa): Deflake this test. | 2005 // TODO(aa): Deflake this test. |
1976 TEST_F(WebFrameTest, FLAKY_ContextNotificationsLoadUnload) | 2006 TEST_F(WebFrameTest, FLAKY_ContextNotificationsLoadUnload) |
1977 { | 2007 { |
1978 v8::HandleScope handleScope(v8::Isolate::GetCurrent()); | 2008 v8::HandleScope handleScope(v8::Isolate::GetCurrent()); |
1979 | 2009 |
1980 registerMockedHttpURLLoad("context_notifications_test.html"); | 2010 registerMockedHttpURLLoad("context_notifications_test.html"); |
1981 registerMockedHttpURLLoad("context_notifications_test_frame.html"); | 2011 registerMockedHttpURLLoad("context_notifications_test_frame.html"); |
1982 | 2012 |
1983 // Load a frame with an iframe, make sure we get the right create notificati
ons. | 2013 // Load a frame with an iframe, make sure we get the right create notificati
ons. |
1984 ContextLifetimeTestWebFrameClient webFrameClient; | 2014 ContextLifetimeTestWebFrameClient webFrameClient; |
1985 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "context_noti
fications_test.html", true, &webFrameClient); | 2015 FrameTestHelpers::WebViewHelper webViewHelper; |
| 2016 webViewHelper.initializeAndLoad(m_baseURL + "context_notifications_test.html
", true, &webFrameClient); |
1986 | 2017 |
1987 WebFrame* mainFrame = m_webView->mainFrame(); | 2018 WebFrame* mainFrame = webViewHelper.webView()->mainFrame(); |
1988 WebFrame* childFrame = mainFrame->firstChild(); | 2019 WebFrame* childFrame = mainFrame->firstChild(); |
1989 | 2020 |
1990 ASSERT_EQ(2u, webFrameClient.createNotifications.size()); | 2021 ASSERT_EQ(2u, webFrameClient.createNotifications.size()); |
1991 EXPECT_EQ(0u, webFrameClient.releaseNotifications.size()); | 2022 EXPECT_EQ(0u, webFrameClient.releaseNotifications.size()); |
1992 | 2023 |
1993 ContextLifetimeTestWebFrameClient::Notification* firstCreateNotification = w
ebFrameClient.createNotifications[0]; | 2024 ContextLifetimeTestWebFrameClient::Notification* firstCreateNotification = w
ebFrameClient.createNotifications[0]; |
1994 ContextLifetimeTestWebFrameClient::Notification* secondCreateNotification =
webFrameClient.createNotifications[1]; | 2025 ContextLifetimeTestWebFrameClient::Notification* secondCreateNotification =
webFrameClient.createNotifications[1]; |
1995 | 2026 |
1996 EXPECT_EQ(mainFrame, firstCreateNotification->frame); | 2027 EXPECT_EQ(mainFrame, firstCreateNotification->frame); |
1997 EXPECT_EQ(mainFrame->mainWorldScriptContext(), firstCreateNotification->cont
ext); | 2028 EXPECT_EQ(mainFrame->mainWorldScriptContext(), firstCreateNotification->cont
ext); |
1998 EXPECT_EQ(0, firstCreateNotification->worldId); | 2029 EXPECT_EQ(0, firstCreateNotification->worldId); |
1999 | 2030 |
2000 EXPECT_EQ(childFrame, secondCreateNotification->frame); | 2031 EXPECT_EQ(childFrame, secondCreateNotification->frame); |
2001 EXPECT_EQ(childFrame->mainWorldScriptContext(), secondCreateNotification->co
ntext); | 2032 EXPECT_EQ(childFrame->mainWorldScriptContext(), secondCreateNotification->co
ntext); |
2002 EXPECT_EQ(0, secondCreateNotification->worldId); | 2033 EXPECT_EQ(0, secondCreateNotification->worldId); |
2003 | 2034 |
2004 // Close the view. We should get two release notifications that are exactly
the same as the create ones, in reverse order. | 2035 // Close the view. We should get two release notifications that are exactly
the same as the create ones, in reverse order. |
2005 m_webView->close(); | 2036 webViewHelper.reset(); |
2006 m_webView = 0; | |
2007 | 2037 |
2008 ASSERT_EQ(2u, webFrameClient.releaseNotifications.size()); | 2038 ASSERT_EQ(2u, webFrameClient.releaseNotifications.size()); |
2009 ContextLifetimeTestWebFrameClient::Notification* firstReleaseNotification =
webFrameClient.releaseNotifications[0]; | 2039 ContextLifetimeTestWebFrameClient::Notification* firstReleaseNotification =
webFrameClient.releaseNotifications[0]; |
2010 ContextLifetimeTestWebFrameClient::Notification* secondReleaseNotification =
webFrameClient.releaseNotifications[1]; | 2040 ContextLifetimeTestWebFrameClient::Notification* secondReleaseNotification =
webFrameClient.releaseNotifications[1]; |
2011 | 2041 |
2012 ASSERT_TRUE(firstCreateNotification->Equals(secondReleaseNotification)); | 2042 ASSERT_TRUE(firstCreateNotification->Equals(secondReleaseNotification)); |
2013 ASSERT_TRUE(secondCreateNotification->Equals(firstReleaseNotification)); | 2043 ASSERT_TRUE(secondCreateNotification->Equals(firstReleaseNotification)); |
2014 } | 2044 } |
2015 | 2045 |
2016 TEST_F(WebFrameTest, ContextNotificationsReload) | 2046 TEST_F(WebFrameTest, ContextNotificationsReload) |
2017 { | 2047 { |
2018 v8::HandleScope handleScope(v8::Isolate::GetCurrent()); | 2048 v8::HandleScope handleScope(v8::Isolate::GetCurrent()); |
2019 | 2049 |
2020 registerMockedHttpURLLoad("context_notifications_test.html"); | 2050 registerMockedHttpURLLoad("context_notifications_test.html"); |
2021 registerMockedHttpURLLoad("context_notifications_test_frame.html"); | 2051 registerMockedHttpURLLoad("context_notifications_test_frame.html"); |
2022 | 2052 |
2023 ContextLifetimeTestWebFrameClient webFrameClient; | 2053 ContextLifetimeTestWebFrameClient webFrameClient; |
2024 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "context_noti
fications_test.html", true, &webFrameClient); | 2054 FrameTestHelpers::WebViewHelper webViewHelper; |
| 2055 webViewHelper.initializeAndLoad(m_baseURL + "context_notifications_test.html
", true, &webFrameClient); |
2025 | 2056 |
2026 // Refresh, we should get two release notifications and two more create noti
fications. | 2057 // Refresh, we should get two release notifications and two more create noti
fications. |
2027 m_webView->mainFrame()->reload(false); | 2058 webViewHelper.webView()->mainFrame()->reload(false); |
2028 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 2059 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
2029 ASSERT_EQ(4u, webFrameClient.createNotifications.size()); | 2060 ASSERT_EQ(4u, webFrameClient.createNotifications.size()); |
2030 ASSERT_EQ(2u, webFrameClient.releaseNotifications.size()); | 2061 ASSERT_EQ(2u, webFrameClient.releaseNotifications.size()); |
2031 | 2062 |
2032 // The two release notifications we got should be exactly the same as the fi
rst two create notifications. | 2063 // The two release notifications we got should be exactly the same as the fi
rst two create notifications. |
2033 for (size_t i = 0; i < webFrameClient.releaseNotifications.size(); ++i) { | 2064 for (size_t i = 0; i < webFrameClient.releaseNotifications.size(); ++i) { |
2034 EXPECT_TRUE(webFrameClient.releaseNotifications[i]->Equals( | 2065 EXPECT_TRUE(webFrameClient.releaseNotifications[i]->Equals( |
2035 webFrameClient.createNotifications[webFrameClient.createNotifications.
size() - 3 - i])); | 2066 webFrameClient.createNotifications[webFrameClient.createNotifications.
size() - 3 - i])); |
2036 } | 2067 } |
2037 | 2068 |
2038 // The last two create notifications should be for the current frames and co
ntext. | 2069 // The last two create notifications should be for the current frames and co
ntext. |
2039 WebFrame* mainFrame = m_webView->mainFrame(); | 2070 WebFrame* mainFrame = webViewHelper.webView()->mainFrame(); |
2040 WebFrame* childFrame = mainFrame->firstChild(); | 2071 WebFrame* childFrame = mainFrame->firstChild(); |
2041 ContextLifetimeTestWebFrameClient::Notification* firstRefreshNotification =
webFrameClient.createNotifications[2]; | 2072 ContextLifetimeTestWebFrameClient::Notification* firstRefreshNotification =
webFrameClient.createNotifications[2]; |
2042 ContextLifetimeTestWebFrameClient::Notification* secondRefreshNotification =
webFrameClient.createNotifications[3]; | 2073 ContextLifetimeTestWebFrameClient::Notification* secondRefreshNotification =
webFrameClient.createNotifications[3]; |
2043 | 2074 |
2044 EXPECT_EQ(mainFrame, firstRefreshNotification->frame); | 2075 EXPECT_EQ(mainFrame, firstRefreshNotification->frame); |
2045 EXPECT_EQ(mainFrame->mainWorldScriptContext(), firstRefreshNotification->con
text); | 2076 EXPECT_EQ(mainFrame->mainWorldScriptContext(), firstRefreshNotification->con
text); |
2046 EXPECT_EQ(0, firstRefreshNotification->worldId); | 2077 EXPECT_EQ(0, firstRefreshNotification->worldId); |
2047 | 2078 |
2048 EXPECT_EQ(childFrame, secondRefreshNotification->frame); | 2079 EXPECT_EQ(childFrame, secondRefreshNotification->frame); |
2049 EXPECT_EQ(childFrame->mainWorldScriptContext(), secondRefreshNotification->c
ontext); | 2080 EXPECT_EQ(childFrame->mainWorldScriptContext(), secondRefreshNotification->c
ontext); |
2050 EXPECT_EQ(0, secondRefreshNotification->worldId); | 2081 EXPECT_EQ(0, secondRefreshNotification->worldId); |
2051 | |
2052 m_webView->close(); | |
2053 m_webView = 0; | |
2054 } | 2082 } |
2055 | 2083 |
2056 TEST_F(WebFrameTest, ContextNotificationsIsolatedWorlds) | 2084 TEST_F(WebFrameTest, ContextNotificationsIsolatedWorlds) |
2057 { | 2085 { |
2058 v8::Isolate* isolate = v8::Isolate::GetCurrent(); | 2086 v8::Isolate* isolate = v8::Isolate::GetCurrent(); |
2059 v8::HandleScope handleScope(isolate); | 2087 v8::HandleScope handleScope(isolate); |
2060 | 2088 |
2061 registerMockedHttpURLLoad("context_notifications_test.html"); | 2089 registerMockedHttpURLLoad("context_notifications_test.html"); |
2062 registerMockedHttpURLLoad("context_notifications_test_frame.html"); | 2090 registerMockedHttpURLLoad("context_notifications_test_frame.html"); |
2063 | 2091 |
2064 ContextLifetimeTestWebFrameClient webFrameClient; | 2092 ContextLifetimeTestWebFrameClient webFrameClient; |
2065 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "context_noti
fications_test.html", true, &webFrameClient); | 2093 FrameTestHelpers::WebViewHelper webViewHelper; |
| 2094 webViewHelper.initializeAndLoad(m_baseURL + "context_notifications_test.html
", true, &webFrameClient); |
2066 | 2095 |
2067 // Add an isolated world. | 2096 // Add an isolated world. |
2068 webFrameClient.reset(); | 2097 webFrameClient.reset(); |
2069 | 2098 |
2070 int isolatedWorldId = 42; | 2099 int isolatedWorldId = 42; |
2071 WebScriptSource scriptSource("hi!"); | 2100 WebScriptSource scriptSource("hi!"); |
2072 int numSources = 1; | 2101 int numSources = 1; |
2073 int extensionGroup = 0; | 2102 int extensionGroup = 0; |
2074 m_webView->mainFrame()->executeScriptInIsolatedWorld(isolatedWorldId, &scrip
tSource, numSources, extensionGroup); | 2103 webViewHelper.webView()->mainFrame()->executeScriptInIsolatedWorld(isolatedW
orldId, &scriptSource, numSources, extensionGroup); |
2075 | 2104 |
2076 // We should now have a new create notification. | 2105 // We should now have a new create notification. |
2077 ASSERT_EQ(1u, webFrameClient.createNotifications.size()); | 2106 ASSERT_EQ(1u, webFrameClient.createNotifications.size()); |
2078 ContextLifetimeTestWebFrameClient::Notification* notification = webFrameClie
nt.createNotifications[0]; | 2107 ContextLifetimeTestWebFrameClient::Notification* notification = webFrameClie
nt.createNotifications[0]; |
2079 ASSERT_EQ(isolatedWorldId, notification->worldId); | 2108 ASSERT_EQ(isolatedWorldId, notification->worldId); |
2080 ASSERT_EQ(m_webView->mainFrame(), notification->frame); | 2109 ASSERT_EQ(webViewHelper.webView()->mainFrame(), notification->frame); |
2081 | 2110 |
2082 // We don't have an API to enumarate isolated worlds for a frame, but we can
at least assert that the context we got is *not* the main world's context. | 2111 // We don't have an API to enumarate isolated worlds for a frame, but we can
at least assert that the context we got is *not* the main world's context. |
2083 ASSERT_NE(m_webView->mainFrame()->mainWorldScriptContext(), v8::Local<v8::Co
ntext>::New(isolate, notification->context)); | 2112 ASSERT_NE(webViewHelper.webView()->mainFrame()->mainWorldScriptContext(), v8
::Local<v8::Context>::New(isolate, notification->context)); |
2084 | 2113 |
2085 m_webView->close(); | 2114 webViewHelper.reset(); |
2086 m_webView = 0; | |
2087 | 2115 |
2088 // We should have gotten three release notifications (one for each of the fr
ames, plus one for the isolated context). | 2116 // We should have gotten three release notifications (one for each of the fr
ames, plus one for the isolated context). |
2089 ASSERT_EQ(3u, webFrameClient.releaseNotifications.size()); | 2117 ASSERT_EQ(3u, webFrameClient.releaseNotifications.size()); |
2090 | 2118 |
2091 // And one of them should be exactly the same as the create notification for
the isolated context. | 2119 // And one of them should be exactly the same as the create notification for
the isolated context. |
2092 int matchCount = 0; | 2120 int matchCount = 0; |
2093 for (size_t i = 0; i < webFrameClient.releaseNotifications.size(); ++i) { | 2121 for (size_t i = 0; i < webFrameClient.releaseNotifications.size(); ++i) { |
2094 if (webFrameClient.releaseNotifications[i]->Equals(webFrameClient.createNo
tifications[0])) | 2122 if (webFrameClient.releaseNotifications[i]->Equals(webFrameClient.createNo
tifications[0])) |
2095 ++matchCount; | 2123 ++matchCount; |
2096 } | 2124 } |
2097 EXPECT_EQ(1, matchCount); | 2125 EXPECT_EQ(1, matchCount); |
2098 } | 2126 } |
2099 | 2127 |
2100 TEST_F(WebFrameTest, FindInPage) | 2128 TEST_F(WebFrameTest, FindInPage) |
2101 { | 2129 { |
2102 registerMockedHttpURLLoad("find.html"); | 2130 registerMockedHttpURLLoad("find.html"); |
2103 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "find.html"); | 2131 FrameTestHelpers::WebViewHelper webViewHelper; |
2104 WebFrame* frame = m_webView->mainFrame(); | 2132 webViewHelper.initializeAndLoad(m_baseURL + "find.html"); |
| 2133 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
2105 const int findIdentifier = 12345; | 2134 const int findIdentifier = 12345; |
2106 WebFindOptions options; | 2135 WebFindOptions options; |
2107 | 2136 |
2108 // Find in a <div> element. | 2137 // Find in a <div> element. |
2109 EXPECT_TRUE(frame->find(findIdentifier, WebString::fromUTF8("bar1"), options
, false, 0)); | 2138 EXPECT_TRUE(frame->find(findIdentifier, WebString::fromUTF8("bar1"), options
, false, 0)); |
2110 frame->stopFinding(false); | 2139 frame->stopFinding(false); |
2111 WebRange range = frame->selectionRange(); | 2140 WebRange range = frame->selectionRange(); |
2112 EXPECT_EQ(5, range.startOffset()); | 2141 EXPECT_EQ(5, range.startOffset()); |
2113 EXPECT_EQ(9, range.endOffset()); | 2142 EXPECT_EQ(9, range.endOffset()); |
2114 EXPECT_TRUE(frame->document().focusedNode().isNull()); | 2143 EXPECT_TRUE(frame->document().focusedNode().isNull()); |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2148 EXPECT_FALSE(frame->find(findIdentifier, WebString::fromUTF8("bar5"), option
s, false, 0)); | 2177 EXPECT_FALSE(frame->find(findIdentifier, WebString::fromUTF8("bar5"), option
s, false, 0)); |
2149 // If there are any matches, stopFinding will set the selection on the found
text. | 2178 // If there are any matches, stopFinding will set the selection on the found
text. |
2150 // However, we do not expect any matches, so check that the selection is nul
l. | 2179 // However, we do not expect any matches, so check that the selection is nul
l. |
2151 frame->stopFinding(false); | 2180 frame->stopFinding(false); |
2152 range = frame->selectionRange(); | 2181 range = frame->selectionRange(); |
2153 ASSERT_TRUE(range.isNull()); | 2182 ASSERT_TRUE(range.isNull()); |
2154 } | 2183 } |
2155 | 2184 |
2156 TEST_F(WebFrameTest, GetContentAsPlainText) | 2185 TEST_F(WebFrameTest, GetContentAsPlainText) |
2157 { | 2186 { |
2158 m_webView = FrameTestHelpers::createWebViewAndLoad("about:blank", true); | 2187 FrameTestHelpers::WebViewHelper webViewHelper; |
| 2188 webViewHelper.initializeAndLoad("about:blank", true); |
2159 // We set the size because it impacts line wrapping, which changes the | 2189 // We set the size because it impacts line wrapping, which changes the |
2160 // resulting text value. | 2190 // resulting text value. |
2161 m_webView->resize(WebSize(640, 480)); | 2191 webViewHelper.webView()->resize(WebSize(640, 480)); |
2162 WebFrame* frame = m_webView->mainFrame(); | 2192 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
2163 | 2193 |
2164 // Generate a simple test case. | 2194 // Generate a simple test case. |
2165 const char simpleSource[] = "<div>Foo bar</div><div></div>baz"; | 2195 const char simpleSource[] = "<div>Foo bar</div><div></div>baz"; |
2166 WebCore::KURL testURL = toKURL("about:blank"); | 2196 WebCore::KURL testURL = toKURL("about:blank"); |
2167 frame->loadHTMLString(simpleSource, testURL); | 2197 frame->loadHTMLString(simpleSource, testURL); |
2168 runPendingTasks(); | 2198 runPendingTasks(); |
2169 | 2199 |
2170 // Make sure it comes out OK. | 2200 // Make sure it comes out OK. |
2171 const std::string expected("Foo bar\nbaz"); | 2201 const std::string expected("Foo bar\nbaz"); |
2172 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); | 2202 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); |
(...skipping 19 matching lines...) Expand all Loading... |
2192 EXPECT_EQ("Hello world\n\nsub\ntext", std::string(text.utf8().data())); | 2222 EXPECT_EQ("Hello world\n\nsub\ntext", std::string(text.utf8().data())); |
2193 | 2223 |
2194 // Get the frame text where the subframe separator falls on the boundary of | 2224 // Get the frame text where the subframe separator falls on the boundary of |
2195 // what we'll take. There used to be a crash in this case. | 2225 // what we'll take. There used to be a crash in this case. |
2196 text = frame->contentAsText(12); | 2226 text = frame->contentAsText(12); |
2197 EXPECT_EQ("Hello world", std::string(text.utf8().data())); | 2227 EXPECT_EQ("Hello world", std::string(text.utf8().data())); |
2198 } | 2228 } |
2199 | 2229 |
2200 TEST_F(WebFrameTest, GetFullHtmlOfPage) | 2230 TEST_F(WebFrameTest, GetFullHtmlOfPage) |
2201 { | 2231 { |
2202 m_webView = FrameTestHelpers::createWebViewAndLoad("about:blank", true); | 2232 FrameTestHelpers::WebViewHelper webViewHelper; |
2203 WebFrame* frame = m_webView->mainFrame(); | 2233 webViewHelper.initializeAndLoad("about:blank", true); |
| 2234 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
2204 | 2235 |
2205 // Generate a simple test case. | 2236 // Generate a simple test case. |
2206 const char simpleSource[] = "<p>Hello</p><p>World</p>"; | 2237 const char simpleSource[] = "<p>Hello</p><p>World</p>"; |
2207 WebCore::KURL testURL = toKURL("about:blank"); | 2238 WebCore::KURL testURL = toKURL("about:blank"); |
2208 frame->loadHTMLString(simpleSource, testURL); | 2239 frame->loadHTMLString(simpleSource, testURL); |
2209 runPendingTasks(); | 2240 runPendingTasks(); |
2210 | 2241 |
2211 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); | 2242 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); |
2212 EXPECT_EQ("Hello\n\nWorld", std::string(text.utf8().data())); | 2243 EXPECT_EQ("Hello\n\nWorld", std::string(text.utf8().data())); |
2213 | 2244 |
(...skipping 24 matching lines...) Expand all Loading... |
2238 { | 2269 { |
2239 frame->executeScript(WebScriptSource("window.history = 'replaced';")); | 2270 frame->executeScript(WebScriptSource("window.history = 'replaced';")); |
2240 } | 2271 } |
2241 }; | 2272 }; |
2242 | 2273 |
2243 TEST_F(WebFrameTest, ExecuteScriptDuringDidCreateScriptContext) | 2274 TEST_F(WebFrameTest, ExecuteScriptDuringDidCreateScriptContext) |
2244 { | 2275 { |
2245 registerMockedHttpURLLoad("hello_world.html"); | 2276 registerMockedHttpURLLoad("hello_world.html"); |
2246 | 2277 |
2247 TestExecuteScriptDuringDidCreateScriptContext webFrameClient; | 2278 TestExecuteScriptDuringDidCreateScriptContext webFrameClient; |
2248 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "hello_world.
html", true, &webFrameClient); | 2279 FrameTestHelpers::WebViewHelper webViewHelper; |
| 2280 webViewHelper.initializeAndLoad(m_baseURL + "hello_world.html", true, &webFr
ameClient); |
2249 | 2281 |
2250 m_webView->mainFrame()->reload(); | 2282 webViewHelper.webView()->mainFrame()->reload(); |
2251 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 2283 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
2252 | |
2253 m_webView->close(); | |
2254 m_webView = 0; | |
2255 } | 2284 } |
2256 | 2285 |
2257 class TestDidCreateFrameWebFrameClient : public WebFrameClient { | 2286 class TestDidCreateFrameWebFrameClient : public WebFrameClient { |
2258 public: | 2287 public: |
2259 TestDidCreateFrameWebFrameClient() : m_frameCount(0), m_parent(0) | 2288 TestDidCreateFrameWebFrameClient() : m_frameCount(0), m_parent(0) |
2260 { | 2289 { |
2261 } | 2290 } |
2262 | 2291 |
2263 virtual void didCreateFrame(WebFrame* parent, WebFrame* child) | 2292 virtual void didCreateFrame(WebFrame* parent, WebFrame* child) |
2264 { | 2293 { |
2265 m_frameCount++; | 2294 m_frameCount++; |
2266 if (!m_parent) | 2295 if (!m_parent) |
2267 m_parent = parent; | 2296 m_parent = parent; |
2268 } | 2297 } |
2269 | 2298 |
2270 int m_frameCount; | 2299 int m_frameCount; |
2271 WebFrame* m_parent; | 2300 WebFrame* m_parent; |
2272 }; | 2301 }; |
2273 | 2302 |
2274 TEST_F(WebFrameTest, DidCreateFrame) | 2303 TEST_F(WebFrameTest, DidCreateFrame) |
2275 { | 2304 { |
2276 registerMockedHttpURLLoad("iframes_test.html"); | 2305 registerMockedHttpURLLoad("iframes_test.html"); |
2277 registerMockedHttpURLLoad("visible_iframe.html"); | 2306 registerMockedHttpURLLoad("visible_iframe.html"); |
2278 registerMockedHttpURLLoad("invisible_iframe.html"); | 2307 registerMockedHttpURLLoad("invisible_iframe.html"); |
2279 registerMockedHttpURLLoad("zero_sized_iframe.html"); | 2308 registerMockedHttpURLLoad("zero_sized_iframe.html"); |
2280 | 2309 |
2281 TestDidCreateFrameWebFrameClient webFrameClient; | 2310 TestDidCreateFrameWebFrameClient webFrameClient; |
2282 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "iframes_test
.html", false, &webFrameClient); | 2311 FrameTestHelpers::WebViewHelper webViewHelper; |
| 2312 webViewHelper.initializeAndLoad(m_baseURL + "iframes_test.html", false, &web
FrameClient); |
2283 | 2313 |
2284 EXPECT_EQ(webFrameClient.m_frameCount, 3); | 2314 EXPECT_EQ(webFrameClient.m_frameCount, 3); |
2285 EXPECT_EQ(webFrameClient.m_parent, m_webView->mainFrame()); | 2315 EXPECT_EQ(webFrameClient.m_parent, webViewHelper.webView()->mainFrame()); |
2286 | |
2287 m_webView->close(); | |
2288 m_webView = 0; | |
2289 } | 2316 } |
2290 | 2317 |
2291 class FindUpdateWebFrameClient : public WebFrameClient { | 2318 class FindUpdateWebFrameClient : public WebFrameClient { |
2292 public: | 2319 public: |
2293 FindUpdateWebFrameClient() | 2320 FindUpdateWebFrameClient() |
2294 : m_findResultsAreReady(false) | 2321 : m_findResultsAreReady(false) |
2295 , m_count(-1) | 2322 , m_count(-1) |
2296 { | 2323 { |
2297 } | 2324 } |
2298 | 2325 |
(...skipping 16 matching lines...) Expand all Loading... |
2315 #if OS(MACOSX) | 2342 #if OS(MACOSX) |
2316 TEST_F(WebFrameTest, DISABLED_FindInPageMatchRects) | 2343 TEST_F(WebFrameTest, DISABLED_FindInPageMatchRects) |
2317 #else | 2344 #else |
2318 TEST_F(WebFrameTest, FindInPageMatchRects) | 2345 TEST_F(WebFrameTest, FindInPageMatchRects) |
2319 #endif | 2346 #endif |
2320 { | 2347 { |
2321 registerMockedHttpURLLoad("find_in_page.html"); | 2348 registerMockedHttpURLLoad("find_in_page.html"); |
2322 registerMockedHttpURLLoad("find_in_page_frame.html"); | 2349 registerMockedHttpURLLoad("find_in_page_frame.html"); |
2323 | 2350 |
2324 FindUpdateWebFrameClient client; | 2351 FindUpdateWebFrameClient client; |
2325 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "find_in_page
.html", true, &client); | 2352 FrameTestHelpers::WebViewHelper webViewHelper; |
2326 m_webView->resize(WebSize(640, 480)); | 2353 webViewHelper.initializeAndLoad(m_baseURL + "find_in_page.html", true, &clie
nt); |
2327 m_webView->layout(); | 2354 webViewHelper.webView()->resize(WebSize(640, 480)); |
| 2355 webViewHelper.webView()->layout(); |
2328 runPendingTasks(); | 2356 runPendingTasks(); |
2329 | 2357 |
2330 // Note that the 'result 19' in the <select> element is not expected to prod
uce a match. | 2358 // Note that the 'result 19' in the <select> element is not expected to prod
uce a match. |
2331 static const char* kFindString = "result"; | 2359 static const char* kFindString = "result"; |
2332 static const int kFindIdentifier = 12345; | 2360 static const int kFindIdentifier = 12345; |
2333 static const int kNumResults = 19; | 2361 static const int kNumResults = 19; |
2334 | 2362 |
2335 WebFindOptions options; | 2363 WebFindOptions options; |
2336 WebString searchText = WebString::fromUTF8(kFindString); | 2364 WebString searchText = WebString::fromUTF8(kFindString); |
2337 WebFrameImpl* mainFrame = toWebFrameImpl(m_webView->mainFrame()); | 2365 WebFrameImpl* mainFrame = toWebFrameImpl(webViewHelper.webView()->mainFrame(
)); |
2338 EXPECT_TRUE(mainFrame->find(kFindIdentifier, searchText, options, false, 0))
; | 2366 EXPECT_TRUE(mainFrame->find(kFindIdentifier, searchText, options, false, 0))
; |
2339 | 2367 |
2340 mainFrame->resetMatchCount(); | 2368 mainFrame->resetMatchCount(); |
2341 | 2369 |
2342 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) | 2370 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) |
2343 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); | 2371 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); |
2344 | 2372 |
2345 runPendingTasks(); | 2373 runPendingTasks(); |
2346 EXPECT_TRUE(client.findResultsAreReady()); | 2374 EXPECT_TRUE(client.findResultsAreReady()); |
2347 | 2375 |
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2422 EXPECT_TRUE(webMatchRects[12].y < webMatchRects[14].y); | 2450 EXPECT_TRUE(webMatchRects[12].y < webMatchRects[14].y); |
2423 | 2451 |
2424 // Result 16 should be below result 15. | 2452 // Result 16 should be below result 15. |
2425 EXPECT_TRUE(webMatchRects[15].y > webMatchRects[14].y); | 2453 EXPECT_TRUE(webMatchRects[15].y > webMatchRects[14].y); |
2426 | 2454 |
2427 // Result 18 should be normalized with respect to the position:relative div,
and not it's | 2455 // Result 18 should be normalized with respect to the position:relative div,
and not it's |
2428 // immediate containing div. Consequently, result 18 should be above result
17. | 2456 // immediate containing div. Consequently, result 18 should be above result
17. |
2429 EXPECT_TRUE(webMatchRects[17].y > webMatchRects[18].y); | 2457 EXPECT_TRUE(webMatchRects[17].y > webMatchRects[18].y); |
2430 | 2458 |
2431 // Resizing should update the rects version. | 2459 // Resizing should update the rects version. |
2432 m_webView->resize(WebSize(800, 600)); | 2460 webViewHelper.webView()->resize(WebSize(800, 600)); |
2433 runPendingTasks(); | 2461 runPendingTasks(); |
2434 EXPECT_TRUE(mainFrame->findMatchMarkersVersion() != rectsVersion); | 2462 EXPECT_TRUE(mainFrame->findMatchMarkersVersion() != rectsVersion); |
2435 | |
2436 m_webView->close(); | |
2437 m_webView = 0; | |
2438 } | 2463 } |
2439 | 2464 |
2440 TEST_F(WebFrameTest, FindInPageSkipsHiddenFrames) | 2465 TEST_F(WebFrameTest, FindInPageSkipsHiddenFrames) |
2441 { | 2466 { |
2442 registerMockedHttpURLLoad("find_in_hidden_frame.html"); | 2467 registerMockedHttpURLLoad("find_in_hidden_frame.html"); |
2443 | 2468 |
2444 FindUpdateWebFrameClient client; | 2469 FindUpdateWebFrameClient client; |
2445 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "find_in_hidd
en_frame.html", true, &client); | 2470 FrameTestHelpers::WebViewHelper webViewHelper; |
2446 m_webView->resize(WebSize(640, 480)); | 2471 webViewHelper.initializeAndLoad(m_baseURL + "find_in_hidden_frame.html", tru
e, &client); |
2447 m_webView->layout(); | 2472 webViewHelper.webView()->resize(WebSize(640, 480)); |
| 2473 webViewHelper.webView()->layout(); |
2448 runPendingTasks(); | 2474 runPendingTasks(); |
2449 | 2475 |
2450 static const char* kFindString = "hello"; | 2476 static const char* kFindString = "hello"; |
2451 static const int kFindIdentifier = 12345; | 2477 static const int kFindIdentifier = 12345; |
2452 static const int kNumResults = 1; | 2478 static const int kNumResults = 1; |
2453 | 2479 |
2454 WebFindOptions options; | 2480 WebFindOptions options; |
2455 WebString searchText = WebString::fromUTF8(kFindString); | 2481 WebString searchText = WebString::fromUTF8(kFindString); |
2456 WebFrameImpl* mainFrame = toWebFrameImpl(m_webView->mainFrame()); | 2482 WebFrameImpl* mainFrame = toWebFrameImpl(webViewHelper.webView()->mainFrame(
)); |
2457 EXPECT_TRUE(mainFrame->find(kFindIdentifier, searchText, options, false, 0))
; | 2483 EXPECT_TRUE(mainFrame->find(kFindIdentifier, searchText, options, false, 0))
; |
2458 | 2484 |
2459 mainFrame->resetMatchCount(); | 2485 mainFrame->resetMatchCount(); |
2460 | 2486 |
2461 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) | 2487 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) |
2462 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); | 2488 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); |
2463 | 2489 |
2464 runPendingTasks(); | 2490 runPendingTasks(); |
2465 EXPECT_TRUE(client.findResultsAreReady()); | 2491 EXPECT_TRUE(client.findResultsAreReady()); |
2466 EXPECT_EQ(kNumResults, client.count()); | 2492 EXPECT_EQ(kNumResults, client.count()); |
2467 | |
2468 m_webView->close(); | |
2469 m_webView = 0; | |
2470 } | 2493 } |
2471 | 2494 |
2472 TEST_F(WebFrameTest, FindOnDetachedFrame) | 2495 TEST_F(WebFrameTest, FindOnDetachedFrame) |
2473 { | 2496 { |
2474 registerMockedHttpURLLoad("find_in_page.html"); | 2497 registerMockedHttpURLLoad("find_in_page.html"); |
2475 registerMockedHttpURLLoad("find_in_page_frame.html"); | 2498 registerMockedHttpURLLoad("find_in_page_frame.html"); |
2476 | 2499 |
2477 FindUpdateWebFrameClient client; | 2500 FindUpdateWebFrameClient client; |
2478 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "find_in_page
.html", true, &client); | 2501 FrameTestHelpers::WebViewHelper webViewHelper; |
2479 m_webView->resize(WebSize(640, 480)); | 2502 webViewHelper.initializeAndLoad(m_baseURL + "find_in_page.html", true, &clie
nt); |
2480 m_webView->layout(); | 2503 webViewHelper.webView()->resize(WebSize(640, 480)); |
| 2504 webViewHelper.webView()->layout(); |
2481 runPendingTasks(); | 2505 runPendingTasks(); |
2482 | 2506 |
2483 static const char* kFindString = "result"; | 2507 static const char* kFindString = "result"; |
2484 static const int kFindIdentifier = 12345; | 2508 static const int kFindIdentifier = 12345; |
2485 | 2509 |
2486 WebFindOptions options; | 2510 WebFindOptions options; |
2487 WebString searchText = WebString::fromUTF8(kFindString); | 2511 WebString searchText = WebString::fromUTF8(kFindString); |
2488 WebFrameImpl* mainFrame = toWebFrameImpl(m_webView->mainFrame()); | 2512 WebFrameImpl* mainFrame = toWebFrameImpl(webViewHelper.webView()->mainFrame(
)); |
2489 WebFrameImpl* secondFrame = toWebFrameImpl(mainFrame->traverseNext(false)); | 2513 WebFrameImpl* secondFrame = toWebFrameImpl(mainFrame->traverseNext(false)); |
2490 RefPtr<WebCore::Frame> holdSecondFrame = secondFrame->frame(); | 2514 RefPtr<WebCore::Frame> holdSecondFrame = secondFrame->frame(); |
2491 | 2515 |
2492 // Detach the frame before finding. | 2516 // Detach the frame before finding. |
2493 EXPECT_TRUE(mainFrame->document().getElementById("frame").remove()); | 2517 EXPECT_TRUE(mainFrame->document().getElementById("frame").remove()); |
2494 | 2518 |
2495 EXPECT_TRUE(mainFrame->find(kFindIdentifier, searchText, options, false, 0))
; | 2519 EXPECT_TRUE(mainFrame->find(kFindIdentifier, searchText, options, false, 0))
; |
2496 EXPECT_FALSE(secondFrame->find(kFindIdentifier, searchText, options, false,
0)); | 2520 EXPECT_FALSE(secondFrame->find(kFindIdentifier, searchText, options, false,
0)); |
2497 | 2521 |
2498 runPendingTasks(); | 2522 runPendingTasks(); |
2499 EXPECT_FALSE(client.findResultsAreReady()); | 2523 EXPECT_FALSE(client.findResultsAreReady()); |
2500 | 2524 |
2501 mainFrame->resetMatchCount(); | 2525 mainFrame->resetMatchCount(); |
2502 | 2526 |
2503 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) | 2527 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) |
2504 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); | 2528 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); |
2505 | 2529 |
2506 runPendingTasks(); | 2530 runPendingTasks(); |
2507 EXPECT_TRUE(client.findResultsAreReady()); | 2531 EXPECT_TRUE(client.findResultsAreReady()); |
2508 | 2532 |
2509 holdSecondFrame.release(); | 2533 holdSecondFrame.release(); |
2510 | |
2511 m_webView->close(); | |
2512 m_webView = 0; | |
2513 } | 2534 } |
2514 | 2535 |
2515 TEST_F(WebFrameTest, FindDetachFrameBeforeScopeStrings) | 2536 TEST_F(WebFrameTest, FindDetachFrameBeforeScopeStrings) |
2516 { | 2537 { |
2517 registerMockedHttpURLLoad("find_in_page.html"); | 2538 registerMockedHttpURLLoad("find_in_page.html"); |
2518 registerMockedHttpURLLoad("find_in_page_frame.html"); | 2539 registerMockedHttpURLLoad("find_in_page_frame.html"); |
2519 | 2540 |
2520 FindUpdateWebFrameClient client; | 2541 FindUpdateWebFrameClient client; |
2521 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "find_in_page
.html", true, &client); | 2542 FrameTestHelpers::WebViewHelper webViewHelper; |
2522 m_webView->resize(WebSize(640, 480)); | 2543 webViewHelper.initializeAndLoad(m_baseURL + "find_in_page.html", true, &clie
nt); |
2523 m_webView->layout(); | 2544 webViewHelper.webView()->resize(WebSize(640, 480)); |
| 2545 webViewHelper.webView()->layout(); |
2524 runPendingTasks(); | 2546 runPendingTasks(); |
2525 | 2547 |
2526 static const char* kFindString = "result"; | 2548 static const char* kFindString = "result"; |
2527 static const int kFindIdentifier = 12345; | 2549 static const int kFindIdentifier = 12345; |
2528 | 2550 |
2529 WebFindOptions options; | 2551 WebFindOptions options; |
2530 WebString searchText = WebString::fromUTF8(kFindString); | 2552 WebString searchText = WebString::fromUTF8(kFindString); |
2531 WebFrameImpl* mainFrame = toWebFrameImpl(m_webView->mainFrame()); | 2553 WebFrameImpl* mainFrame = toWebFrameImpl(webViewHelper.webView()->mainFrame(
)); |
2532 WebFrameImpl* secondFrame = toWebFrameImpl(mainFrame->traverseNext(false)); | 2554 WebFrameImpl* secondFrame = toWebFrameImpl(mainFrame->traverseNext(false)); |
2533 RefPtr<WebCore::Frame> holdSecondFrame = secondFrame->frame(); | 2555 RefPtr<WebCore::Frame> holdSecondFrame = secondFrame->frame(); |
2534 | 2556 |
2535 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) | 2557 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) |
2536 EXPECT_TRUE(frame->find(kFindIdentifier, searchText, options, false, 0))
; | 2558 EXPECT_TRUE(frame->find(kFindIdentifier, searchText, options, false, 0))
; |
2537 | 2559 |
2538 runPendingTasks(); | 2560 runPendingTasks(); |
2539 EXPECT_FALSE(client.findResultsAreReady()); | 2561 EXPECT_FALSE(client.findResultsAreReady()); |
2540 | 2562 |
2541 // Detach the frame between finding and scoping. | 2563 // Detach the frame between finding and scoping. |
2542 EXPECT_TRUE(mainFrame->document().getElementById("frame").remove()); | 2564 EXPECT_TRUE(mainFrame->document().getElementById("frame").remove()); |
2543 | 2565 |
2544 mainFrame->resetMatchCount(); | 2566 mainFrame->resetMatchCount(); |
2545 | 2567 |
2546 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) | 2568 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) |
2547 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); | 2569 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); |
2548 | 2570 |
2549 runPendingTasks(); | 2571 runPendingTasks(); |
2550 EXPECT_TRUE(client.findResultsAreReady()); | 2572 EXPECT_TRUE(client.findResultsAreReady()); |
2551 | 2573 |
2552 holdSecondFrame.release(); | 2574 holdSecondFrame.release(); |
2553 | |
2554 m_webView->close(); | |
2555 m_webView = 0; | |
2556 } | 2575 } |
2557 | 2576 |
2558 TEST_F(WebFrameTest, FindDetachFrameWhileScopingStrings) | 2577 TEST_F(WebFrameTest, FindDetachFrameWhileScopingStrings) |
2559 { | 2578 { |
2560 registerMockedHttpURLLoad("find_in_page.html"); | 2579 registerMockedHttpURLLoad("find_in_page.html"); |
2561 registerMockedHttpURLLoad("find_in_page_frame.html"); | 2580 registerMockedHttpURLLoad("find_in_page_frame.html"); |
2562 | 2581 |
2563 FindUpdateWebFrameClient client; | 2582 FindUpdateWebFrameClient client; |
2564 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "find_in_page
.html", true, &client); | 2583 FrameTestHelpers::WebViewHelper webViewHelper; |
2565 m_webView->resize(WebSize(640, 480)); | 2584 webViewHelper.initializeAndLoad(m_baseURL + "find_in_page.html", true, &clie
nt); |
2566 m_webView->layout(); | 2585 webViewHelper.webView()->resize(WebSize(640, 480)); |
| 2586 webViewHelper.webView()->layout(); |
2567 runPendingTasks(); | 2587 runPendingTasks(); |
2568 | 2588 |
2569 static const char* kFindString = "result"; | 2589 static const char* kFindString = "result"; |
2570 static const int kFindIdentifier = 12345; | 2590 static const int kFindIdentifier = 12345; |
2571 | 2591 |
2572 WebFindOptions options; | 2592 WebFindOptions options; |
2573 WebString searchText = WebString::fromUTF8(kFindString); | 2593 WebString searchText = WebString::fromUTF8(kFindString); |
2574 WebFrameImpl* mainFrame = toWebFrameImpl(m_webView->mainFrame()); | 2594 WebFrameImpl* mainFrame = toWebFrameImpl(webViewHelper.webView()->mainFrame(
)); |
2575 WebFrameImpl* secondFrame = toWebFrameImpl(mainFrame->traverseNext(false)); | 2595 WebFrameImpl* secondFrame = toWebFrameImpl(mainFrame->traverseNext(false)); |
2576 RefPtr<WebCore::Frame> holdSecondFrame = secondFrame->frame(); | 2596 RefPtr<WebCore::Frame> holdSecondFrame = secondFrame->frame(); |
2577 | 2597 |
2578 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) | 2598 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) |
2579 EXPECT_TRUE(frame->find(kFindIdentifier, searchText, options, false, 0))
; | 2599 EXPECT_TRUE(frame->find(kFindIdentifier, searchText, options, false, 0))
; |
2580 | 2600 |
2581 runPendingTasks(); | 2601 runPendingTasks(); |
2582 EXPECT_FALSE(client.findResultsAreReady()); | 2602 EXPECT_FALSE(client.findResultsAreReady()); |
2583 | 2603 |
2584 mainFrame->resetMatchCount(); | 2604 mainFrame->resetMatchCount(); |
2585 | 2605 |
2586 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) | 2606 for (WebFrame* frame = mainFrame; frame; frame = frame->traverseNext(false)) |
2587 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); | 2607 frame->scopeStringMatches(kFindIdentifier, searchText, options, true); |
2588 | 2608 |
2589 // The first scopeStringMatches will have reset the state. Detach before it
actually scopes. | 2609 // The first scopeStringMatches will have reset the state. Detach before it
actually scopes. |
2590 EXPECT_TRUE(mainFrame->document().getElementById("frame").remove()); | 2610 EXPECT_TRUE(mainFrame->document().getElementById("frame").remove()); |
2591 | 2611 |
2592 runPendingTasks(); | 2612 runPendingTasks(); |
2593 EXPECT_TRUE(client.findResultsAreReady()); | 2613 EXPECT_TRUE(client.findResultsAreReady()); |
2594 | 2614 |
2595 holdSecondFrame.release(); | 2615 holdSecondFrame.release(); |
2596 | |
2597 m_webView->close(); | |
2598 m_webView = 0; | |
2599 } | |
2600 | |
2601 static WebView* createWebViewForTextSelection(const std::string& url) | |
2602 { | |
2603 WebView* webView = FrameTestHelpers::createWebViewAndLoad(url, true); | |
2604 webView->settings()->setDefaultFontSize(12); | |
2605 webView->enableFixedLayoutMode(false); | |
2606 webView->resize(WebSize(640, 480)); | |
2607 return webView; | |
2608 } | 2616 } |
2609 | 2617 |
2610 static WebPoint topLeft(const WebRect& rect) | 2618 static WebPoint topLeft(const WebRect& rect) |
2611 { | 2619 { |
2612 return WebPoint(rect.x, rect.y); | 2620 return WebPoint(rect.x, rect.y); |
2613 } | 2621 } |
2614 | 2622 |
2615 static WebPoint bottomRightMinusOne(const WebRect& rect) | 2623 static WebPoint bottomRightMinusOne(const WebRect& rect) |
2616 { | 2624 { |
2617 // FIXME: If we don't subtract 1 from the x- and y-coordinates of the | 2625 // FIXME: If we don't subtract 1 from the x- and y-coordinates of the |
(...skipping 15 matching lines...) Expand all Loading... |
2633 | 2641 |
2634 TEST_F(WebFrameTest, SelectRange) | 2642 TEST_F(WebFrameTest, SelectRange) |
2635 { | 2643 { |
2636 WebFrame* frame; | 2644 WebFrame* frame; |
2637 WebRect startWebRect; | 2645 WebRect startWebRect; |
2638 WebRect endWebRect; | 2646 WebRect endWebRect; |
2639 | 2647 |
2640 registerMockedHttpURLLoad("select_range_basic.html"); | 2648 registerMockedHttpURLLoad("select_range_basic.html"); |
2641 registerMockedHttpURLLoad("select_range_scroll.html"); | 2649 registerMockedHttpURLLoad("select_range_scroll.html"); |
2642 | 2650 |
2643 m_webView = createWebViewForTextSelection(m_baseURL + "select_range_basic.ht
ml"); | 2651 FrameTestHelpers::WebViewHelper webViewHelper; |
2644 frame = m_webView->mainFrame(); | 2652 initializeTextSelectionWebView(m_baseURL + "select_range_basic.html", &webVi
ewHelper); |
| 2653 frame = webViewHelper.webView()->mainFrame(); |
2645 EXPECT_EQ("Some test text for testing.", selectionAsString(frame)); | 2654 EXPECT_EQ("Some test text for testing.", selectionAsString(frame)); |
2646 m_webView->selectionBounds(startWebRect, endWebRect); | 2655 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2647 frame->executeCommand(WebString::fromUTF8("Unselect")); | 2656 frame->executeCommand(WebString::fromUTF8("Unselect")); |
2648 EXPECT_EQ("", selectionAsString(frame)); | 2657 EXPECT_EQ("", selectionAsString(frame)); |
2649 frame->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)); | 2658 frame->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)); |
2650 EXPECT_EQ("Some test text for testing.", selectionAsString(frame)); | 2659 EXPECT_EQ("Some test text for testing.", selectionAsString(frame)); |
2651 m_webView->close(); | |
2652 m_webView = 0; | |
2653 | 2660 |
2654 m_webView = createWebViewForTextSelection(m_baseURL + "select_range_scroll.h
tml"); | 2661 initializeTextSelectionWebView(m_baseURL + "select_range_scroll.html", &webV
iewHelper); |
2655 frame = m_webView->mainFrame(); | 2662 frame = webViewHelper.webView()->mainFrame(); |
2656 EXPECT_EQ("Some offscreen test text for testing.", selectionAsString(frame))
; | 2663 EXPECT_EQ("Some offscreen test text for testing.", selectionAsString(frame))
; |
2657 m_webView->selectionBounds(startWebRect, endWebRect); | 2664 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2658 frame->executeCommand(WebString::fromUTF8("Unselect")); | 2665 frame->executeCommand(WebString::fromUTF8("Unselect")); |
2659 EXPECT_EQ("", selectionAsString(frame)); | 2666 EXPECT_EQ("", selectionAsString(frame)); |
2660 frame->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)); | 2667 frame->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)); |
2661 EXPECT_EQ("Some offscreen test text for testing.", selectionAsString(frame))
; | 2668 EXPECT_EQ("Some offscreen test text for testing.", selectionAsString(frame))
; |
2662 m_webView->close(); | |
2663 m_webView = 0; | |
2664 } | 2669 } |
2665 | 2670 |
2666 TEST_F(WebFrameTest, SelectRangeInIframe) | 2671 TEST_F(WebFrameTest, SelectRangeInIframe) |
2667 { | 2672 { |
2668 WebFrame* frame; | 2673 WebFrame* frame; |
2669 WebRect startWebRect; | 2674 WebRect startWebRect; |
2670 WebRect endWebRect; | 2675 WebRect endWebRect; |
2671 | 2676 |
2672 registerMockedHttpURLLoad("select_range_iframe.html"); | 2677 registerMockedHttpURLLoad("select_range_iframe.html"); |
2673 registerMockedHttpURLLoad("select_range_basic.html"); | 2678 registerMockedHttpURLLoad("select_range_basic.html"); |
2674 | 2679 |
2675 m_webView = createWebViewForTextSelection(m_baseURL + "select_range_iframe.h
tml"); | 2680 FrameTestHelpers::WebViewHelper webViewHelper; |
2676 frame = m_webView->mainFrame(); | 2681 initializeTextSelectionWebView(m_baseURL + "select_range_iframe.html", &webV
iewHelper); |
| 2682 frame = webViewHelper.webView()->mainFrame(); |
2677 WebFrame* subframe = frame->findChildByExpression(WebString::fromUTF8("/html
/body/iframe")); | 2683 WebFrame* subframe = frame->findChildByExpression(WebString::fromUTF8("/html
/body/iframe")); |
2678 EXPECT_EQ("Some test text for testing.", selectionAsString(subframe)); | 2684 EXPECT_EQ("Some test text for testing.", selectionAsString(subframe)); |
2679 m_webView->selectionBounds(startWebRect, endWebRect); | 2685 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2680 subframe->executeCommand(WebString::fromUTF8("Unselect")); | 2686 subframe->executeCommand(WebString::fromUTF8("Unselect")); |
2681 EXPECT_EQ("", selectionAsString(subframe)); | 2687 EXPECT_EQ("", selectionAsString(subframe)); |
2682 subframe->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)
); | 2688 subframe->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)
); |
2683 EXPECT_EQ("Some test text for testing.", selectionAsString(subframe)); | 2689 EXPECT_EQ("Some test text for testing.", selectionAsString(subframe)); |
2684 m_webView->close(); | |
2685 m_webView = 0; | |
2686 } | 2690 } |
2687 | 2691 |
2688 TEST_F(WebFrameTest, SelectRangeDivContentEditable) | 2692 TEST_F(WebFrameTest, SelectRangeDivContentEditable) |
2689 { | 2693 { |
2690 WebFrame* frame; | 2694 WebFrame* frame; |
2691 WebRect startWebRect; | 2695 WebRect startWebRect; |
2692 WebRect endWebRect; | 2696 WebRect endWebRect; |
2693 | 2697 |
2694 registerMockedHttpURLLoad("select_range_div_editable.html"); | 2698 registerMockedHttpURLLoad("select_range_div_editable.html"); |
2695 | 2699 |
2696 // Select the middle of an editable element, then try to extend the selectio
n to the top of the document. | 2700 // Select the middle of an editable element, then try to extend the selectio
n to the top of the document. |
2697 // The selection range should be clipped to the bounds of the editable eleme
nt. | 2701 // The selection range should be clipped to the bounds of the editable eleme
nt. |
2698 m_webView = createWebViewForTextSelection(m_baseURL + "select_range_div_edit
able.html"); | 2702 FrameTestHelpers::WebViewHelper webViewHelper; |
2699 frame = m_webView->mainFrame(); | 2703 initializeTextSelectionWebView(m_baseURL + "select_range_div_editable.html",
&webViewHelper); |
| 2704 frame = webViewHelper.webView()->mainFrame(); |
2700 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); | 2705 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); |
2701 m_webView->selectionBounds(startWebRect, endWebRect); | 2706 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2702 | 2707 |
2703 frame->selectRange(bottomRightMinusOne(endWebRect), WebPoint(0, 0)); | 2708 frame->selectRange(bottomRightMinusOne(endWebRect), WebPoint(0, 0)); |
2704 EXPECT_EQ("16-char header. This text is initially selected.", selectionAsStr
ing(frame)); | 2709 EXPECT_EQ("16-char header. This text is initially selected.", selectionAsStr
ing(frame)); |
2705 m_webView->close(); | |
2706 m_webView = 0; | |
2707 | 2710 |
2708 // As above, but extending the selection to the bottom of the document. | 2711 // As above, but extending the selection to the bottom of the document. |
2709 m_webView = createWebViewForTextSelection(m_baseURL + "select_range_div_edit
able.html"); | 2712 initializeTextSelectionWebView(m_baseURL + "select_range_div_editable.html",
&webViewHelper); |
2710 frame = m_webView->mainFrame(); | 2713 frame = webViewHelper.webView()->mainFrame(); |
2711 | 2714 |
2712 m_webView->selectionBounds(startWebRect, endWebRect); | 2715 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2713 frame->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)); | 2716 frame->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)); |
2714 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); | 2717 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); |
2715 m_webView->selectionBounds(startWebRect, endWebRect); | 2718 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2716 | 2719 |
2717 m_webView->selectionBounds(startWebRect, endWebRect); | 2720 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2718 frame->selectRange(topLeft(startWebRect), WebPoint(640, 480)); | 2721 frame->selectRange(topLeft(startWebRect), WebPoint(640, 480)); |
2719 EXPECT_EQ("This text is initially selected. 16-char footer.", selectionAsStr
ing(frame)); | 2722 EXPECT_EQ("This text is initially selected. 16-char footer.", selectionAsStr
ing(frame)); |
2720 m_webView->close(); | |
2721 m_webView = 0; | |
2722 } | 2723 } |
2723 | 2724 |
2724 // positionForPoint returns the wrong values for contenteditable spans. See | 2725 // positionForPoint returns the wrong values for contenteditable spans. See |
2725 // http://crbug.com/238334. | 2726 // http://crbug.com/238334. |
2726 TEST_F(WebFrameTest, DISABLED_SelectRangeSpanContentEditable) | 2727 TEST_F(WebFrameTest, DISABLED_SelectRangeSpanContentEditable) |
2727 { | 2728 { |
2728 WebFrame* frame; | 2729 WebFrame* frame; |
2729 WebRect startWebRect; | 2730 WebRect startWebRect; |
2730 WebRect endWebRect; | 2731 WebRect endWebRect; |
2731 | 2732 |
2732 registerMockedHttpURLLoad("select_range_span_editable.html"); | 2733 registerMockedHttpURLLoad("select_range_span_editable.html"); |
2733 | 2734 |
2734 // Select the middle of an editable element, then try to extend the selectio
n to the top of the document. | 2735 // Select the middle of an editable element, then try to extend the selectio
n to the top of the document. |
2735 // The selection range should be clipped to the bounds of the editable eleme
nt. | 2736 // The selection range should be clipped to the bounds of the editable eleme
nt. |
2736 m_webView = createWebViewForTextSelection(m_baseURL + "select_range_span_edi
table.html"); | 2737 FrameTestHelpers::WebViewHelper webViewHelper; |
2737 frame = m_webView->mainFrame(); | 2738 initializeTextSelectionWebView(m_baseURL + "select_range_span_editable.html"
, &webViewHelper); |
| 2739 frame = webViewHelper.webView()->mainFrame(); |
2738 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); | 2740 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); |
2739 m_webView->selectionBounds(startWebRect, endWebRect); | 2741 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2740 | 2742 |
2741 frame->selectRange(bottomRightMinusOne(endWebRect), WebPoint(0, 0)); | 2743 frame->selectRange(bottomRightMinusOne(endWebRect), WebPoint(0, 0)); |
2742 EXPECT_EQ("16-char header. This text is initially selected.", selectionAsStr
ing(frame)); | 2744 EXPECT_EQ("16-char header. This text is initially selected.", selectionAsStr
ing(frame)); |
2743 m_webView->close(); | |
2744 m_webView = 0; | |
2745 | 2745 |
2746 // As above, but extending the selection to the bottom of the document. | 2746 // As above, but extending the selection to the bottom of the document. |
2747 m_webView = createWebViewForTextSelection(m_baseURL + "select_range_span_edi
table.html"); | 2747 initializeTextSelectionWebView(m_baseURL + "select_range_span_editable.html"
, &webViewHelper); |
2748 frame = m_webView->mainFrame(); | 2748 frame = webViewHelper.webView()->mainFrame(); |
2749 | 2749 |
2750 m_webView->selectionBounds(startWebRect, endWebRect); | 2750 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2751 frame->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)); | 2751 frame->selectRange(topLeft(startWebRect), bottomRightMinusOne(endWebRect)); |
2752 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); | 2752 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); |
2753 m_webView->selectionBounds(startWebRect, endWebRect); | 2753 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2754 | 2754 |
2755 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); | 2755 EXPECT_EQ("This text is initially selected.", selectionAsString(frame)); |
2756 m_webView->selectionBounds(startWebRect, endWebRect); | 2756 webViewHelper.webView()->selectionBounds(startWebRect, endWebRect); |
2757 frame->selectRange(topLeft(startWebRect), WebPoint(640, 480)); | 2757 frame->selectRange(topLeft(startWebRect), WebPoint(640, 480)); |
2758 EXPECT_EQ("This text is initially selected. 16-char footer.", selectionAsStr
ing(frame)); | 2758 EXPECT_EQ("This text is initially selected. 16-char footer.", selectionAsStr
ing(frame)); |
2759 m_webView->close(); | |
2760 m_webView = 0; | |
2761 } | 2759 } |
2762 | 2760 |
2763 TEST_F(WebFrameTest, SelectRangeCanMoveSelectionStart) | 2761 TEST_F(WebFrameTest, SelectRangeCanMoveSelectionStart) |
2764 { | 2762 { |
2765 registerMockedHttpURLLoad("text_selection.html"); | 2763 registerMockedHttpURLLoad("text_selection.html"); |
2766 m_webView = createWebViewForTextSelection(m_baseURL + "text_selection.html")
; | 2764 FrameTestHelpers::WebViewHelper webViewHelper; |
2767 WebFrame* frame = m_webView->mainFrame(); | 2765 initializeTextSelectionWebView(m_baseURL + "text_selection.html", &webViewHe
lper); |
| 2766 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
2768 | 2767 |
2769 // Select second span. We can move the start to include the first span. | 2768 // Select second span. We can move the start to include the first span. |
2770 frame->executeScript(WebScriptSource("selectElement('header_2');")); | 2769 frame->executeScript(WebScriptSource("selectElement('header_2');")); |
2771 EXPECT_EQ("Header 2.", selectionAsString(frame)); | 2770 EXPECT_EQ("Header 2.", selectionAsString(frame)); |
2772 frame->selectRange(bottomRightMinusOne(elementBounds(frame, "header_2")), to
pLeft(elementBounds(frame, "header_1"))); | 2771 frame->selectRange(bottomRightMinusOne(elementBounds(frame, "header_2")), to
pLeft(elementBounds(frame, "header_1"))); |
2773 EXPECT_EQ("Header 1. Header 2.", selectionAsString(frame)); | 2772 EXPECT_EQ("Header 1. Header 2.", selectionAsString(frame)); |
2774 | 2773 |
2775 // We can move the start and end together. | 2774 // We can move the start and end together. |
2776 frame->executeScript(WebScriptSource("selectElement('header_1');")); | 2775 frame->executeScript(WebScriptSource("selectElement('header_1');")); |
2777 EXPECT_EQ("Header 1.", selectionAsString(frame)); | 2776 EXPECT_EQ("Header 1.", selectionAsString(frame)); |
(...skipping 25 matching lines...) Expand all Loading... |
2803 EXPECT_EQ("Editable 2.", selectionAsString(frame)); | 2802 EXPECT_EQ("Editable 2.", selectionAsString(frame)); |
2804 frame->selectRange(bottomRightMinusOne(elementBounds(frame, "editable_2")),
topLeft(elementBounds(frame, "header_2"))); | 2803 frame->selectRange(bottomRightMinusOne(elementBounds(frame, "editable_2")),
topLeft(elementBounds(frame, "header_2"))); |
2805 // positionForPoint returns the wrong values for contenteditable spans. See | 2804 // positionForPoint returns the wrong values for contenteditable spans. See |
2806 // http://crbug.com/238334. | 2805 // http://crbug.com/238334. |
2807 // EXPECT_EQ("[ Editable 1. Editable 2.", selectionAsString(frame)); | 2806 // EXPECT_EQ("[ Editable 1. Editable 2.", selectionAsString(frame)); |
2808 } | 2807 } |
2809 | 2808 |
2810 TEST_F(WebFrameTest, SelectRangeCanMoveSelectionEnd) | 2809 TEST_F(WebFrameTest, SelectRangeCanMoveSelectionEnd) |
2811 { | 2810 { |
2812 registerMockedHttpURLLoad("text_selection.html"); | 2811 registerMockedHttpURLLoad("text_selection.html"); |
2813 m_webView = createWebViewForTextSelection(m_baseURL + "text_selection.html")
; | 2812 FrameTestHelpers::WebViewHelper webViewHelper; |
2814 WebFrame* frame = m_webView->mainFrame(); | 2813 initializeTextSelectionWebView(m_baseURL + "text_selection.html", &webViewHe
lper); |
| 2814 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
2815 | 2815 |
2816 // Select first span. We can move the end to include the second span. | 2816 // Select first span. We can move the end to include the second span. |
2817 frame->executeScript(WebScriptSource("selectElement('header_1');")); | 2817 frame->executeScript(WebScriptSource("selectElement('header_1');")); |
2818 EXPECT_EQ("Header 1.", selectionAsString(frame)); | 2818 EXPECT_EQ("Header 1.", selectionAsString(frame)); |
2819 frame->selectRange(topLeft(elementBounds(frame, "header_1")), bottomRightMin
usOne(elementBounds(frame, "header_2"))); | 2819 frame->selectRange(topLeft(elementBounds(frame, "header_1")), bottomRightMin
usOne(elementBounds(frame, "header_2"))); |
2820 EXPECT_EQ("Header 1. Header 2.", selectionAsString(frame)); | 2820 EXPECT_EQ("Header 1. Header 2.", selectionAsString(frame)); |
2821 | 2821 |
2822 // We can move the start and end together. | 2822 // We can move the start and end together. |
2823 frame->executeScript(WebScriptSource("selectElement('header_2');")); | 2823 frame->executeScript(WebScriptSource("selectElement('header_2');")); |
2824 EXPECT_EQ("Header 2.", selectionAsString(frame)); | 2824 EXPECT_EQ("Header 2.", selectionAsString(frame)); |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2857 static int computeOffset(WebCore::RenderObject* renderer, int x, int y) | 2857 static int computeOffset(WebCore::RenderObject* renderer, int x, int y) |
2858 { | 2858 { |
2859 return WebCore::VisiblePosition(renderer->positionForPoint(WebCore::LayoutPo
int(x, y))).deepEquivalent().computeOffsetInContainerNode(); | 2859 return WebCore::VisiblePosition(renderer->positionForPoint(WebCore::LayoutPo
int(x, y))).deepEquivalent().computeOffsetInContainerNode(); |
2860 } | 2860 } |
2861 | 2861 |
2862 // positionForPoint returns the wrong values for contenteditable spans. See | 2862 // positionForPoint returns the wrong values for contenteditable spans. See |
2863 // http://crbug.com/238334. | 2863 // http://crbug.com/238334. |
2864 TEST_F(WebFrameTest, DISABLED_PositionForPointTest) | 2864 TEST_F(WebFrameTest, DISABLED_PositionForPointTest) |
2865 { | 2865 { |
2866 registerMockedHttpURLLoad("select_range_span_editable.html"); | 2866 registerMockedHttpURLLoad("select_range_span_editable.html"); |
2867 m_webView = createWebViewForTextSelection(m_baseURL + "select_range_span_edi
table.html"); | 2867 FrameTestHelpers::WebViewHelper webViewHelper; |
2868 WebFrameImpl* mainFrame = toWebFrameImpl(m_webView->mainFrame()); | 2868 initializeTextSelectionWebView(m_baseURL + "select_range_span_editable.html"
, &webViewHelper); |
| 2869 WebFrameImpl* mainFrame = toWebFrameImpl(webViewHelper.webView()->mainFrame(
)); |
2869 WebCore::RenderObject* renderer = mainFrame->frame()->selection().rootEditab
leElement()->renderer(); | 2870 WebCore::RenderObject* renderer = mainFrame->frame()->selection().rootEditab
leElement()->renderer(); |
2870 EXPECT_EQ(0, computeOffset(renderer, -1, -1)); | 2871 EXPECT_EQ(0, computeOffset(renderer, -1, -1)); |
2871 EXPECT_EQ(64, computeOffset(renderer, 1000, 1000)); | 2872 EXPECT_EQ(64, computeOffset(renderer, 1000, 1000)); |
2872 | 2873 |
2873 registerMockedHttpURLLoad("select_range_div_editable.html"); | 2874 registerMockedHttpURLLoad("select_range_div_editable.html"); |
2874 m_webView = createWebViewForTextSelection(m_baseURL + "select_range_div_edit
able.html"); | 2875 initializeTextSelectionWebView(m_baseURL + "select_range_div_editable.html",
&webViewHelper); |
2875 mainFrame = toWebFrameImpl(m_webView->mainFrame()); | 2876 mainFrame = toWebFrameImpl(webViewHelper.webView()->mainFrame()); |
2876 renderer = mainFrame->frame()->selection().rootEditableElement()->renderer()
; | 2877 renderer = mainFrame->frame()->selection().rootEditableElement()->renderer()
; |
2877 EXPECT_EQ(0, computeOffset(renderer, -1, -1)); | 2878 EXPECT_EQ(0, computeOffset(renderer, -1, -1)); |
2878 EXPECT_EQ(64, computeOffset(renderer, 1000, 1000)); | 2879 EXPECT_EQ(64, computeOffset(renderer, 1000, 1000)); |
2879 } | 2880 } |
2880 | 2881 |
2881 #if !OS(MACOSX) | 2882 #if !OS(MACOSX) |
2882 TEST_F(WebFrameTest, SelectRangeStaysHorizontallyAlignedWhenMoved) | 2883 TEST_F(WebFrameTest, SelectRangeStaysHorizontallyAlignedWhenMoved) |
2883 { | 2884 { |
2884 WebFrameImpl* frame; | |
2885 registerMockedHttpURLLoad("move_caret.html"); | 2885 registerMockedHttpURLLoad("move_caret.html"); |
2886 | 2886 |
2887 m_webView = createWebViewForTextSelection(m_baseURL + "move_caret.html"); | 2887 FrameTestHelpers::WebViewHelper webViewHelper; |
2888 frame = (WebFrameImpl*)m_webView->mainFrame(); | 2888 initializeTextSelectionWebView(m_baseURL + "move_caret.html", &webViewHelper
); |
| 2889 WebFrameImpl* frame = toWebFrameImpl(webViewHelper.webView()->mainFrame()); |
2889 | 2890 |
2890 WebRect initialStartRect; | 2891 WebRect initialStartRect; |
2891 WebRect initialEndRect; | 2892 WebRect initialEndRect; |
2892 WebRect startRect; | 2893 WebRect startRect; |
2893 WebRect endRect; | 2894 WebRect endRect; |
2894 | 2895 |
2895 frame->executeScript(WebScriptSource("selectRange();")); | 2896 frame->executeScript(WebScriptSource("selectRange();")); |
2896 m_webView->selectionBounds(initialStartRect, initialEndRect); | 2897 webViewHelper.webView()->selectionBounds(initialStartRect, initialEndRect); |
2897 WebPoint movedStart(topLeft(initialStartRect)); | 2898 WebPoint movedStart(topLeft(initialStartRect)); |
2898 | 2899 |
2899 movedStart.y += 40; | 2900 movedStart.y += 40; |
2900 frame->selectRange(movedStart, bottomRightMinusOne(initialEndRect)); | 2901 frame->selectRange(movedStart, bottomRightMinusOne(initialEndRect)); |
2901 m_webView->selectionBounds(startRect, endRect); | 2902 webViewHelper.webView()->selectionBounds(startRect, endRect); |
2902 EXPECT_EQ(startRect, initialStartRect); | 2903 EXPECT_EQ(startRect, initialStartRect); |
2903 EXPECT_EQ(endRect, initialEndRect); | 2904 EXPECT_EQ(endRect, initialEndRect); |
2904 | 2905 |
2905 movedStart.y -= 80; | 2906 movedStart.y -= 80; |
2906 frame->selectRange(movedStart, bottomRightMinusOne(initialEndRect)); | 2907 frame->selectRange(movedStart, bottomRightMinusOne(initialEndRect)); |
2907 m_webView->selectionBounds(startRect, endRect); | 2908 webViewHelper.webView()->selectionBounds(startRect, endRect); |
2908 EXPECT_EQ(startRect, initialStartRect); | 2909 EXPECT_EQ(startRect, initialStartRect); |
2909 EXPECT_EQ(endRect, initialEndRect); | 2910 EXPECT_EQ(endRect, initialEndRect); |
2910 | 2911 |
2911 WebPoint movedEnd(bottomRightMinusOne(initialEndRect)); | 2912 WebPoint movedEnd(bottomRightMinusOne(initialEndRect)); |
2912 | 2913 |
2913 movedEnd.y += 40; | 2914 movedEnd.y += 40; |
2914 frame->selectRange(topLeft(initialStartRect), movedEnd); | 2915 frame->selectRange(topLeft(initialStartRect), movedEnd); |
2915 m_webView->selectionBounds(startRect, endRect); | 2916 webViewHelper.webView()->selectionBounds(startRect, endRect); |
2916 EXPECT_EQ(startRect, initialStartRect); | 2917 EXPECT_EQ(startRect, initialStartRect); |
2917 EXPECT_EQ(endRect, initialEndRect); | 2918 EXPECT_EQ(endRect, initialEndRect); |
2918 | 2919 |
2919 movedEnd.y -= 80; | 2920 movedEnd.y -= 80; |
2920 frame->selectRange(topLeft(initialStartRect), movedEnd); | 2921 frame->selectRange(topLeft(initialStartRect), movedEnd); |
2921 m_webView->selectionBounds(startRect, endRect); | 2922 webViewHelper.webView()->selectionBounds(startRect, endRect); |
2922 EXPECT_EQ(startRect, initialStartRect); | 2923 EXPECT_EQ(startRect, initialStartRect); |
2923 EXPECT_EQ(endRect, initialEndRect); | 2924 EXPECT_EQ(endRect, initialEndRect); |
2924 } | 2925 } |
2925 | 2926 |
2926 TEST_F(WebFrameTest, MoveCaretStaysHorizontallyAlignedWhenMoved) | 2927 TEST_F(WebFrameTest, MoveCaretStaysHorizontallyAlignedWhenMoved) |
2927 { | 2928 { |
2928 WebFrameImpl* frame; | 2929 WebFrameImpl* frame; |
2929 registerMockedHttpURLLoad("move_caret.html"); | 2930 registerMockedHttpURLLoad("move_caret.html"); |
2930 | 2931 |
2931 m_webView = createWebViewForTextSelection(m_baseURL + "move_caret.html"); | 2932 FrameTestHelpers::WebViewHelper webViewHelper; |
2932 frame = (WebFrameImpl*)m_webView->mainFrame(); | 2933 initializeTextSelectionWebView(m_baseURL + "move_caret.html", &webViewHelper
); |
| 2934 frame = (WebFrameImpl*)webViewHelper.webView()->mainFrame(); |
2933 | 2935 |
2934 WebRect initialStartRect; | 2936 WebRect initialStartRect; |
2935 WebRect initialEndRect; | 2937 WebRect initialEndRect; |
2936 WebRect startRect; | 2938 WebRect startRect; |
2937 WebRect endRect; | 2939 WebRect endRect; |
2938 | 2940 |
2939 frame->executeScript(WebScriptSource("selectCaret();")); | 2941 frame->executeScript(WebScriptSource("selectCaret();")); |
2940 m_webView->selectionBounds(initialStartRect, initialEndRect); | 2942 webViewHelper.webView()->selectionBounds(initialStartRect, initialEndRect); |
2941 WebPoint moveTo(topLeft(initialStartRect)); | 2943 WebPoint moveTo(topLeft(initialStartRect)); |
2942 | 2944 |
2943 moveTo.y += 40; | 2945 moveTo.y += 40; |
2944 frame->moveCaretSelectionTowardsWindowPoint(moveTo); | 2946 frame->moveCaretSelectionTowardsWindowPoint(moveTo); |
2945 m_webView->selectionBounds(startRect, endRect); | 2947 webViewHelper.webView()->selectionBounds(startRect, endRect); |
2946 EXPECT_EQ(startRect, initialStartRect); | 2948 EXPECT_EQ(startRect, initialStartRect); |
2947 EXPECT_EQ(endRect, initialEndRect); | 2949 EXPECT_EQ(endRect, initialEndRect); |
2948 | 2950 |
2949 moveTo.y -= 80; | 2951 moveTo.y -= 80; |
2950 frame->moveCaretSelectionTowardsWindowPoint(moveTo); | 2952 frame->moveCaretSelectionTowardsWindowPoint(moveTo); |
2951 m_webView->selectionBounds(startRect, endRect); | 2953 webViewHelper.webView()->selectionBounds(startRect, endRect); |
2952 EXPECT_EQ(startRect, initialStartRect); | 2954 EXPECT_EQ(startRect, initialStartRect); |
2953 EXPECT_EQ(endRect, initialEndRect); | 2955 EXPECT_EQ(endRect, initialEndRect); |
2954 } | 2956 } |
2955 #endif | 2957 #endif |
2956 | 2958 |
2957 class DisambiguationPopupTestWebViewClient : public WebViewClient { | 2959 class DisambiguationPopupTestWebViewClient : public WebViewClient { |
2958 public: | 2960 public: |
2959 virtual bool didTapMultipleTargets(const WebGestureEvent&, const WebVector<W
ebRect>& targetRects) OVERRIDE | 2961 virtual bool didTapMultipleTargets(const WebGestureEvent&, const WebVector<W
ebRect>& targetRects) OVERRIDE |
2960 { | 2962 { |
2961 EXPECT_GE(targetRects.size(), 2u); | 2963 EXPECT_GE(targetRects.size(), 2u); |
(...skipping 19 matching lines...) Expand all Loading... |
2981 | 2983 |
2982 TEST_F(WebFrameTest, DisambiguationPopup) | 2984 TEST_F(WebFrameTest, DisambiguationPopup) |
2983 { | 2985 { |
2984 const std::string htmlFile = "disambiguation_popup.html"; | 2986 const std::string htmlFile = "disambiguation_popup.html"; |
2985 registerMockedHttpURLLoad(htmlFile); | 2987 registerMockedHttpURLLoad(htmlFile); |
2986 | 2988 |
2987 DisambiguationPopupTestWebViewClient client; | 2989 DisambiguationPopupTestWebViewClient client; |
2988 | 2990 |
2989 // Make sure we initialize to minimum scale, even if the window size | 2991 // Make sure we initialize to minimum scale, even if the window size |
2990 // only becomes available after the load begins. | 2992 // only becomes available after the load begins. |
2991 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + htmlFile, tru
e, 0, &client); | 2993 FrameTestHelpers::WebViewHelper webViewHelper; |
2992 m_webView->resize(WebSize(1000, 1000)); | 2994 webViewHelper.initializeAndLoad(m_baseURL + htmlFile, true, 0, &client); |
2993 m_webView->layout(); | 2995 webViewHelper.webView()->resize(WebSize(1000, 1000)); |
| 2996 webViewHelper.webView()->layout(); |
2994 | 2997 |
2995 client.resetTriggered(); | 2998 client.resetTriggered(); |
2996 m_webView->handleInputEvent(fatTap(0, 0)); | 2999 webViewHelper.webView()->handleInputEvent(fatTap(0, 0)); |
2997 EXPECT_FALSE(client.triggered()); | 3000 EXPECT_FALSE(client.triggered()); |
2998 | 3001 |
2999 client.resetTriggered(); | 3002 client.resetTriggered(); |
3000 m_webView->handleInputEvent(fatTap(200, 115)); | 3003 webViewHelper.webView()->handleInputEvent(fatTap(200, 115)); |
3001 EXPECT_FALSE(client.triggered()); | 3004 EXPECT_FALSE(client.triggered()); |
3002 | 3005 |
3003 for (int i = 0; i <= 46; i++) { | 3006 for (int i = 0; i <= 46; i++) { |
3004 client.resetTriggered(); | 3007 client.resetTriggered(); |
3005 m_webView->handleInputEvent(fatTap(120, 230 + i * 5)); | 3008 webViewHelper.webView()->handleInputEvent(fatTap(120, 230 + i * 5)); |
3006 | 3009 |
3007 int j = i % 10; | 3010 int j = i % 10; |
3008 if (j >= 7 && j <= 9) | 3011 if (j >= 7 && j <= 9) |
3009 EXPECT_TRUE(client.triggered()); | 3012 EXPECT_TRUE(client.triggered()); |
3010 else | 3013 else |
3011 EXPECT_FALSE(client.triggered()); | 3014 EXPECT_FALSE(client.triggered()); |
3012 } | 3015 } |
3013 | 3016 |
3014 for (int i = 0; i <= 46; i++) { | 3017 for (int i = 0; i <= 46; i++) { |
3015 client.resetTriggered(); | 3018 client.resetTriggered(); |
3016 m_webView->handleInputEvent(fatTap(10 + i * 5, 590)); | 3019 webViewHelper.webView()->handleInputEvent(fatTap(10 + i * 5, 590)); |
3017 | 3020 |
3018 int j = i % 10; | 3021 int j = i % 10; |
3019 if (j >= 7 && j <= 9) | 3022 if (j >= 7 && j <= 9) |
3020 EXPECT_TRUE(client.triggered()); | 3023 EXPECT_TRUE(client.triggered()); |
3021 else | 3024 else |
3022 EXPECT_FALSE(client.triggered()); | 3025 EXPECT_FALSE(client.triggered()); |
3023 } | 3026 } |
3024 | |
3025 m_webView->close(); | |
3026 m_webView = 0; | |
3027 | |
3028 } | 3027 } |
3029 | 3028 |
3030 TEST_F(WebFrameTest, DisambiguationPopupNoContainer) | 3029 TEST_F(WebFrameTest, DisambiguationPopupNoContainer) |
3031 { | 3030 { |
3032 registerMockedHttpURLLoad("disambiguation_popup_no_container.html"); | 3031 registerMockedHttpURLLoad("disambiguation_popup_no_container.html"); |
3033 | 3032 |
3034 DisambiguationPopupTestWebViewClient client; | 3033 DisambiguationPopupTestWebViewClient client; |
3035 | 3034 |
3036 // Make sure we initialize to minimum scale, even if the window size | 3035 // Make sure we initialize to minimum scale, even if the window size |
3037 // only becomes available after the load begins. | 3036 // only becomes available after the load begins. |
3038 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "disambiguati
on_popup_no_container.html", true, 0, &client); | 3037 FrameTestHelpers::WebViewHelper webViewHelper; |
3039 m_webView->resize(WebSize(1000, 1000)); | 3038 webViewHelper.initializeAndLoad(m_baseURL + "disambiguation_popup_no_contain
er.html", true, 0, &client); |
3040 m_webView->layout(); | 3039 webViewHelper.webView()->resize(WebSize(1000, 1000)); |
| 3040 webViewHelper.webView()->layout(); |
3041 | 3041 |
3042 client.resetTriggered(); | 3042 client.resetTriggered(); |
3043 m_webView->handleInputEvent(fatTap(50, 50)); | 3043 webViewHelper.webView()->handleInputEvent(fatTap(50, 50)); |
3044 EXPECT_FALSE(client.triggered()); | 3044 EXPECT_FALSE(client.triggered()); |
3045 | |
3046 m_webView->close(); | |
3047 m_webView = 0; | |
3048 } | 3045 } |
3049 | 3046 |
3050 TEST_F(WebFrameTest, DisambiguationPopupMobileSite) | 3047 TEST_F(WebFrameTest, DisambiguationPopupMobileSite) |
3051 { | 3048 { |
3052 const std::string htmlFile = "disambiguation_popup_mobile_site.html"; | 3049 const std::string htmlFile = "disambiguation_popup_mobile_site.html"; |
3053 registerMockedHttpURLLoad(htmlFile); | 3050 registerMockedHttpURLLoad(htmlFile); |
3054 | 3051 |
3055 DisambiguationPopupTestWebViewClient client; | 3052 DisambiguationPopupTestWebViewClient client; |
3056 | 3053 |
3057 // Make sure we initialize to minimum scale, even if the window size | 3054 // Make sure we initialize to minimum scale, even if the window size |
3058 // only becomes available after the load begins. | 3055 // only becomes available after the load begins. |
3059 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + htmlFile, tru
e, 0, &client); | 3056 FrameTestHelpers::WebViewHelper webViewHelper; |
3060 m_webView->enableFixedLayoutMode(true); | 3057 webViewHelper.initializeAndLoad(m_baseURL + htmlFile, true, 0, &client); |
3061 m_webView->settings()->setViewportEnabled(true); | 3058 webViewHelper.webView()->enableFixedLayoutMode(true); |
3062 m_webView->resize(WebSize(1000, 1000)); | 3059 webViewHelper.webView()->settings()->setViewportEnabled(true); |
3063 m_webView->layout(); | 3060 webViewHelper.webView()->resize(WebSize(1000, 1000)); |
| 3061 webViewHelper.webView()->layout(); |
3064 | 3062 |
3065 client.resetTriggered(); | 3063 client.resetTriggered(); |
3066 m_webView->handleInputEvent(fatTap(0, 0)); | 3064 webViewHelper.webView()->handleInputEvent(fatTap(0, 0)); |
3067 EXPECT_FALSE(client.triggered()); | 3065 EXPECT_FALSE(client.triggered()); |
3068 | 3066 |
3069 client.resetTriggered(); | 3067 client.resetTriggered(); |
3070 m_webView->handleInputEvent(fatTap(200, 115)); | 3068 webViewHelper.webView()->handleInputEvent(fatTap(200, 115)); |
3071 EXPECT_FALSE(client.triggered()); | 3069 EXPECT_FALSE(client.triggered()); |
3072 | 3070 |
3073 for (int i = 0; i <= 46; i++) { | 3071 for (int i = 0; i <= 46; i++) { |
3074 client.resetTriggered(); | 3072 client.resetTriggered(); |
3075 m_webView->handleInputEvent(fatTap(120, 230 + i * 5)); | 3073 webViewHelper.webView()->handleInputEvent(fatTap(120, 230 + i * 5)); |
3076 EXPECT_FALSE(client.triggered()); | 3074 EXPECT_FALSE(client.triggered()); |
3077 } | 3075 } |
3078 | 3076 |
3079 for (int i = 0; i <= 46; i++) { | 3077 for (int i = 0; i <= 46; i++) { |
3080 client.resetTriggered(); | 3078 client.resetTriggered(); |
3081 m_webView->handleInputEvent(fatTap(10 + i * 5, 590)); | 3079 webViewHelper.webView()->handleInputEvent(fatTap(10 + i * 5, 590)); |
3082 EXPECT_FALSE(client.triggered()); | 3080 EXPECT_FALSE(client.triggered()); |
3083 } | 3081 } |
3084 | |
3085 m_webView->close(); | |
3086 m_webView = 0; | |
3087 } | 3082 } |
3088 | 3083 |
3089 TEST_F(WebFrameTest, DisambiguationPopupViewportSite) | 3084 TEST_F(WebFrameTest, DisambiguationPopupViewportSite) |
3090 { | 3085 { |
3091 const std::string htmlFile = "disambiguation_popup_viewport_site.html"; | 3086 const std::string htmlFile = "disambiguation_popup_viewport_site.html"; |
3092 registerMockedHttpURLLoad(htmlFile); | 3087 registerMockedHttpURLLoad(htmlFile); |
3093 | 3088 |
3094 DisambiguationPopupTestWebViewClient client; | 3089 DisambiguationPopupTestWebViewClient client; |
3095 | 3090 |
3096 // Make sure we initialize to minimum scale, even if the window size | 3091 // Make sure we initialize to minimum scale, even if the window size |
3097 // only becomes available after the load begins. | 3092 // only becomes available after the load begins. |
3098 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + htmlFile, tru
e, 0, &client); | 3093 FrameTestHelpers::WebViewHelper webViewHelper; |
3099 m_webView->enableFixedLayoutMode(true); | 3094 webViewHelper.initializeAndLoad(m_baseURL + htmlFile, true, 0, &client); |
3100 m_webView->settings()->setViewportEnabled(true); | 3095 webViewHelper.webView()->enableFixedLayoutMode(true); |
3101 m_webView->resize(WebSize(1000, 1000)); | 3096 webViewHelper.webView()->settings()->setViewportEnabled(true); |
3102 m_webView->layout(); | 3097 webViewHelper.webView()->resize(WebSize(1000, 1000)); |
| 3098 webViewHelper.webView()->layout(); |
3103 | 3099 |
3104 client.resetTriggered(); | 3100 client.resetTriggered(); |
3105 m_webView->handleInputEvent(fatTap(0, 0)); | 3101 webViewHelper.webView()->handleInputEvent(fatTap(0, 0)); |
3106 EXPECT_FALSE(client.triggered()); | 3102 EXPECT_FALSE(client.triggered()); |
3107 | 3103 |
3108 client.resetTriggered(); | 3104 client.resetTriggered(); |
3109 m_webView->handleInputEvent(fatTap(200, 115)); | 3105 webViewHelper.webView()->handleInputEvent(fatTap(200, 115)); |
3110 EXPECT_FALSE(client.triggered()); | 3106 EXPECT_FALSE(client.triggered()); |
3111 | 3107 |
3112 for (int i = 0; i <= 46; i++) { | 3108 for (int i = 0; i <= 46; i++) { |
3113 client.resetTriggered(); | 3109 client.resetTriggered(); |
3114 m_webView->handleInputEvent(fatTap(120, 230 + i * 5)); | 3110 webViewHelper.webView()->handleInputEvent(fatTap(120, 230 + i * 5)); |
3115 EXPECT_FALSE(client.triggered()); | 3111 EXPECT_FALSE(client.triggered()); |
3116 } | 3112 } |
3117 | 3113 |
3118 for (int i = 0; i <= 46; i++) { | 3114 for (int i = 0; i <= 46; i++) { |
3119 client.resetTriggered(); | 3115 client.resetTriggered(); |
3120 m_webView->handleInputEvent(fatTap(10 + i * 5, 590)); | 3116 webViewHelper.webView()->handleInputEvent(fatTap(10 + i * 5, 590)); |
3121 EXPECT_FALSE(client.triggered()); | 3117 EXPECT_FALSE(client.triggered()); |
3122 } | 3118 } |
3123 | |
3124 m_webView->close(); | |
3125 m_webView = 0; | |
3126 } | 3119 } |
3127 | 3120 |
3128 TEST_F(WebFrameTest, DisambiguationPopupBlacklist) | 3121 TEST_F(WebFrameTest, DisambiguationPopupBlacklist) |
3129 { | 3122 { |
3130 const unsigned viewportWidth = 500; | 3123 const unsigned viewportWidth = 500; |
3131 const unsigned viewportHeight = 1000; | 3124 const unsigned viewportHeight = 1000; |
3132 const unsigned divHeight = 100; | 3125 const unsigned divHeight = 100; |
3133 const std::string htmlFile = "disambiguation_popup_blacklist.html"; | 3126 const std::string htmlFile = "disambiguation_popup_blacklist.html"; |
3134 registerMockedHttpURLLoad(htmlFile); | 3127 registerMockedHttpURLLoad(htmlFile); |
3135 | 3128 |
3136 DisambiguationPopupTestWebViewClient client; | 3129 DisambiguationPopupTestWebViewClient client; |
3137 | 3130 |
3138 // Make sure we initialize to minimum scale, even if the window size | 3131 // Make sure we initialize to minimum scale, even if the window size |
3139 // only becomes available after the load begins. | 3132 // only becomes available after the load begins. |
3140 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + htmlFile, tru
e, 0, &client); | 3133 FrameTestHelpers::WebViewHelper webViewHelper; |
3141 m_webView->resize(WebSize(viewportWidth, viewportHeight)); | 3134 webViewHelper.initializeAndLoad(m_baseURL + htmlFile, true, 0, &client); |
3142 m_webView->layout(); | 3135 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
| 3136 webViewHelper.webView()->layout(); |
3143 | 3137 |
3144 // Click somewhere where the popup shouldn't appear. | 3138 // Click somewhere where the popup shouldn't appear. |
3145 client.resetTriggered(); | 3139 client.resetTriggered(); |
3146 m_webView->handleInputEvent(fatTap(viewportWidth / 2, 0)); | 3140 webViewHelper.webView()->handleInputEvent(fatTap(viewportWidth / 2, 0)); |
3147 EXPECT_FALSE(client.triggered()); | 3141 EXPECT_FALSE(client.triggered()); |
3148 | 3142 |
3149 // Click directly in between two container divs with click handlers, with ch
ildren that don't handle clicks. | 3143 // Click directly in between two container divs with click handlers, with ch
ildren that don't handle clicks. |
3150 client.resetTriggered(); | 3144 client.resetTriggered(); |
3151 m_webView->handleInputEvent(fatTap(viewportWidth / 2, divHeight)); | 3145 webViewHelper.webView()->handleInputEvent(fatTap(viewportWidth / 2, divHeigh
t)); |
3152 EXPECT_TRUE(client.triggered()); | 3146 EXPECT_TRUE(client.triggered()); |
3153 | 3147 |
3154 // The third div container should be blacklisted if you click on the link it
contains. | 3148 // The third div container should be blacklisted if you click on the link it
contains. |
3155 client.resetTriggered(); | 3149 client.resetTriggered(); |
3156 m_webView->handleInputEvent(fatTap(viewportWidth / 2, divHeight * 3.25)); | 3150 webViewHelper.webView()->handleInputEvent(fatTap(viewportWidth / 2, divHeigh
t * 3.25)); |
3157 EXPECT_FALSE(client.triggered()); | 3151 EXPECT_FALSE(client.triggered()); |
3158 | |
3159 m_webView->close(); | |
3160 m_webView = 0; | |
3161 } | 3152 } |
3162 | 3153 |
3163 TEST_F(WebFrameTest, DisambiguationPopupPageScale) | 3154 TEST_F(WebFrameTest, DisambiguationPopupPageScale) |
3164 { | 3155 { |
3165 registerMockedHttpURLLoad("disambiguation_popup_page_scale.html"); | 3156 registerMockedHttpURLLoad("disambiguation_popup_page_scale.html"); |
3166 | 3157 |
3167 DisambiguationPopupTestWebViewClient client; | 3158 DisambiguationPopupTestWebViewClient client; |
3168 | 3159 |
3169 // Make sure we initialize to minimum scale, even if the window size | 3160 // Make sure we initialize to minimum scale, even if the window size |
3170 // only becomes available after the load begins. | 3161 // only becomes available after the load begins. |
3171 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "disambiguati
on_popup_page_scale.html", true, 0, &client); | 3162 FrameTestHelpers::WebViewHelper webViewHelper; |
3172 m_webView->resize(WebSize(1000, 1000)); | 3163 webViewHelper.initializeAndLoad(m_baseURL + "disambiguation_popup_page_scale
.html", true, 0, &client); |
3173 m_webView->layout(); | 3164 webViewHelper.webView()->resize(WebSize(1000, 1000)); |
| 3165 webViewHelper.webView()->layout(); |
3174 | 3166 |
3175 client.resetTriggered(); | 3167 client.resetTriggered(); |
3176 m_webView->handleInputEvent(fatTap(80, 80)); | 3168 webViewHelper.webView()->handleInputEvent(fatTap(80, 80)); |
3177 EXPECT_TRUE(client.triggered()); | 3169 EXPECT_TRUE(client.triggered()); |
3178 | 3170 |
3179 client.resetTriggered(); | 3171 client.resetTriggered(); |
3180 m_webView->handleInputEvent(fatTap(230, 190)); | 3172 webViewHelper.webView()->handleInputEvent(fatTap(230, 190)); |
3181 EXPECT_TRUE(client.triggered()); | 3173 EXPECT_TRUE(client.triggered()); |
3182 | 3174 |
3183 m_webView->setPageScaleFactor(3.0f, WebPoint(0, 0)); | 3175 webViewHelper.webView()->setPageScaleFactor(3.0f, WebPoint(0, 0)); |
3184 m_webView->layout(); | 3176 webViewHelper.webView()->layout(); |
3185 | 3177 |
3186 client.resetTriggered(); | 3178 client.resetTriggered(); |
3187 m_webView->handleInputEvent(fatTap(240, 240)); | 3179 webViewHelper.webView()->handleInputEvent(fatTap(240, 240)); |
3188 EXPECT_TRUE(client.triggered()); | 3180 EXPECT_TRUE(client.triggered()); |
3189 | 3181 |
3190 client.resetTriggered(); | 3182 client.resetTriggered(); |
3191 m_webView->handleInputEvent(fatTap(690, 570)); | 3183 webViewHelper.webView()->handleInputEvent(fatTap(690, 570)); |
3192 EXPECT_FALSE(client.triggered()); | 3184 EXPECT_FALSE(client.triggered()); |
3193 | |
3194 m_webView->close(); | |
3195 m_webView = 0; | |
3196 } | 3185 } |
3197 | 3186 |
3198 class TestSubstituteDataWebFrameClient : public WebFrameClient { | 3187 class TestSubstituteDataWebFrameClient : public WebFrameClient { |
3199 public: | 3188 public: |
3200 TestSubstituteDataWebFrameClient() | 3189 TestSubstituteDataWebFrameClient() |
3201 : m_commitCalled(false) | 3190 : m_commitCalled(false) |
3202 { | 3191 { |
3203 } | 3192 } |
3204 | 3193 |
3205 virtual void didFailProvisionalLoad(WebFrame* frame, const WebURLError& erro
r) | 3194 virtual void didFailProvisionalLoad(WebFrame* frame, const WebURLError& erro
r) |
(...skipping 11 matching lines...) Expand all Loading... |
3217 bool commitCalled() const { return m_commitCalled; } | 3206 bool commitCalled() const { return m_commitCalled; } |
3218 | 3207 |
3219 private: | 3208 private: |
3220 bool m_commitCalled; | 3209 bool m_commitCalled; |
3221 }; | 3210 }; |
3222 | 3211 |
3223 TEST_F(WebFrameTest, ReplaceNavigationAfterHistoryNavigation) | 3212 TEST_F(WebFrameTest, ReplaceNavigationAfterHistoryNavigation) |
3224 { | 3213 { |
3225 TestSubstituteDataWebFrameClient webFrameClient; | 3214 TestSubstituteDataWebFrameClient webFrameClient; |
3226 | 3215 |
3227 m_webView = FrameTestHelpers::createWebViewAndLoad("about:blank", true, &web
FrameClient); | 3216 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3217 webViewHelper.initializeAndLoad("about:blank", true, &webFrameClient); |
3228 runPendingTasks(); | 3218 runPendingTasks(); |
3229 WebFrame* frame = m_webView->mainFrame(); | 3219 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
3230 | 3220 |
3231 // Load a url as a history navigation that will return an error. TestSubstit
uteDataWebFrameClient | 3221 // Load a url as a history navigation that will return an error. TestSubstit
uteDataWebFrameClient |
3232 // will start a SubstituteData load in response to the load failure, which s
hould get fully committed. | 3222 // will start a SubstituteData load in response to the load failure, which s
hould get fully committed. |
3233 // Due to https://bugs.webkit.org/show_bug.cgi?id=91685, FrameLoader::didRec
eiveData() wasn't getting | 3223 // Due to https://bugs.webkit.org/show_bug.cgi?id=91685, FrameLoader::didRec
eiveData() wasn't getting |
3234 // called in this case, which resulted in the SubstituteData document not ge
tting displayed. | 3224 // called in this case, which resulted in the SubstituteData document not ge
tting displayed. |
3235 WebURLError error; | 3225 WebURLError error; |
3236 error.reason = 1337; | 3226 error.reason = 1337; |
3237 error.domain = "WebFrameTest"; | 3227 error.domain = "WebFrameTest"; |
3238 std::string errorURL = "http://0.0.0.0"; | 3228 std::string errorURL = "http://0.0.0.0"; |
3239 WebURLResponse response; | 3229 WebURLResponse response; |
3240 response.initialize(); | 3230 response.initialize(); |
3241 response.setURL(URLTestHelpers::toKURL(errorURL)); | 3231 response.setURL(URLTestHelpers::toKURL(errorURL)); |
3242 response.setMIMEType("text/html"); | 3232 response.setMIMEType("text/html"); |
3243 response.setHTTPStatusCode(500); | 3233 response.setHTTPStatusCode(500); |
3244 WebHistoryItem errorHistoryItem; | 3234 WebHistoryItem errorHistoryItem; |
3245 errorHistoryItem.initialize(); | 3235 errorHistoryItem.initialize(); |
3246 errorHistoryItem.setURLString(WebString::fromUTF8(errorURL.c_str(), errorURL
.length())); | 3236 errorHistoryItem.setURLString(WebString::fromUTF8(errorURL.c_str(), errorURL
.length())); |
3247 errorHistoryItem.setOriginalURLString(WebString::fromUTF8(errorURL.c_str(),
errorURL.length())); | 3237 errorHistoryItem.setOriginalURLString(WebString::fromUTF8(errorURL.c_str(),
errorURL.length())); |
3248 Platform::current()->unitTestSupport()->registerMockedErrorURL(URLTestHelper
s::toKURL(errorURL), response, error); | 3238 Platform::current()->unitTestSupport()->registerMockedErrorURL(URLTestHelper
s::toKURL(errorURL), response, error); |
3249 frame->loadHistoryItem(errorHistoryItem); | 3239 frame->loadHistoryItem(errorHistoryItem); |
3250 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 3240 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
3251 | 3241 |
3252 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); | 3242 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); |
3253 EXPECT_EQ("This should appear", std::string(text.utf8().data())); | 3243 EXPECT_EQ("This should appear", std::string(text.utf8().data())); |
3254 EXPECT_TRUE(webFrameClient.commitCalled()); | 3244 EXPECT_TRUE(webFrameClient.commitCalled()); |
3255 | |
3256 m_webView->close(); | |
3257 m_webView = 0; | |
3258 } | 3245 } |
3259 | 3246 |
3260 class TestWillInsertBodyWebFrameClient : public WebFrameClient { | 3247 class TestWillInsertBodyWebFrameClient : public WebFrameClient { |
3261 public: | 3248 public: |
3262 TestWillInsertBodyWebFrameClient() : m_numBodies(0), m_didLoad(false) | 3249 TestWillInsertBodyWebFrameClient() : m_numBodies(0), m_didLoad(false) |
3263 { | 3250 { |
3264 } | 3251 } |
3265 | 3252 |
3266 virtual void didCommitProvisionalLoad(WebFrame*, bool) OVERRIDE | 3253 virtual void didCommitProvisionalLoad(WebFrame*, bool) OVERRIDE |
3267 { | 3254 { |
(...skipping 13 matching lines...) Expand all Loading... |
3281 | 3268 |
3282 int m_numBodies; | 3269 int m_numBodies; |
3283 bool m_didLoad; | 3270 bool m_didLoad; |
3284 }; | 3271 }; |
3285 | 3272 |
3286 TEST_F(WebFrameTest, HTMLDocument) | 3273 TEST_F(WebFrameTest, HTMLDocument) |
3287 { | 3274 { |
3288 registerMockedHttpURLLoad("clipped-body.html"); | 3275 registerMockedHttpURLLoad("clipped-body.html"); |
3289 | 3276 |
3290 TestWillInsertBodyWebFrameClient webFrameClient; | 3277 TestWillInsertBodyWebFrameClient webFrameClient; |
3291 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "clipped-body
.html", false, &webFrameClient); | 3278 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3279 webViewHelper.initializeAndLoad(m_baseURL + "clipped-body.html", false, &web
FrameClient); |
3292 | 3280 |
3293 EXPECT_TRUE(webFrameClient.m_didLoad); | 3281 EXPECT_TRUE(webFrameClient.m_didLoad); |
3294 EXPECT_EQ(1, webFrameClient.m_numBodies); | 3282 EXPECT_EQ(1, webFrameClient.m_numBodies); |
3295 | |
3296 m_webView->close(); | |
3297 m_webView = 0; | |
3298 } | 3283 } |
3299 | 3284 |
3300 TEST_F(WebFrameTest, EmptyDocument) | 3285 TEST_F(WebFrameTest, EmptyDocument) |
3301 { | 3286 { |
3302 registerMockedHttpURLLoad("pageserializer/green_rectangle.svg"); | 3287 registerMockedHttpURLLoad("pageserializer/green_rectangle.svg"); |
3303 | 3288 |
3304 TestWillInsertBodyWebFrameClient webFrameClient; | 3289 TestWillInsertBodyWebFrameClient webFrameClient; |
3305 m_webView = FrameTestHelpers::createWebView(false, &webFrameClient); | 3290 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3291 webViewHelper.initialize(false, &webFrameClient); |
3306 | 3292 |
3307 EXPECT_FALSE(webFrameClient.m_didLoad); | 3293 EXPECT_FALSE(webFrameClient.m_didLoad); |
3308 EXPECT_EQ(1, webFrameClient.m_numBodies); // The empty document that a new f
rame starts with triggers this. | 3294 EXPECT_EQ(1, webFrameClient.m_numBodies); // The empty document that a new f
rame starts with triggers this. |
3309 m_webView->close(); | |
3310 m_webView = 0; | |
3311 } | 3295 } |
3312 | 3296 |
3313 TEST_F(WebFrameTest, MoveCaretSelectionTowardsWindowPointWithNoSelection) | 3297 TEST_F(WebFrameTest, MoveCaretSelectionTowardsWindowPointWithNoSelection) |
3314 { | 3298 { |
3315 m_webView = FrameTestHelpers::createWebViewAndLoad("about:blank", true); | 3299 FrameTestHelpers::WebViewHelper webViewHelper; |
3316 WebFrame* frame = m_webView->mainFrame(); | 3300 webViewHelper.initializeAndLoad("about:blank", true); |
| 3301 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
3317 | 3302 |
3318 // This test passes if this doesn't crash. | 3303 // This test passes if this doesn't crash. |
3319 frame->moveCaretSelectionTowardsWindowPoint(WebPoint(0, 0)); | 3304 frame->moveCaretSelectionTowardsWindowPoint(WebPoint(0, 0)); |
3320 } | 3305 } |
3321 | 3306 |
3322 class SpellCheckClient : public WebSpellCheckClient { | 3307 class SpellCheckClient : public WebSpellCheckClient { |
3323 public: | 3308 public: |
3324 explicit SpellCheckClient(uint32_t hash = 0) : m_numberOfTimesChecked(0), m_
hash(hash) { } | 3309 explicit SpellCheckClient(uint32_t hash = 0) : m_numberOfTimesChecked(0), m_
hash(hash) { } |
3325 virtual ~SpellCheckClient() { } | 3310 virtual ~SpellCheckClient() { } |
3326 virtual void requestCheckingOfText(const WebKit::WebString&, const WebKit::W
ebVector<uint32_t>&, const WebKit::WebVector<unsigned>&, WebKit::WebTextChecking
Completion* completion) OVERRIDE | 3311 virtual void requestCheckingOfText(const WebKit::WebString&, const WebKit::W
ebVector<uint32_t>&, const WebKit::WebVector<unsigned>&, WebKit::WebTextChecking
Completion* completion) OVERRIDE |
3327 { | 3312 { |
3328 ++m_numberOfTimesChecked; | 3313 ++m_numberOfTimesChecked; |
3329 Vector<WebTextCheckingResult> results; | 3314 Vector<WebTextCheckingResult> results; |
3330 const int misspellingStartOffset = 1; | 3315 const int misspellingStartOffset = 1; |
3331 const int misspellingLength = 8; | 3316 const int misspellingLength = 8; |
3332 results.append(WebTextCheckingResult(WebTextCheckingTypeSpelling, misspe
llingStartOffset, misspellingLength, WebString(), m_hash)); | 3317 results.append(WebTextCheckingResult(WebTextCheckingTypeSpelling, misspe
llingStartOffset, misspellingLength, WebString(), m_hash)); |
3333 completion->didFinishCheckingText(results); | 3318 completion->didFinishCheckingText(results); |
3334 } | 3319 } |
3335 int numberOfTimesChecked() const { return m_numberOfTimesChecked; } | 3320 int numberOfTimesChecked() const { return m_numberOfTimesChecked; } |
3336 private: | 3321 private: |
3337 int m_numberOfTimesChecked; | 3322 int m_numberOfTimesChecked; |
3338 uint32_t m_hash; | 3323 uint32_t m_hash; |
3339 }; | 3324 }; |
3340 | 3325 |
3341 TEST_F(WebFrameTest, ReplaceMisspelledRange) | 3326 TEST_F(WebFrameTest, ReplaceMisspelledRange) |
3342 { | 3327 { |
3343 registerMockedHttpURLLoad("spell.html"); | 3328 registerMockedHttpURLLoad("spell.html"); |
3344 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "spell.html")
; | 3329 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3330 webViewHelper.initializeAndLoad(m_baseURL + "spell.html"); |
3345 SpellCheckClient spellcheck; | 3331 SpellCheckClient spellcheck; |
3346 m_webView->setSpellCheckClient(&spellcheck); | 3332 webViewHelper.webView()->setSpellCheckClient(&spellcheck); |
3347 | 3333 |
3348 WebFrameImpl* frame = toWebFrameImpl(m_webView->mainFrame()); | 3334 WebFrameImpl* frame = toWebFrameImpl(webViewHelper.webView()->mainFrame()); |
3349 Document* document = frame->frame()->document(); | 3335 Document* document = frame->frame()->document(); |
3350 Element* element = document->getElementById("data"); | 3336 Element* element = document->getElementById("data"); |
3351 | 3337 |
3352 m_webView->settings()->setAsynchronousSpellCheckingEnabled(true); | 3338 webViewHelper.webView()->settings()->setAsynchronousSpellCheckingEnabled(tru
e); |
3353 m_webView->settings()->setUnifiedTextCheckerEnabled(true); | 3339 webViewHelper.webView()->settings()->setUnifiedTextCheckerEnabled(true); |
3354 m_webView->settings()->setEditingBehavior(WebSettings::EditingBehaviorWin); | 3340 webViewHelper.webView()->settings()->setEditingBehavior(WebSettings::Editing
BehaviorWin); |
3355 | 3341 |
3356 element->focus(); | 3342 element->focus(); |
3357 document->execCommand("InsertText", false, "_wellcome_."); | 3343 document->execCommand("InsertText", false, "_wellcome_."); |
3358 | 3344 |
3359 const int allTextBeginOffset = 0; | 3345 const int allTextBeginOffset = 0; |
3360 const int allTextLength = 11; | 3346 const int allTextLength = 11; |
3361 frame->selectRange(WebRange::fromDocumentRange(frame, allTextBeginOffset, al
lTextLength)); | 3347 frame->selectRange(WebRange::fromDocumentRange(frame, allTextBeginOffset, al
lTextLength)); |
3362 RefPtr<Range> selectionRange = frame->frame()->selection().toNormalizedRange
(); | 3348 RefPtr<Range> selectionRange = frame->frame()->selection().toNormalizedRange
(); |
3363 | 3349 |
3364 EXPECT_EQ(1, spellcheck.numberOfTimesChecked()); | 3350 EXPECT_EQ(1, spellcheck.numberOfTimesChecked()); |
3365 EXPECT_EQ(1U, document->markers()->markersInRange(selectionRange.get(), Docu
mentMarker::Spelling).size()); | 3351 EXPECT_EQ(1U, document->markers()->markersInRange(selectionRange.get(), Docu
mentMarker::Spelling).size()); |
3366 | 3352 |
3367 frame->replaceMisspelledRange("welcome"); | 3353 frame->replaceMisspelledRange("welcome"); |
3368 EXPECT_EQ("_welcome_.", std::string(frame->contentAsText(std::numeric_limits
<size_t>::max()).utf8().data())); | 3354 EXPECT_EQ("_welcome_.", std::string(frame->contentAsText(std::numeric_limits
<size_t>::max()).utf8().data())); |
3369 | |
3370 m_webView->close(); | |
3371 m_webView = 0; | |
3372 } | 3355 } |
3373 | 3356 |
3374 TEST_F(WebFrameTest, RemoveSpellingMarkers) | 3357 TEST_F(WebFrameTest, RemoveSpellingMarkers) |
3375 { | 3358 { |
3376 registerMockedHttpURLLoad("spell.html"); | 3359 registerMockedHttpURLLoad("spell.html"); |
3377 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "spell.html")
; | 3360 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3361 webViewHelper.initializeAndLoad(m_baseURL + "spell.html"); |
3378 SpellCheckClient spellcheck; | 3362 SpellCheckClient spellcheck; |
3379 m_webView->setSpellCheckClient(&spellcheck); | 3363 webViewHelper.webView()->setSpellCheckClient(&spellcheck); |
3380 | 3364 |
3381 WebFrameImpl* frame = toWebFrameImpl(m_webView->mainFrame()); | 3365 WebFrameImpl* frame = toWebFrameImpl(webViewHelper.webView()->mainFrame()); |
3382 Document* document = frame->frame()->document(); | 3366 Document* document = frame->frame()->document(); |
3383 Element* element = document->getElementById("data"); | 3367 Element* element = document->getElementById("data"); |
3384 | 3368 |
3385 m_webView->settings()->setAsynchronousSpellCheckingEnabled(true); | 3369 webViewHelper.webView()->settings()->setAsynchronousSpellCheckingEnabled(tru
e); |
3386 m_webView->settings()->setUnifiedTextCheckerEnabled(true); | 3370 webViewHelper.webView()->settings()->setUnifiedTextCheckerEnabled(true); |
3387 m_webView->settings()->setEditingBehavior(WebSettings::EditingBehaviorWin); | 3371 webViewHelper.webView()->settings()->setEditingBehavior(WebSettings::Editing
BehaviorWin); |
3388 | 3372 |
3389 element->focus(); | 3373 element->focus(); |
3390 document->execCommand("InsertText", false, "_wellcome_."); | 3374 document->execCommand("InsertText", false, "_wellcome_."); |
3391 | 3375 |
3392 frame->removeSpellingMarkers(); | 3376 frame->removeSpellingMarkers(); |
3393 | 3377 |
3394 const int allTextBeginOffset = 0; | 3378 const int allTextBeginOffset = 0; |
3395 const int allTextLength = 11; | 3379 const int allTextLength = 11; |
3396 frame->selectRange(WebRange::fromDocumentRange(frame, allTextBeginOffset, al
lTextLength)); | 3380 frame->selectRange(WebRange::fromDocumentRange(frame, allTextBeginOffset, al
lTextLength)); |
3397 RefPtr<Range> selectionRange = frame->frame()->selection().toNormalizedRange
(); | 3381 RefPtr<Range> selectionRange = frame->frame()->selection().toNormalizedRange
(); |
3398 | 3382 |
3399 EXPECT_EQ(0U, document->markers()->markersInRange(selectionRange.get(), Docu
mentMarker::Spelling).size()); | 3383 EXPECT_EQ(0U, document->markers()->markersInRange(selectionRange.get(), Docu
mentMarker::Spelling).size()); |
3400 | |
3401 m_webView->close(); | |
3402 m_webView = 0; | |
3403 } | 3384 } |
3404 | 3385 |
3405 TEST_F(WebFrameTest, MarkerHashIdentifiers) { | 3386 TEST_F(WebFrameTest, MarkerHashIdentifiers) { |
3406 registerMockedHttpURLLoad("spell.html"); | 3387 registerMockedHttpURLLoad("spell.html"); |
3407 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "spell.html")
; | 3388 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3389 webViewHelper.initializeAndLoad(m_baseURL + "spell.html"); |
3408 | 3390 |
3409 static const uint32_t kHash = 42; | 3391 static const uint32_t kHash = 42; |
3410 SpellCheckClient spellcheck(kHash); | 3392 SpellCheckClient spellcheck(kHash); |
3411 m_webView->setSpellCheckClient(&spellcheck); | 3393 webViewHelper.webView()->setSpellCheckClient(&spellcheck); |
3412 | 3394 |
3413 WebFrameImpl* frame = toWebFrameImpl(m_webView->mainFrame()); | 3395 WebFrameImpl* frame = toWebFrameImpl(webViewHelper.webView()->mainFrame()); |
3414 Document* document = frame->frame()->document(); | 3396 Document* document = frame->frame()->document(); |
3415 Element* element = document->getElementById("data"); | 3397 Element* element = document->getElementById("data"); |
3416 | 3398 |
3417 m_webView->settings()->setAsynchronousSpellCheckingEnabled(true); | 3399 webViewHelper.webView()->settings()->setAsynchronousSpellCheckingEnabled(tru
e); |
3418 m_webView->settings()->setUnifiedTextCheckerEnabled(true); | 3400 webViewHelper.webView()->settings()->setUnifiedTextCheckerEnabled(true); |
3419 m_webView->settings()->setEditingBehavior(WebSettings::EditingBehaviorWin); | 3401 webViewHelper.webView()->settings()->setEditingBehavior(WebSettings::Editing
BehaviorWin); |
3420 | 3402 |
3421 element->focus(); | 3403 element->focus(); |
3422 document->execCommand("InsertText", false, "wellcome."); | 3404 document->execCommand("InsertText", false, "wellcome."); |
3423 | 3405 |
3424 WebVector<uint32_t> documentMarkers; | 3406 WebVector<uint32_t> documentMarkers; |
3425 m_webView->spellingMarkers(&documentMarkers); | 3407 webViewHelper.webView()->spellingMarkers(&documentMarkers); |
3426 EXPECT_EQ(1U, documentMarkers.size()); | 3408 EXPECT_EQ(1U, documentMarkers.size()); |
3427 EXPECT_EQ(kHash, documentMarkers[0]); | 3409 EXPECT_EQ(kHash, documentMarkers[0]); |
3428 | |
3429 m_webView->close(); | |
3430 m_webView = 0; | |
3431 } | 3410 } |
3432 | 3411 |
3433 class StubbornSpellCheckClient : public WebSpellCheckClient { | 3412 class StubbornSpellCheckClient : public WebSpellCheckClient { |
3434 public: | 3413 public: |
3435 StubbornSpellCheckClient() : m_completion(0) { } | 3414 StubbornSpellCheckClient() : m_completion(0) { } |
3436 virtual ~StubbornSpellCheckClient() { } | 3415 virtual ~StubbornSpellCheckClient() { } |
3437 | 3416 |
3438 virtual void requestCheckingOfText( | 3417 virtual void requestCheckingOfText( |
3439 const WebKit::WebString&, | 3418 const WebKit::WebString&, |
3440 const WebKit::WebVector<uint32_t>&, | 3419 const WebKit::WebVector<uint32_t>&, |
(...skipping 15 matching lines...) Expand all Loading... |
3456 m_completion = 0; | 3435 m_completion = 0; |
3457 } | 3436 } |
3458 | 3437 |
3459 private: | 3438 private: |
3460 WebKit::WebTextCheckingCompletion* m_completion; | 3439 WebKit::WebTextCheckingCompletion* m_completion; |
3461 }; | 3440 }; |
3462 | 3441 |
3463 TEST_F(WebFrameTest, SlowSpellcheckMarkerPosition) | 3442 TEST_F(WebFrameTest, SlowSpellcheckMarkerPosition) |
3464 { | 3443 { |
3465 registerMockedHttpURLLoad("spell.html"); | 3444 registerMockedHttpURLLoad("spell.html"); |
3466 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "spell.html")
; | 3445 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3446 webViewHelper.initializeAndLoad(m_baseURL + "spell.html"); |
3467 | 3447 |
3468 StubbornSpellCheckClient spellcheck; | 3448 StubbornSpellCheckClient spellcheck; |
3469 m_webView->setSpellCheckClient(&spellcheck); | 3449 webViewHelper.webView()->setSpellCheckClient(&spellcheck); |
3470 | 3450 |
3471 WebFrameImpl* frame = toWebFrameImpl(m_webView->mainFrame()); | 3451 WebFrameImpl* frame = toWebFrameImpl(webViewHelper.webView()->mainFrame()); |
3472 WebInputElement webInputElement = frame->document().getElementById("data").t
o<WebInputElement>(); | 3452 WebInputElement webInputElement = frame->document().getElementById("data").t
o<WebInputElement>(); |
3473 Document* document = frame->frame()->document(); | 3453 Document* document = frame->frame()->document(); |
3474 Element* element = document->getElementById("data"); | 3454 Element* element = document->getElementById("data"); |
3475 | 3455 |
3476 m_webView->settings()->setAsynchronousSpellCheckingEnabled(true); | 3456 webViewHelper.webView()->settings()->setAsynchronousSpellCheckingEnabled(tru
e); |
3477 m_webView->settings()->setUnifiedTextCheckerEnabled(true); | 3457 webViewHelper.webView()->settings()->setUnifiedTextCheckerEnabled(true); |
3478 m_webView->settings()->setEditingBehavior(WebSettings::EditingBehaviorWin); | 3458 webViewHelper.webView()->settings()->setEditingBehavior(WebSettings::Editing
BehaviorWin); |
3479 | 3459 |
3480 element->focus(); | 3460 element->focus(); |
3481 document->execCommand("InsertText", false, "wellcome "); | 3461 document->execCommand("InsertText", false, "wellcome "); |
3482 webInputElement.setSelectionRange(0, 0); | 3462 webInputElement.setSelectionRange(0, 0); |
3483 document->execCommand("InsertText", false, "he"); | 3463 document->execCommand("InsertText", false, "he"); |
3484 | 3464 |
3485 spellcheck.kick(); | 3465 spellcheck.kick(); |
3486 | 3466 |
3487 WebVector<uint32_t> documentMarkers; | 3467 WebVector<uint32_t> documentMarkers; |
3488 m_webView->spellingMarkers(&documentMarkers); | 3468 webViewHelper.webView()->spellingMarkers(&documentMarkers); |
3489 EXPECT_EQ(0U, documentMarkers.size()); | 3469 EXPECT_EQ(0U, documentMarkers.size()); |
3490 | |
3491 m_webView->close(); | |
3492 m_webView = 0; | |
3493 } | 3470 } |
3494 | 3471 |
3495 // This test verifies that cancelling spelling request does not cause a | 3472 // This test verifies that cancelling spelling request does not cause a |
3496 // write-after-free when there's no spellcheck client set. | 3473 // write-after-free when there's no spellcheck client set. |
3497 TEST_F(WebFrameTest, CancelSpellingRequestCrash) | 3474 TEST_F(WebFrameTest, CancelSpellingRequestCrash) |
3498 { | 3475 { |
3499 registerMockedHttpURLLoad("spell.html"); | 3476 registerMockedHttpURLLoad("spell.html"); |
3500 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "spell.html")
; | 3477 FrameTestHelpers::WebViewHelper webViewHelper; |
3501 m_webView->setSpellCheckClient(0); | 3478 webViewHelper.initializeAndLoad(m_baseURL + "spell.html"); |
| 3479 webViewHelper.webView()->setSpellCheckClient(0); |
3502 | 3480 |
3503 WebFrameImpl* frame = toWebFrameImpl(m_webView->mainFrame()); | 3481 WebFrameImpl* frame = toWebFrameImpl(webViewHelper.webView()->mainFrame()); |
3504 Document* document = frame->frame()->document(); | 3482 Document* document = frame->frame()->document(); |
3505 Element* element = document->getElementById("data"); | 3483 Element* element = document->getElementById("data"); |
3506 | 3484 |
3507 m_webView->settings()->setAsynchronousSpellCheckingEnabled(true); | 3485 webViewHelper.webView()->settings()->setAsynchronousSpellCheckingEnabled(tru
e); |
3508 m_webView->settings()->setUnifiedTextCheckerEnabled(true); | 3486 webViewHelper.webView()->settings()->setUnifiedTextCheckerEnabled(true); |
3509 m_webView->settings()->setEditingBehavior(WebSettings::EditingBehaviorWin); | 3487 webViewHelper.webView()->settings()->setEditingBehavior(WebSettings::Editing
BehaviorWin); |
3510 | 3488 |
3511 element->focus(); | 3489 element->focus(); |
3512 frame->frame()->editor().replaceSelectionWithText("A", false, false); | 3490 frame->frame()->editor().replaceSelectionWithText("A", false, false); |
3513 frame->frame()->editor().spellCheckRequester().cancelCheck(); | 3491 frame->frame()->editor().spellCheckRequester().cancelCheck(); |
3514 | |
3515 m_webView->close(); | |
3516 m_webView = 0; | |
3517 } | 3492 } |
3518 | 3493 |
3519 class TestAccessInitialDocumentWebFrameClient : public WebFrameClient { | 3494 class TestAccessInitialDocumentWebFrameClient : public WebFrameClient { |
3520 public: | 3495 public: |
3521 TestAccessInitialDocumentWebFrameClient() : m_didAccessInitialDocument(false
) | 3496 TestAccessInitialDocumentWebFrameClient() : m_didAccessInitialDocument(false
) |
3522 { | 3497 { |
3523 } | 3498 } |
3524 | 3499 |
3525 virtual void didAccessInitialDocument(WebFrame* frame) | 3500 virtual void didAccessInitialDocument(WebFrame* frame) |
3526 { | 3501 { |
3527 EXPECT_TRUE(!m_didAccessInitialDocument); | 3502 EXPECT_TRUE(!m_didAccessInitialDocument); |
3528 m_didAccessInitialDocument = true; | 3503 m_didAccessInitialDocument = true; |
3529 } | 3504 } |
3530 | 3505 |
3531 bool m_didAccessInitialDocument; | 3506 bool m_didAccessInitialDocument; |
3532 }; | 3507 }; |
3533 | 3508 |
3534 TEST_F(WebFrameTest, DidAccessInitialDocumentBody) | 3509 TEST_F(WebFrameTest, DidAccessInitialDocumentBody) |
3535 { | 3510 { |
3536 TestAccessInitialDocumentWebFrameClient webFrameClient; | 3511 TestAccessInitialDocumentWebFrameClient webFrameClient; |
3537 m_webView = FrameTestHelpers::createWebView(true, &webFrameClient); | 3512 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3513 webViewHelper.initialize(true, &webFrameClient); |
3538 runPendingTasks(); | 3514 runPendingTasks(); |
3539 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); | 3515 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); |
3540 | 3516 |
3541 // Create another window that will try to access it. | 3517 // Create another window that will try to access it. |
3542 WebView* newView = FrameTestHelpers::createWebView(true); | 3518 FrameTestHelpers::WebViewHelper newWebViewHelper; |
3543 newView->mainFrame()->setOpener(m_webView->mainFrame()); | 3519 WebView* newView = newWebViewHelper.initialize(true); |
| 3520 newView->mainFrame()->setOpener(webViewHelper.webView()->mainFrame()); |
3544 runPendingTasks(); | 3521 runPendingTasks(); |
3545 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); | 3522 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); |
3546 | 3523 |
3547 // Access the initial document by modifying the body. | 3524 // Access the initial document by modifying the body. |
3548 newView->mainFrame()->executeScript( | 3525 newView->mainFrame()->executeScript( |
3549 WebScriptSource("window.opener.document.body.innerHTML += 'Modified';"))
; | 3526 WebScriptSource("window.opener.document.body.innerHTML += 'Modified';"))
; |
3550 runPendingTasks(); | 3527 runPendingTasks(); |
3551 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); | 3528 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); |
3552 | 3529 |
3553 // Access the initial document again, to ensure we don't notify twice. | 3530 // Access the initial document again, to ensure we don't notify twice. |
3554 newView->mainFrame()->executeScript( | 3531 newView->mainFrame()->executeScript( |
3555 WebScriptSource("window.opener.document.body.innerHTML += 'Modified';"))
; | 3532 WebScriptSource("window.opener.document.body.innerHTML += 'Modified';"))
; |
3556 runPendingTasks(); | 3533 runPendingTasks(); |
3557 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); | 3534 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); |
3558 | |
3559 newView->close(); | |
3560 m_webView->close(); | |
3561 m_webView = 0; | |
3562 } | 3535 } |
3563 | 3536 |
3564 TEST_F(WebFrameTest, DidAccessInitialDocumentNavigator) | 3537 TEST_F(WebFrameTest, DidAccessInitialDocumentNavigator) |
3565 { | 3538 { |
3566 TestAccessInitialDocumentWebFrameClient webFrameClient; | 3539 TestAccessInitialDocumentWebFrameClient webFrameClient; |
3567 m_webView = FrameTestHelpers::createWebView(true, &webFrameClient); | 3540 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3541 webViewHelper.initialize(true, &webFrameClient); |
3568 runPendingTasks(); | 3542 runPendingTasks(); |
3569 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); | 3543 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); |
3570 | 3544 |
3571 // Create another window that will try to access it. | 3545 // Create another window that will try to access it. |
3572 WebView* newView = FrameTestHelpers::createWebView(true); | 3546 FrameTestHelpers::WebViewHelper newWebViewHelper; |
3573 newView->mainFrame()->setOpener(m_webView->mainFrame()); | 3547 WebView* newView = newWebViewHelper.initialize(true); |
| 3548 newView->mainFrame()->setOpener(webViewHelper.webView()->mainFrame()); |
3574 runPendingTasks(); | 3549 runPendingTasks(); |
3575 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); | 3550 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); |
3576 | 3551 |
3577 // Access the initial document to get to the navigator object. | 3552 // Access the initial document to get to the navigator object. |
3578 newView->mainFrame()->executeScript( | 3553 newView->mainFrame()->executeScript( |
3579 WebScriptSource("console.log(window.opener.navigator);")); | 3554 WebScriptSource("console.log(window.opener.navigator);")); |
3580 runPendingTasks(); | 3555 runPendingTasks(); |
3581 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); | 3556 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); |
3582 | |
3583 newView->close(); | |
3584 m_webView->close(); | |
3585 m_webView = 0; | |
3586 } | 3557 } |
3587 | 3558 |
3588 TEST_F(WebFrameTest, DidAccessInitialDocumentViaJavascriptUrl) | 3559 TEST_F(WebFrameTest, DidAccessInitialDocumentViaJavascriptUrl) |
3589 { | 3560 { |
3590 TestAccessInitialDocumentWebFrameClient webFrameClient; | 3561 TestAccessInitialDocumentWebFrameClient webFrameClient; |
3591 m_webView = FrameTestHelpers::createWebView(true, &webFrameClient); | 3562 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3563 webViewHelper.initialize(true, &webFrameClient); |
3592 runPendingTasks(); | 3564 runPendingTasks(); |
3593 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); | 3565 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); |
3594 | 3566 |
3595 // Access the initial document from a javascript: URL. | 3567 // Access the initial document from a javascript: URL. |
3596 FrameTestHelpers::loadFrame(m_webView->mainFrame(), "javascript:document.bod
y.appendChild(document.createTextNode('Modified'))"); | 3568 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.body.appendChild(document.createTextNode('Modified'))"); |
3597 runPendingTasks(); | 3569 runPendingTasks(); |
3598 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); | 3570 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); |
3599 | |
3600 m_webView->close(); | |
3601 m_webView = 0; | |
3602 } | 3571 } |
3603 | 3572 |
3604 TEST_F(WebFrameTest, DidAccessInitialDocumentBodyBeforeModalDialog) | 3573 TEST_F(WebFrameTest, DidAccessInitialDocumentBodyBeforeModalDialog) |
3605 { | 3574 { |
3606 TestAccessInitialDocumentWebFrameClient webFrameClient; | 3575 TestAccessInitialDocumentWebFrameClient webFrameClient; |
3607 m_webView = FrameTestHelpers::createWebView(true, &webFrameClient); | 3576 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3577 webViewHelper.initialize(true, &webFrameClient); |
3608 runPendingTasks(); | 3578 runPendingTasks(); |
3609 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); | 3579 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); |
3610 | 3580 |
3611 // Create another window that will try to access it. | 3581 // Create another window that will try to access it. |
3612 WebView* newView = FrameTestHelpers::createWebView(true); | 3582 FrameTestHelpers::WebViewHelper newWebViewHelper; |
3613 newView->mainFrame()->setOpener(m_webView->mainFrame()); | 3583 WebView* newView = newWebViewHelper.initialize(true); |
| 3584 newView->mainFrame()->setOpener(webViewHelper.webView()->mainFrame()); |
3614 runPendingTasks(); | 3585 runPendingTasks(); |
3615 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); | 3586 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); |
3616 | 3587 |
3617 // Access the initial document by modifying the body. We normally set a | 3588 // Access the initial document by modifying the body. We normally set a |
3618 // timer to notify the client. | 3589 // timer to notify the client. |
3619 newView->mainFrame()->executeScript( | 3590 newView->mainFrame()->executeScript( |
3620 WebScriptSource("window.opener.document.body.innerHTML += 'Modified';"))
; | 3591 WebScriptSource("window.opener.document.body.innerHTML += 'Modified';"))
; |
3621 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); | 3592 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); |
3622 | 3593 |
3623 // Make sure that a modal dialog forces us to notify right away. | 3594 // Make sure that a modal dialog forces us to notify right away. |
3624 newView->mainFrame()->executeScript( | 3595 newView->mainFrame()->executeScript( |
3625 WebScriptSource("window.opener.confirm('Modal');")); | 3596 WebScriptSource("window.opener.confirm('Modal');")); |
3626 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); | 3597 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); |
3627 | 3598 |
3628 // Ensure that we don't notify again later. | 3599 // Ensure that we don't notify again later. |
3629 runPendingTasks(); | 3600 runPendingTasks(); |
3630 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); | 3601 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); |
3631 | |
3632 newView->close(); | |
3633 m_webView->close(); | |
3634 m_webView = 0; | |
3635 } | 3602 } |
3636 | 3603 |
3637 class TestMainFrameUserOrProgrammaticScrollFrameClient : public WebFrameClient { | 3604 class TestMainFrameUserOrProgrammaticScrollFrameClient : public WebFrameClient { |
3638 public: | 3605 public: |
3639 TestMainFrameUserOrProgrammaticScrollFrameClient() { reset(); } | 3606 TestMainFrameUserOrProgrammaticScrollFrameClient() { reset(); } |
3640 void reset() | 3607 void reset() |
3641 { | 3608 { |
3642 m_didScrollMainFrame = false; | 3609 m_didScrollMainFrame = false; |
3643 m_wasProgrammaticScroll = false; | 3610 m_wasProgrammaticScroll = false; |
3644 } | 3611 } |
(...skipping 20 matching lines...) Expand all Loading... |
3665 bool m_wasProgrammaticScroll; | 3632 bool m_wasProgrammaticScroll; |
3666 }; | 3633 }; |
3667 | 3634 |
3668 TEST_F(WebFrameTest, CompositorScrollIsUserScrollLongPage) | 3635 TEST_F(WebFrameTest, CompositorScrollIsUserScrollLongPage) |
3669 { | 3636 { |
3670 registerMockedHttpURLLoad("long_scroll.html"); | 3637 registerMockedHttpURLLoad("long_scroll.html"); |
3671 TestMainFrameUserOrProgrammaticScrollFrameClient client; | 3638 TestMainFrameUserOrProgrammaticScrollFrameClient client; |
3672 | 3639 |
3673 // Make sure we initialize to minimum scale, even if the window size | 3640 // Make sure we initialize to minimum scale, even if the window size |
3674 // only becomes available after the load begins. | 3641 // only becomes available after the load begins. |
3675 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "long_scroll.
html", true, &client); | 3642 FrameTestHelpers::WebViewHelper webViewHelper; |
3676 m_webView->resize(WebSize(1000, 1000)); | 3643 webViewHelper.initializeAndLoad(m_baseURL + "long_scroll.html", true, &clien
t); |
3677 m_webView->layout(); | 3644 webViewHelper.webView()->resize(WebSize(1000, 1000)); |
| 3645 webViewHelper.webView()->layout(); |
3678 | 3646 |
3679 EXPECT_FALSE(client.wasUserScroll()); | 3647 EXPECT_FALSE(client.wasUserScroll()); |
3680 EXPECT_FALSE(client.wasProgrammaticScroll()); | 3648 EXPECT_FALSE(client.wasProgrammaticScroll()); |
3681 | 3649 |
3682 // Do a compositor scroll, verify that this is counted as a user scroll. | 3650 // Do a compositor scroll, verify that this is counted as a user scroll. |
3683 webViewImpl()->applyScrollAndScale(WebSize(0, 1), 1.1f); | 3651 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(0, 1), 1.1f); |
3684 EXPECT_TRUE(client.wasUserScroll()); | 3652 EXPECT_TRUE(client.wasUserScroll()); |
3685 client.reset(); | 3653 client.reset(); |
3686 | 3654 |
3687 EXPECT_FALSE(client.wasUserScroll()); | 3655 EXPECT_FALSE(client.wasUserScroll()); |
3688 EXPECT_FALSE(client.wasProgrammaticScroll()); | 3656 EXPECT_FALSE(client.wasProgrammaticScroll()); |
3689 | 3657 |
3690 // The page scale 1.0f and scroll. | 3658 // The page scale 1.0f and scroll. |
3691 webViewImpl()->applyScrollAndScale(WebSize(0, 1), 1.0f); | 3659 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(0, 1), 1.0f); |
3692 EXPECT_TRUE(client.wasUserScroll()); | 3660 EXPECT_TRUE(client.wasUserScroll()); |
3693 client.reset(); | 3661 client.reset(); |
3694 | 3662 |
3695 // No scroll event if there is no scroll delta. | 3663 // No scroll event if there is no scroll delta. |
3696 webViewImpl()->applyScrollAndScale(WebSize(), 1.0f); | 3664 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(), 1.0f); |
3697 EXPECT_FALSE(client.wasUserScroll()); | 3665 EXPECT_FALSE(client.wasUserScroll()); |
3698 EXPECT_FALSE(client.wasProgrammaticScroll()); | 3666 EXPECT_FALSE(client.wasProgrammaticScroll()); |
3699 client.reset(); | 3667 client.reset(); |
3700 | 3668 |
3701 // Non zero page scale and scroll. | 3669 // Non zero page scale and scroll. |
3702 webViewImpl()->applyScrollAndScale(WebSize(9, 13), 0.6f); | 3670 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(9, 13), 0.6f); |
3703 EXPECT_TRUE(client.wasUserScroll()); | 3671 EXPECT_TRUE(client.wasUserScroll()); |
3704 client.reset(); | 3672 client.reset(); |
3705 | 3673 |
3706 // Programmatic scroll. | 3674 // Programmatic scroll. |
3707 WebFrameImpl* frameImpl = webViewImpl()->mainFrameImpl(); | 3675 WebFrameImpl* frameImpl = webViewHelper.webViewImpl()->mainFrameImpl(); |
3708 frameImpl->executeScript(WebScriptSource("window.scrollTo(0, 20);")); | 3676 frameImpl->executeScript(WebScriptSource("window.scrollTo(0, 20);")); |
3709 EXPECT_FALSE(client.wasUserScroll()); | 3677 EXPECT_FALSE(client.wasUserScroll()); |
3710 EXPECT_TRUE(client.wasProgrammaticScroll()); | 3678 EXPECT_TRUE(client.wasProgrammaticScroll()); |
3711 client.reset(); | 3679 client.reset(); |
3712 | 3680 |
3713 // Programmatic scroll to same offset. No scroll event should be generated. | 3681 // Programmatic scroll to same offset. No scroll event should be generated. |
3714 frameImpl->executeScript(WebScriptSource("window.scrollTo(0, 20);")); | 3682 frameImpl->executeScript(WebScriptSource("window.scrollTo(0, 20);")); |
3715 EXPECT_FALSE(client.wasProgrammaticScroll()); | 3683 EXPECT_FALSE(client.wasProgrammaticScroll()); |
3716 EXPECT_FALSE(client.wasUserScroll()); | 3684 EXPECT_FALSE(client.wasUserScroll()); |
3717 client.reset(); | 3685 client.reset(); |
3718 | |
3719 m_webView->close(); | |
3720 m_webView = 0; | |
3721 } | 3686 } |
3722 | 3687 |
3723 TEST_F(WebFrameTest, CompositorScrollIsUserScrollShortPage) | 3688 TEST_F(WebFrameTest, CompositorScrollIsUserScrollShortPage) |
3724 { | 3689 { |
3725 registerMockedHttpURLLoad("short_scroll.html"); | 3690 registerMockedHttpURLLoad("short_scroll.html"); |
3726 | 3691 |
3727 TestMainFrameUserOrProgrammaticScrollFrameClient client; | 3692 TestMainFrameUserOrProgrammaticScrollFrameClient client; |
3728 | 3693 |
3729 // Short page tests. | 3694 // Short page tests. |
3730 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "short_scroll
.html", true, &client); | 3695 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3696 webViewHelper.initializeAndLoad(m_baseURL + "short_scroll.html", true, &clie
nt); |
3731 | 3697 |
3732 m_webView->resize(WebSize(1000, 1000)); | 3698 webViewHelper.webView()->resize(WebSize(1000, 1000)); |
3733 m_webView->layout(); | 3699 webViewHelper.webView()->layout(); |
3734 | 3700 |
3735 EXPECT_FALSE(client.wasUserScroll()); | 3701 EXPECT_FALSE(client.wasUserScroll()); |
3736 EXPECT_FALSE(client.wasProgrammaticScroll()); | 3702 EXPECT_FALSE(client.wasProgrammaticScroll()); |
3737 | 3703 |
3738 // Non zero page scale and scroll. | 3704 // Non zero page scale and scroll. |
3739 webViewImpl()->applyScrollAndScale(WebSize(9, 13), 2.0f); | 3705 webViewHelper.webViewImpl()->applyScrollAndScale(WebSize(9, 13), 2.0f); |
3740 EXPECT_FALSE(client.wasProgrammaticScroll()); | 3706 EXPECT_FALSE(client.wasProgrammaticScroll()); |
3741 EXPECT_TRUE(client.wasUserScroll()); | 3707 EXPECT_TRUE(client.wasUserScroll()); |
3742 client.reset(); | 3708 client.reset(); |
3743 | |
3744 m_webView->close(); | |
3745 m_webView = 0; | |
3746 } | 3709 } |
3747 | 3710 |
3748 TEST_F(WebFrameTest, FirstPartyForCookiesForRedirect) | 3711 TEST_F(WebFrameTest, FirstPartyForCookiesForRedirect) |
3749 { | 3712 { |
3750 WTF::String filePath = Platform::current()->unitTestSupport()->webKitRootDir
(); | 3713 WTF::String filePath = Platform::current()->unitTestSupport()->webKitRootDir
(); |
3751 filePath.append("/Source/web/tests/data/first_party.html"); | 3714 filePath.append("/Source/web/tests/data/first_party.html"); |
3752 | 3715 |
3753 WebURL testURL(toKURL("http://www.test.com/first_party_redirect.html")); | 3716 WebURL testURL(toKURL("http://www.test.com/first_party_redirect.html")); |
3754 char redirect[] = "http://www.test.com/first_party.html"; | 3717 char redirect[] = "http://www.test.com/first_party.html"; |
3755 WebURL redirectURL(toKURL(redirect)); | 3718 WebURL redirectURL(toKURL(redirect)); |
3756 WebURLResponse redirectResponse; | 3719 WebURLResponse redirectResponse; |
3757 redirectResponse.initialize(); | 3720 redirectResponse.initialize(); |
3758 redirectResponse.setMIMEType("text/html"); | 3721 redirectResponse.setMIMEType("text/html"); |
3759 redirectResponse.setHTTPStatusCode(302); | 3722 redirectResponse.setHTTPStatusCode(302); |
3760 redirectResponse.setHTTPHeaderField("Location", redirect); | 3723 redirectResponse.setHTTPHeaderField("Location", redirect); |
3761 Platform::current()->unitTestSupport()->registerMockedURL(testURL, redirectR
esponse, filePath); | 3724 Platform::current()->unitTestSupport()->registerMockedURL(testURL, redirectR
esponse, filePath); |
3762 | 3725 |
3763 WebURLResponse finalResponse; | 3726 WebURLResponse finalResponse; |
3764 finalResponse.initialize(); | 3727 finalResponse.initialize(); |
3765 finalResponse.setMIMEType("text/html"); | 3728 finalResponse.setMIMEType("text/html"); |
3766 Platform::current()->unitTestSupport()->registerMockedURL(redirectURL, final
Response, filePath); | 3729 Platform::current()->unitTestSupport()->registerMockedURL(redirectURL, final
Response, filePath); |
3767 | 3730 |
3768 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "first_party_
redirect.html", true); | 3731 FrameTestHelpers::WebViewHelper webViewHelper; |
3769 EXPECT_TRUE(m_webView->mainFrame()->document().firstPartyForCookies() == red
irectURL); | 3732 webViewHelper.initializeAndLoad(m_baseURL + "first_party_redirect.html", tru
e); |
3770 | 3733 EXPECT_TRUE(webViewHelper.webView()->mainFrame()->document().firstPartyForCo
okies() == redirectURL); |
3771 m_webView->close(); | |
3772 m_webView = 0; | |
3773 } | 3734 } |
3774 | 3735 |
3775 class TestNavigationPolicyWebFrameClient : public WebFrameClient { | 3736 class TestNavigationPolicyWebFrameClient : public WebFrameClient { |
3776 public: | 3737 public: |
3777 | 3738 |
3778 virtual void didNavigateWithinPage(WebFrame*, bool) | 3739 virtual void didNavigateWithinPage(WebFrame*, bool) |
3779 { | 3740 { |
3780 EXPECT_TRUE(false); | 3741 EXPECT_TRUE(false); |
3781 } | 3742 } |
3782 }; | 3743 }; |
3783 | 3744 |
3784 TEST_F(WebFrameTest, SimulateFragmentAnchorMiddleClick) | 3745 TEST_F(WebFrameTest, SimulateFragmentAnchorMiddleClick) |
3785 { | 3746 { |
3786 registerMockedHttpURLLoad("fragment_middle_click.html"); | 3747 registerMockedHttpURLLoad("fragment_middle_click.html"); |
3787 TestNavigationPolicyWebFrameClient client; | 3748 TestNavigationPolicyWebFrameClient client; |
3788 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fragment_mid
dle_click.html", true, &client); | 3749 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3750 webViewHelper.initializeAndLoad(m_baseURL + "fragment_middle_click.html", tr
ue, &client); |
3789 | 3751 |
3790 WebCore::Document* document = webViewImpl()->page()->mainFrame()->document()
; | 3752 WebCore::Document* document = webViewHelper.webViewImpl()->page()->mainFrame
()->document(); |
3791 WebCore::KURL destination = document->url(); | 3753 WebCore::KURL destination = document->url(); |
3792 destination.setFragmentIdentifier("test"); | 3754 destination.setFragmentIdentifier("test"); |
3793 | 3755 |
3794 RefPtr<WebCore::Event> event = WebCore::MouseEvent::create(WebCore::eventNam
es().clickEvent, false, false, | 3756 RefPtr<WebCore::Event> event = WebCore::MouseEvent::create(WebCore::eventNam
es().clickEvent, false, false, |
3795 document->defaultView(), 0, 0, 0, 0, 0, 0, 0, false, false, false, false
, 1, 0, 0); | 3757 document->defaultView(), 0, 0, 0, 0, 0, 0, 0, false, false, false, false
, 1, 0, 0); |
3796 WebCore::FrameLoadRequest frameRequest(document->securityOrigin(), WebCore::
ResourceRequest(destination)); | 3758 WebCore::FrameLoadRequest frameRequest(document->securityOrigin(), WebCore::
ResourceRequest(destination)); |
3797 frameRequest.setTriggeringEvent(event); | 3759 frameRequest.setTriggeringEvent(event); |
3798 webViewImpl()->page()->mainFrame()->loader()->load(frameRequest); | 3760 webViewHelper.webViewImpl()->page()->mainFrame()->loader()->load(frameReques
t); |
3799 | |
3800 m_webView->close(); | |
3801 m_webView = 0; | |
3802 } | 3761 } |
3803 | 3762 |
3804 TEST_F(WebFrameTest, BackToReload) | 3763 TEST_F(WebFrameTest, BackToReload) |
3805 { | 3764 { |
3806 registerMockedHttpURLLoad("fragment_middle_click.html"); | 3765 registerMockedHttpURLLoad("fragment_middle_click.html"); |
3807 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "fragment_mid
dle_click.html", true); | 3766 FrameTestHelpers::WebViewHelper webViewHelper; |
3808 WebFrame* frame = m_webView->mainFrame(); | 3767 webViewHelper.initializeAndLoad(m_baseURL + "fragment_middle_click.html", tr
ue); |
| 3768 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
3809 WebHistoryItem firstItem = frame->currentHistoryItem(); | 3769 WebHistoryItem firstItem = frame->currentHistoryItem(); |
3810 EXPECT_FALSE(firstItem.isNull()); | 3770 EXPECT_FALSE(firstItem.isNull()); |
3811 | 3771 |
3812 registerMockedHttpURLLoad("white-1x1.png"); | 3772 registerMockedHttpURLLoad("white-1x1.png"); |
3813 FrameTestHelpers::loadFrame(frame, m_baseURL + "white-1x1.png"); | 3773 FrameTestHelpers::loadFrame(frame, m_baseURL + "white-1x1.png"); |
3814 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 3774 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
3815 EXPECT_FALSE(frame->previousHistoryItem().isNull()); | 3775 EXPECT_FALSE(frame->previousHistoryItem().isNull()); |
3816 EXPECT_EQ(firstItem.urlString(), frame->previousHistoryItem().urlString()); | 3776 EXPECT_EQ(firstItem.urlString(), frame->previousHistoryItem().urlString()); |
3817 | 3777 |
3818 frame->loadHistoryItem(frame->previousHistoryItem()); | 3778 frame->loadHistoryItem(frame->previousHistoryItem()); |
3819 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 3779 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
3820 EXPECT_EQ(firstItem.urlString(), frame->currentHistoryItem().urlString()); | 3780 EXPECT_EQ(firstItem.urlString(), frame->currentHistoryItem().urlString()); |
3821 | 3781 |
3822 frame->reload(); | 3782 frame->reload(); |
3823 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 3783 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
3824 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); | 3784 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); |
3825 | |
3826 m_webView->close(); | |
3827 m_webView = 0; | |
3828 } | 3785 } |
3829 | 3786 |
3830 TEST_F(WebFrameTest, ReloadPost) | 3787 TEST_F(WebFrameTest, ReloadPost) |
3831 { | 3788 { |
3832 registerMockedHttpURLLoad("reload_post.html"); | 3789 registerMockedHttpURLLoad("reload_post.html"); |
3833 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "reload_post.
html", true); | 3790 FrameTestHelpers::WebViewHelper webViewHelper; |
3834 WebFrame* frame = m_webView->mainFrame(); | 3791 webViewHelper.initializeAndLoad(m_baseURL + "reload_post.html", true); |
| 3792 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
3835 | 3793 |
3836 FrameTestHelpers::loadFrame(m_webView->mainFrame(), "javascript:document.for
ms[0].submit()"); | 3794 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.forms[0].submit()"); |
3837 runPendingTasks(); | 3795 runPendingTasks(); |
3838 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 3796 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
3839 EXPECT_FALSE(frame->previousHistoryItem().isNull()); | 3797 EXPECT_FALSE(frame->previousHistoryItem().isNull()); |
3840 EXPECT_EQ(WebString::fromUTF8("POST"), frame->dataSource()->request().httpMe
thod()); | 3798 EXPECT_EQ(WebString::fromUTF8("POST"), frame->dataSource()->request().httpMe
thod()); |
3841 | 3799 |
3842 frame->reload(); | 3800 frame->reload(); |
3843 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 3801 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
3844 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); | 3802 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); |
3845 EXPECT_EQ(WebNavigationTypeFormResubmitted, frame->dataSource()->navigationT
ype()); | 3803 EXPECT_EQ(WebNavigationTypeFormResubmitted, frame->dataSource()->navigationT
ype()); |
3846 | |
3847 m_webView->close(); | |
3848 m_webView = 0; | |
3849 } | 3804 } |
3850 | 3805 |
3851 class TestSameDocumentWebFrameClient : public WebFrameClient { | 3806 class TestSameDocumentWebFrameClient : public WebFrameClient { |
3852 public: | 3807 public: |
3853 TestSameDocumentWebFrameClient() | 3808 TestSameDocumentWebFrameClient() |
3854 : m_frameLoadTypeSameSeen(false) | 3809 : m_frameLoadTypeSameSeen(false) |
3855 { | 3810 { |
3856 } | 3811 } |
3857 | 3812 |
3858 virtual void willSendRequest(WebFrame* frame, unsigned, WebURLRequest&, cons
t WebURLResponse&) | 3813 virtual void willSendRequest(WebFrame* frame, unsigned, WebURLRequest&, cons
t WebURLResponse&) |
3859 { | 3814 { |
3860 if (toWebFrameImpl(frame)->frame()->loader()->loadType() == WebCore::Fra
meLoadTypeSame) | 3815 if (toWebFrameImpl(frame)->frame()->loader()->loadType() == WebCore::Fra
meLoadTypeSame) |
3861 m_frameLoadTypeSameSeen = true; | 3816 m_frameLoadTypeSameSeen = true; |
3862 } | 3817 } |
3863 | 3818 |
3864 bool frameLoadTypeSameSeen() const { return m_frameLoadTypeSameSeen; } | 3819 bool frameLoadTypeSameSeen() const { return m_frameLoadTypeSameSeen; } |
3865 | 3820 |
3866 private: | 3821 private: |
3867 bool m_frameLoadTypeSameSeen; | 3822 bool m_frameLoadTypeSameSeen; |
3868 }; | 3823 }; |
3869 | 3824 |
3870 TEST_F(WebFrameTest, NavigateToSame) | 3825 TEST_F(WebFrameTest, NavigateToSame) |
3871 { | 3826 { |
3872 registerMockedHttpURLLoad("navigate_to_same.html"); | 3827 registerMockedHttpURLLoad("navigate_to_same.html"); |
3873 TestSameDocumentWebFrameClient client; | 3828 TestSameDocumentWebFrameClient client; |
3874 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "navigate_to_
same.html", true, &client); | 3829 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3830 webViewHelper.initializeAndLoad(m_baseURL + "navigate_to_same.html", true, &
client); |
3875 EXPECT_FALSE(client.frameLoadTypeSameSeen()); | 3831 EXPECT_FALSE(client.frameLoadTypeSameSeen()); |
3876 | 3832 |
3877 WebCore::FrameLoadRequest frameRequest(0, WebCore::ResourceRequest(webViewIm
pl()->page()->mainFrame()->document()->url())); | 3833 WebCore::FrameLoadRequest frameRequest(0, WebCore::ResourceRequest(webViewHe
lper.webViewImpl()->page()->mainFrame()->document()->url())); |
3878 webViewImpl()->page()->mainFrame()->loader()->load(frameRequest); | 3834 webViewHelper.webViewImpl()->page()->mainFrame()->loader()->load(frameReques
t); |
3879 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 3835 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
3880 | 3836 |
3881 EXPECT_TRUE(client.frameLoadTypeSameSeen()); | 3837 EXPECT_TRUE(client.frameLoadTypeSameSeen()); |
3882 m_webView->close(); | |
3883 m_webView = 0; | |
3884 } | 3838 } |
3885 | 3839 |
3886 TEST_F(WebFrameTest, WebNodeImageContents) | 3840 TEST_F(WebFrameTest, WebNodeImageContents) |
3887 { | 3841 { |
3888 m_webView = FrameTestHelpers::createWebViewAndLoad("about:blank", true); | 3842 FrameTestHelpers::WebViewHelper webViewHelper; |
3889 WebFrame* frame = m_webView->mainFrame(); | 3843 webViewHelper.initializeAndLoad("about:blank", true); |
| 3844 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
3890 | 3845 |
3891 static const char bluePNG[] = "<img src=\"
AAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAGElEQVQYV2NkYPj/n4EIwDiqEF8oUT94AFIQE/cCn90I
AAAAAElFTkSuQmCC\">"; | 3846 static const char bluePNG[] = "<img src=\"
AAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAGElEQVQYV2NkYPj/n4EIwDiqEF8oUT94AFIQE/cCn90I
AAAAAElFTkSuQmCC\">"; |
3892 | 3847 |
3893 // Load up the image and test that we can extract the contents. | 3848 // Load up the image and test that we can extract the contents. |
3894 WebCore::KURL testURL = toKURL("about:blank"); | 3849 WebCore::KURL testURL = toKURL("about:blank"); |
3895 frame->loadHTMLString(bluePNG, testURL); | 3850 frame->loadHTMLString(bluePNG, testURL); |
3896 runPendingTasks(); | 3851 runPendingTasks(); |
3897 | 3852 |
3898 WebNode node = frame->document().body().firstChild(); | 3853 WebNode node = frame->document().body().firstChild(); |
3899 EXPECT_TRUE(node.isElementNode()); | 3854 EXPECT_TRUE(node.isElementNode()); |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3932 | 3887 |
3933 private: | 3888 private: |
3934 int m_startLoadingCount; | 3889 int m_startLoadingCount; |
3935 int m_stopLoadingCount; | 3890 int m_stopLoadingCount; |
3936 }; | 3891 }; |
3937 | 3892 |
3938 TEST_F(WebFrameTest, PushStateStartsAndStops) | 3893 TEST_F(WebFrameTest, PushStateStartsAndStops) |
3939 { | 3894 { |
3940 registerMockedHttpURLLoad("push_state.html"); | 3895 registerMockedHttpURLLoad("push_state.html"); |
3941 TestStartStopCallbackWebViewClient client; | 3896 TestStartStopCallbackWebViewClient client; |
3942 m_webView = FrameTestHelpers::createWebViewAndLoad(m_baseURL + "push_state.h
tml", true, 0, &client); | 3897 FrameTestHelpers::WebViewHelper webViewHelper; |
| 3898 webViewHelper.initializeAndLoad(m_baseURL + "push_state.html", true, 0, &cli
ent); |
3943 runPendingTasks(); | 3899 runPendingTasks(); |
3944 | 3900 |
3945 EXPECT_EQ(client.startLoadingCount(), 2); | 3901 EXPECT_EQ(client.startLoadingCount(), 2); |
3946 EXPECT_EQ(client.stopLoadingCount(), 2); | 3902 EXPECT_EQ(client.stopLoadingCount(), 2); |
3947 m_webView->close(); | |
3948 m_webView = 0; | |
3949 } | 3903 } |
3950 | 3904 |
3951 } // namespace | 3905 } // namespace |
OLD | NEW |