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 276 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
287 URLTestHelpers::registerMockedURLLoad(toKURL("http://www.test.com:0/" + file
Name), WebString::fromUTF8(fileName)); | 287 URLTestHelpers::registerMockedURLLoad(toKURL("http://www.test.com:0/" + file
Name), WebString::fromUTF8(fileName)); |
288 | 288 |
289 FrameTestHelpers::WebViewHelper webViewHelper; | 289 FrameTestHelpers::WebViewHelper webViewHelper; |
290 | 290 |
291 /// Pass true to enable JavaScript. | 291 /// Pass true to enable JavaScript. |
292 webViewHelper.initializeAndLoad(m_baseURL + fileName, true); | 292 webViewHelper.initializeAndLoad(m_baseURL + fileName, true); |
293 | 293 |
294 // Setting host to "hostname:" should be treated as "hostname:0". | 294 // Setting host to "hostname:" should be treated as "hostname:0". |
295 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:location.host = 'www.test.com:'; void 0;"); | 295 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:location.host = 'www.test.com:'; void 0;"); |
296 | 296 |
| 297 runPendingTasks(); |
| 298 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
| 299 |
297 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.body.textContent = location.href; void 0;"); | 300 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.body.textContent = location.href; void 0;"); |
| 301 // Required to see any updates in contentAsText. |
| 302 runPendingTasks(); |
| 303 webViewHelper.webView()->layout(); |
298 | 304 |
299 std::string content = webViewHelper.webView()->mainFrame()->contentAsText(10
24).utf8(); | 305 std::string content = webViewHelper.webView()->mainFrame()->contentAsText(10
24).utf8(); |
300 EXPECT_EQ("http://www.test.com:0/" + fileName, content); | 306 EXPECT_EQ("http://www.test.com:0/" + fileName, content); |
301 } | 307 } |
302 | 308 |
303 TEST_F(WebFrameTest, LocationSetEmptyPort) | 309 TEST_F(WebFrameTest, LocationSetEmptyPort) |
304 { | 310 { |
305 std::string fileName = "print-location-href.html"; | 311 std::string fileName = "print-location-href.html"; |
306 registerMockedHttpURLLoad(fileName); | 312 registerMockedHttpURLLoad(fileName); |
307 URLTestHelpers::registerMockedURLLoad(toKURL("http://www.test.com:0/" + file
Name), WebString::fromUTF8(fileName)); | 313 URLTestHelpers::registerMockedURLLoad(toKURL("http://www.test.com:0/" + file
Name), WebString::fromUTF8(fileName)); |
308 | 314 |
309 FrameTestHelpers::WebViewHelper webViewHelper; | 315 FrameTestHelpers::WebViewHelper webViewHelper; |
310 | 316 |
311 /// Pass true to enable JavaScript. | 317 /// Pass true to enable JavaScript. |
312 webViewHelper.initializeAndLoad(m_baseURL + fileName, true); | 318 webViewHelper.initializeAndLoad(m_baseURL + fileName, true); |
313 | 319 |
314 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:location.port = ''; void 0;"); | 320 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:location.port = ''; void 0;"); |
315 | 321 |
| 322 runPendingTasks(); |
| 323 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
| 324 |
316 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.body.textContent = location.href; void 0;"); | 325 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.body.textContent = location.href; void 0;"); |
| 326 // Required to see any updates in contentAsText. |
| 327 runPendingTasks(); |
| 328 webViewHelper.webView()->layout(); |
317 | 329 |
318 std::string content = webViewHelper.webView()->mainFrame()->contentAsText(10
24).utf8(); | 330 std::string content = webViewHelper.webView()->mainFrame()->contentAsText(10
24).utf8(); |
319 EXPECT_EQ("http://www.test.com:0/" + fileName, content); | 331 EXPECT_EQ("http://www.test.com:0/" + fileName, content); |
320 } | 332 } |
321 | 333 |
322 class CSSCallbackWebFrameClient : public FrameTestHelpers::TestWebFrameClient { | 334 class CSSCallbackWebFrameClient : public FrameTestHelpers::TestWebFrameClient { |
323 public: | 335 public: |
324 CSSCallbackWebFrameClient() : m_updateCount(0) { } | 336 CSSCallbackWebFrameClient() : m_updateCount(0) { } |
325 virtual void didMatchCSS(WebLocalFrame*, const WebVector<WebString>& newlyMa
tchingSelectors, const WebVector<WebString>& stoppedMatchingSelectors) OVERRIDE; | 337 virtual void didMatchCSS(WebLocalFrame*, const WebVector<WebString>& newlyMa
tchingSelectors, const WebVector<WebString>& stoppedMatchingSelectors) OVERRIDE; |
326 | 338 |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
365 int updateCount() const | 377 int updateCount() const |
366 { | 378 { |
367 return m_client.m_updateCount; | 379 return m_client.m_updateCount; |
368 } | 380 } |
369 | 381 |
370 const std::set<std::string>& matchedSelectors() | 382 const std::set<std::string>& matchedSelectors() |
371 { | 383 { |
372 return m_client.m_matchedSelectors[m_frame]; | 384 return m_client.m_matchedSelectors[m_frame]; |
373 } | 385 } |
374 | 386 |
375 void loadHTML(const std::string& html) | 387 void loadHTML(const WebData& html) |
376 { | 388 { |
377 FrameTestHelpers::loadHTMLString(m_frame, html, toKURL("about:blank")); | 389 m_frame->loadHTMLString(html, toKURL("about:blank")); |
| 390 runPendingTasks(); |
378 } | 391 } |
379 | 392 |
380 void executeScript(const WebString& code) | 393 void executeScript(const WebString& code) |
381 { | 394 { |
382 m_frame->executeScript(WebScriptSource(code)); | 395 m_frame->executeScript(WebScriptSource(code)); |
383 m_frame->view()->layout(); | 396 m_frame->view()->layout(); |
384 runPendingTasks(); | 397 runPendingTasks(); |
385 } | 398 } |
386 | 399 |
387 CSSCallbackWebFrameClient m_client; | 400 CSSCallbackWebFrameClient m_client; |
(...skipping 976 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1364 int viewportHeight = 800; | 1377 int viewportHeight = 800; |
1365 | 1378 |
1366 FrameTestHelpers::WebViewHelper webViewHelper; | 1379 FrameTestHelpers::WebViewHelper webViewHelper; |
1367 webViewHelper.initializeAndLoad("about:blank", true, 0, &client, enableViewp
ortSettings); | 1380 webViewHelper.initializeAndLoad("about:blank", true, 0, &client, enableViewp
ortSettings); |
1368 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); | 1381 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
1369 webViewHelper.webView()->settings()->setUseWideViewport(true); | 1382 webViewHelper.webView()->settings()->setUseWideViewport(true); |
1370 webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); | 1383 webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); |
1371 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1384 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1372 | 1385 |
1373 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "wide_document_width_viewport.html"); | 1386 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "wide_document_width_viewport.html"); |
| 1387 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1374 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1388 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1375 | 1389 |
1376 int wideDocumentWidth = 800; | 1390 int wideDocumentWidth = 800; |
1377 float minimumPageScaleFactor = viewportWidth / (float) wideDocumentWidth; | 1391 float minimumPageScaleFactor = viewportWidth / (float) wideDocumentWidth; |
1378 EXPECT_EQ(minimumPageScaleFactor, webViewHelper.webView()->pageScaleFactor()
); | 1392 EXPECT_EQ(minimumPageScaleFactor, webViewHelper.webView()->pageScaleFactor()
); |
1379 EXPECT_EQ(minimumPageScaleFactor, webViewHelper.webView()->minimumPageScaleF
actor()); | 1393 EXPECT_EQ(minimumPageScaleFactor, webViewHelper.webView()->minimumPageScaleF
actor()); |
1380 } | 1394 } |
1381 | 1395 |
1382 TEST_F(WebFrameTest, WideViewportQuirkClobbersHeight) | 1396 TEST_F(WebFrameTest, WideViewportQuirkClobbersHeight) |
1383 { | 1397 { |
1384 UseMockScrollbarSettings mockScrollbarSettings; | 1398 UseMockScrollbarSettings mockScrollbarSettings; |
1385 registerMockedHttpURLLoad("viewport-height-1000.html"); | 1399 registerMockedHttpURLLoad("viewport-height-1000.html"); |
1386 | 1400 |
1387 FixedLayoutTestWebViewClient client; | 1401 FixedLayoutTestWebViewClient client; |
1388 client.m_screenInfo.deviceScaleFactor = 1; | 1402 client.m_screenInfo.deviceScaleFactor = 1; |
1389 int viewportWidth = 600; | 1403 int viewportWidth = 600; |
1390 int viewportHeight = 800; | 1404 int viewportHeight = 800; |
1391 | 1405 |
1392 FrameTestHelpers::WebViewHelper webViewHelper; | 1406 FrameTestHelpers::WebViewHelper webViewHelper; |
1393 webViewHelper.initializeAndLoad("about:blank", true, 0, &client, enableViewp
ortSettings); | 1407 webViewHelper.initializeAndLoad("about:blank", true, 0, &client, enableViewp
ortSettings); |
1394 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); | 1408 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
1395 webViewHelper.webView()->settings()->setUseWideViewport(false); | 1409 webViewHelper.webView()->settings()->setUseWideViewport(false); |
1396 webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); | 1410 webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); |
1397 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1411 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1398 | 1412 |
1399 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "viewport-height-1000.html"); | 1413 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "viewport-height-1000.html"); |
| 1414 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1400 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1415 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1401 | 1416 |
1402 EXPECT_EQ(800, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->la
youtSize().height()); | 1417 EXPECT_EQ(800, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->la
youtSize().height()); |
1403 EXPECT_EQ(1, webViewHelper.webView()->pageScaleFactor()); | 1418 EXPECT_EQ(1, webViewHelper.webView()->pageScaleFactor()); |
1404 } | 1419 } |
1405 | 1420 |
1406 TEST_F(WebFrameTest, LayoutSize320Quirk) | 1421 TEST_F(WebFrameTest, LayoutSize320Quirk) |
1407 { | 1422 { |
1408 UseMockScrollbarSettings mockScrollbarSettings; | 1423 UseMockScrollbarSettings mockScrollbarSettings; |
1409 registerMockedHttpURLLoad("viewport/viewport-30.html"); | 1424 registerMockedHttpURLLoad("viewport/viewport-30.html"); |
1410 | 1425 |
1411 FixedLayoutTestWebViewClient client; | 1426 FixedLayoutTestWebViewClient client; |
1412 client.m_screenInfo.deviceScaleFactor = 1; | 1427 client.m_screenInfo.deviceScaleFactor = 1; |
1413 int viewportWidth = 600; | 1428 int viewportWidth = 600; |
1414 int viewportHeight = 800; | 1429 int viewportHeight = 800; |
1415 | 1430 |
1416 FrameTestHelpers::WebViewHelper webViewHelper; | 1431 FrameTestHelpers::WebViewHelper webViewHelper; |
1417 webViewHelper.initializeAndLoad("about:blank", true, 0, &client, enableViewp
ortSettings); | 1432 webViewHelper.initializeAndLoad("about:blank", true, 0, &client, enableViewp
ortSettings); |
1418 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); | 1433 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
1419 webViewHelper.webView()->settings()->setUseWideViewport(true); | 1434 webViewHelper.webView()->settings()->setUseWideViewport(true); |
1420 webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); | 1435 webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); |
1421 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1436 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1422 | 1437 |
1423 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "viewport/viewport-30.html"); | 1438 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "viewport/viewport-30.html"); |
| 1439 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1424 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1440 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1425 | 1441 |
1426 EXPECT_EQ(600, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->la
youtSize().width()); | 1442 EXPECT_EQ(600, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->la
youtSize().width()); |
1427 EXPECT_EQ(800, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->la
youtSize().height()); | 1443 EXPECT_EQ(800, webViewHelper.webViewImpl()->mainFrameImpl()->frameView()->la
youtSize().height()); |
1428 EXPECT_EQ(1, webViewHelper.webView()->pageScaleFactor()); | 1444 EXPECT_EQ(1, webViewHelper.webView()->pageScaleFactor()); |
1429 | 1445 |
1430 // The magic number to snap to device-width is 320, so test that 321 is | 1446 // The magic number to snap to device-width is 320, so test that 321 is |
1431 // respected. | 1447 // respected. |
1432 WebCore::Document* document = webViewHelper.webViewImpl()->page()->mainFrame
()->document(); | 1448 WebCore::Document* document = webViewHelper.webViewImpl()->page()->mainFrame
()->document(); |
1433 WebCore::ViewportDescription description = document->viewportDescription(); | 1449 WebCore::ViewportDescription description = document->viewportDescription(); |
(...skipping 30 matching lines...) Expand all Loading... |
1464 client.m_screenInfo.deviceScaleFactor = 1; | 1480 client.m_screenInfo.deviceScaleFactor = 1; |
1465 int viewportWidth = 640; | 1481 int viewportWidth = 640; |
1466 int viewportHeight = 480; | 1482 int viewportHeight = 480; |
1467 | 1483 |
1468 FrameTestHelpers::WebViewHelper webViewHelper; | 1484 FrameTestHelpers::WebViewHelper webViewHelper; |
1469 webViewHelper.initialize(true, 0, &client, enableViewportSettings); | 1485 webViewHelper.initialize(true, 0, &client, enableViewportSettings); |
1470 webViewHelper.webView()->settings()->setViewportMetaZeroValuesQuirk(true); | 1486 webViewHelper.webView()->settings()->setViewportMetaZeroValuesQuirk(true); |
1471 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); | 1487 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
1472 webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); | 1488 webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); |
1473 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "viewport-zero-values.html"); | 1489 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "viewport-zero-values.html"); |
| 1490 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1474 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1491 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1475 | 1492 |
1476 EXPECT_EQ(viewportWidth, webViewHelper.webViewImpl()->mainFrameImpl()->frame
View()->layoutSize().width()); | 1493 EXPECT_EQ(viewportWidth, webViewHelper.webViewImpl()->mainFrameImpl()->frame
View()->layoutSize().width()); |
1477 EXPECT_EQ(1.0f, webViewHelper.webView()->pageScaleFactor()); | 1494 EXPECT_EQ(1.0f, webViewHelper.webView()->pageScaleFactor()); |
1478 | 1495 |
1479 webViewHelper.webView()->settings()->setUseWideViewport(true); | 1496 webViewHelper.webView()->settings()->setUseWideViewport(true); |
1480 webViewHelper.webView()->layout(); | 1497 webViewHelper.webView()->layout(); |
1481 EXPECT_EQ(viewportWidth, webViewHelper.webViewImpl()->mainFrameImpl()->frame
View()->layoutSize().width()); | 1498 EXPECT_EQ(viewportWidth, webViewHelper.webViewImpl()->mainFrameImpl()->frame
View()->layoutSize().width()); |
1482 EXPECT_EQ(1.0f, webViewHelper.webView()->pageScaleFactor()); | 1499 EXPECT_EQ(1.0f, webViewHelper.webView()->pageScaleFactor()); |
1483 } | 1500 } |
1484 | 1501 |
1485 TEST_F(WebFrameTest, OverflowHiddenDisablesScrolling) | 1502 TEST_F(WebFrameTest, OverflowHiddenDisablesScrolling) |
1486 { | 1503 { |
1487 registerMockedHttpURLLoad("body-overflow-hidden.html"); | 1504 registerMockedHttpURLLoad("body-overflow-hidden.html"); |
1488 | 1505 |
1489 FixedLayoutTestWebViewClient client; | 1506 FixedLayoutTestWebViewClient client; |
1490 client.m_screenInfo.deviceScaleFactor = 1; | 1507 client.m_screenInfo.deviceScaleFactor = 1; |
1491 int viewportWidth = 640; | 1508 int viewportWidth = 640; |
1492 int viewportHeight = 480; | 1509 int viewportHeight = 480; |
1493 | 1510 |
1494 FrameTestHelpers::WebViewHelper webViewHelper; | 1511 FrameTestHelpers::WebViewHelper webViewHelper; |
1495 webViewHelper.initialize(true, 0, &client); | 1512 webViewHelper.initialize(true, 0, &client); |
1496 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "body-overflow-hidden.html"); | 1513 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "body-overflow-hidden.html"); |
| 1514 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1497 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1515 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1498 | 1516 |
1499 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); | 1517 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); |
1500 EXPECT_FALSE(view->userInputScrollable(WebCore::VerticalScrollbar)); | 1518 EXPECT_FALSE(view->userInputScrollable(WebCore::VerticalScrollbar)); |
1501 } | 1519 } |
1502 | 1520 |
1503 TEST_F(WebFrameTest, IgnoreOverflowHiddenQuirk) | 1521 TEST_F(WebFrameTest, IgnoreOverflowHiddenQuirk) |
1504 { | 1522 { |
1505 registerMockedHttpURLLoad("body-overflow-hidden.html"); | 1523 registerMockedHttpURLLoad("body-overflow-hidden.html"); |
1506 | 1524 |
1507 FixedLayoutTestWebViewClient client; | 1525 FixedLayoutTestWebViewClient client; |
1508 client.m_screenInfo.deviceScaleFactor = 1; | 1526 client.m_screenInfo.deviceScaleFactor = 1; |
1509 int viewportWidth = 640; | 1527 int viewportWidth = 640; |
1510 int viewportHeight = 480; | 1528 int viewportHeight = 480; |
1511 | 1529 |
1512 FrameTestHelpers::WebViewHelper webViewHelper; | 1530 FrameTestHelpers::WebViewHelper webViewHelper; |
1513 webViewHelper.initialize(true, 0, &client); | 1531 webViewHelper.initialize(true, 0, &client); |
1514 webViewHelper.webView()->settings()->setIgnoreMainFrameOverflowHiddenQuirk(t
rue); | 1532 webViewHelper.webView()->settings()->setIgnoreMainFrameOverflowHiddenQuirk(t
rue); |
1515 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "body-overflow-hidden.html"); | 1533 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "body-overflow-hidden.html"); |
| 1534 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1516 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1535 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1517 | 1536 |
1518 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); | 1537 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); |
1519 EXPECT_TRUE(view->userInputScrollable(WebCore::VerticalScrollbar)); | 1538 EXPECT_TRUE(view->userInputScrollable(WebCore::VerticalScrollbar)); |
1520 } | 1539 } |
1521 | 1540 |
1522 TEST_F(WebFrameTest, NonZeroValuesNoQuirk) | 1541 TEST_F(WebFrameTest, NonZeroValuesNoQuirk) |
1523 { | 1542 { |
1524 UseMockScrollbarSettings mockScrollbarSettings; | 1543 UseMockScrollbarSettings mockScrollbarSettings; |
1525 registerMockedHttpURLLoad("viewport-nonzero-values.html"); | 1544 registerMockedHttpURLLoad("viewport-nonzero-values.html"); |
1526 | 1545 |
1527 FixedLayoutTestWebViewClient client; | 1546 FixedLayoutTestWebViewClient client; |
1528 client.m_screenInfo.deviceScaleFactor = 1; | 1547 client.m_screenInfo.deviceScaleFactor = 1; |
1529 int viewportWidth = 640; | 1548 int viewportWidth = 640; |
1530 int viewportHeight = 480; | 1549 int viewportHeight = 480; |
1531 float expectedPageScaleFactor = 0.5f; | 1550 float expectedPageScaleFactor = 0.5f; |
1532 | 1551 |
1533 FrameTestHelpers::WebViewHelper webViewHelper; | 1552 FrameTestHelpers::WebViewHelper webViewHelper; |
1534 webViewHelper.initialize(true, 0, &client, enableViewportSettings); | 1553 webViewHelper.initialize(true, 0, &client, enableViewportSettings); |
1535 webViewHelper.webView()->settings()->setViewportMetaZeroValuesQuirk(true); | 1554 webViewHelper.webView()->settings()->setViewportMetaZeroValuesQuirk(true); |
1536 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); | 1555 webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
1537 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "viewport-nonzero-values.html"); | 1556 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "viewport-nonzero-values.html"); |
| 1557 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1538 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); | 1558 webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
1539 | 1559 |
1540 EXPECT_EQ(viewportWidth / expectedPageScaleFactor, webViewHelper.webViewImpl
()->mainFrameImpl()->frameView()->layoutSize().width()); | 1560 EXPECT_EQ(viewportWidth / expectedPageScaleFactor, webViewHelper.webViewImpl
()->mainFrameImpl()->frameView()->layoutSize().width()); |
1541 EXPECT_EQ(expectedPageScaleFactor, webViewHelper.webView()->pageScaleFactor(
)); | 1561 EXPECT_EQ(expectedPageScaleFactor, webViewHelper.webView()->pageScaleFactor(
)); |
1542 | 1562 |
1543 webViewHelper.webView()->settings()->setUseWideViewport(true); | 1563 webViewHelper.webView()->settings()->setUseWideViewport(true); |
1544 webViewHelper.webView()->layout(); | 1564 webViewHelper.webView()->layout(); |
1545 EXPECT_EQ(viewportWidth / expectedPageScaleFactor, webViewHelper.webViewImpl
()->mainFrameImpl()->frameView()->layoutSize().width()); | 1565 EXPECT_EQ(viewportWidth / expectedPageScaleFactor, webViewHelper.webViewImpl
()->mainFrameImpl()->frameView()->layoutSize().width()); |
1546 EXPECT_EQ(expectedPageScaleFactor, webViewHelper.webView()->pageScaleFactor(
)); | 1566 EXPECT_EQ(expectedPageScaleFactor, webViewHelper.webView()->pageScaleFactor(
)); |
1547 } | 1567 } |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1594 TEST_F(WebFrameTest, setPageScaleFactorBeforeFrameHasView) | 1614 TEST_F(WebFrameTest, setPageScaleFactorBeforeFrameHasView) |
1595 { | 1615 { |
1596 registerMockedHttpURLLoad("fixed_layout.html"); | 1616 registerMockedHttpURLLoad("fixed_layout.html"); |
1597 | 1617 |
1598 float pageScaleFactor = 3; | 1618 float pageScaleFactor = 3; |
1599 FrameTestHelpers::WebViewHelper webViewHelper; | 1619 FrameTestHelpers::WebViewHelper webViewHelper; |
1600 webViewHelper.initializeAndLoad("about:html", true, 0, 0); | 1620 webViewHelper.initializeAndLoad("about:html", true, 0, 0); |
1601 webViewHelper.webView()->setPageScaleFactor(pageScaleFactor); | 1621 webViewHelper.webView()->setPageScaleFactor(pageScaleFactor); |
1602 | 1622 |
1603 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "fixed_layout.html"); | 1623 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "fixed_layout.html"); |
| 1624 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
1604 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); | 1625 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); |
1605 EXPECT_EQ(pageScaleFactor, view->visibleContentScaleFactor()); | 1626 EXPECT_EQ(pageScaleFactor, view->visibleContentScaleFactor()); |
1606 } | 1627 } |
1607 | 1628 |
1608 TEST_F(WebFrameTest, pageScaleFactorWrittenToHistoryItem) | 1629 TEST_F(WebFrameTest, pageScaleFactorWrittenToHistoryItem) |
1609 { | 1630 { |
1610 UseMockScrollbarSettings mockScrollbarSettings; | 1631 UseMockScrollbarSettings mockScrollbarSettings; |
1611 registerMockedHttpURLLoad("fixed_layout.html"); | 1632 registerMockedHttpURLLoad("fixed_layout.html"); |
1612 | 1633 |
1613 FixedLayoutTestWebViewClient client; | 1634 FixedLayoutTestWebViewClient client; |
(...skipping 557 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2171 | 2192 |
2172 int viewWidth = 500; | 2193 int viewWidth = 500; |
2173 int viewHeight = 500; | 2194 int viewHeight = 500; |
2174 | 2195 |
2175 OwnPtr<FakeCompositingWebViewClient> fakeCompositingWebViewClient = adoptPtr
(new FakeCompositingWebViewClient()); | 2196 OwnPtr<FakeCompositingWebViewClient> fakeCompositingWebViewClient = adoptPtr
(new FakeCompositingWebViewClient()); |
2176 FrameTestHelpers::WebViewHelper webViewHelper; | 2197 FrameTestHelpers::WebViewHelper webViewHelper; |
2177 webViewHelper.initialize(true, 0, fakeCompositingWebViewClient.get(), &confi
gueCompositingWebView); | 2198 webViewHelper.initialize(true, 0, fakeCompositingWebViewClient.get(), &confi
gueCompositingWebView); |
2178 | 2199 |
2179 webViewHelper.webView()->resize(WebSize(viewWidth, viewHeight)); | 2200 webViewHelper.webView()->resize(WebSize(viewWidth, viewHeight)); |
2180 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "large-div.html"); | 2201 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "large-div.html"); |
| 2202 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
| 2203 webViewHelper.webView()->layout(); |
2181 | 2204 |
2182 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); | 2205 WebCore::FrameView* view = webViewHelper.webViewImpl()->mainFrameImpl()->fra
meView(); |
2183 EXPECT_TRUE(view->renderView()->compositor()->layerForHorizontalScrollbar())
; | 2206 EXPECT_TRUE(view->renderView()->compositor()->layerForHorizontalScrollbar())
; |
2184 EXPECT_TRUE(view->renderView()->compositor()->layerForVerticalScrollbar()); | 2207 EXPECT_TRUE(view->renderView()->compositor()->layerForVerticalScrollbar()); |
2185 | 2208 |
2186 webViewHelper.webView()->resize(WebSize(viewWidth * 10, viewHeight * 10)); | 2209 webViewHelper.webView()->resize(WebSize(viewWidth * 10, viewHeight * 10)); |
2187 webViewHelper.webView()->layout(); | 2210 webViewHelper.webView()->layout(); |
2188 EXPECT_FALSE(view->renderView()->compositor()->layerForHorizontalScrollbar()
); | 2211 EXPECT_FALSE(view->renderView()->compositor()->layerForHorizontalScrollbar()
); |
2189 EXPECT_FALSE(view->renderView()->compositor()->layerForVerticalScrollbar()); | 2212 EXPECT_FALSE(view->renderView()->compositor()->layerForVerticalScrollbar()); |
2190 } | 2213 } |
(...skipping 461 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2652 { | 2675 { |
2653 // Test for case in http://crbug.com/73104. Reloading a frame very quickly | 2676 // Test for case in http://crbug.com/73104. Reloading a frame very quickly |
2654 // would sometimes call decidePolicyForNavigation with isRedirect=true | 2677 // would sometimes call decidePolicyForNavigation with isRedirect=true |
2655 registerMockedHttpURLLoad("form.html"); | 2678 registerMockedHttpURLLoad("form.html"); |
2656 | 2679 |
2657 TestReloadDoesntRedirectWebFrameClient webFrameClient; | 2680 TestReloadDoesntRedirectWebFrameClient webFrameClient; |
2658 FrameTestHelpers::WebViewHelper webViewHelper; | 2681 FrameTestHelpers::WebViewHelper webViewHelper; |
2659 webViewHelper.initializeAndLoad(m_baseURL + "form.html", false, &webFrameCli
ent); | 2682 webViewHelper.initializeAndLoad(m_baseURL + "form.html", false, &webFrameCli
ent); |
2660 | 2683 |
2661 webViewHelper.webView()->mainFrame()->reload(true); | 2684 webViewHelper.webView()->mainFrame()->reload(true); |
2662 // start another reload before request is delivered. | 2685 // start reload before request is delivered. |
2663 FrameTestHelpers::reloadFrameIgnoringCache(webViewHelper.webView()->mainFram
e()); | 2686 webViewHelper.webView()->mainFrame()->reload(true); |
| 2687 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
2664 } | 2688 } |
2665 | 2689 |
2666 class ReloadWithOverrideURLTask : public WebThread::Task { | |
2667 public: | |
2668 ReloadWithOverrideURLTask(WebFrame* frame, const WebCore::KURL& url, bool ig
noreCache) | |
2669 : m_frame(frame), m_url(url), m_ignoreCache(ignoreCache) | |
2670 { | |
2671 } | |
2672 | |
2673 virtual void run() OVERRIDE | |
2674 { | |
2675 m_frame->reloadWithOverrideURL(m_url, m_ignoreCache); | |
2676 } | |
2677 | |
2678 private: | |
2679 WebFrame* const m_frame; | |
2680 const WebCore::KURL m_url; | |
2681 const bool m_ignoreCache; | |
2682 }; | |
2683 | |
2684 TEST_F(WebFrameTest, ReloadWithOverrideURLPreservesState) | 2690 TEST_F(WebFrameTest, ReloadWithOverrideURLPreservesState) |
2685 { | 2691 { |
2686 const std::string firstURL = "find.html"; | 2692 const std::string firstURL = "find.html"; |
2687 const std::string secondURL = "form.html"; | 2693 const std::string secondURL = "form.html"; |
2688 const std::string thirdURL = "history.html"; | 2694 const std::string thirdURL = "history.html"; |
2689 const float pageScaleFactor = 1.1684f; | 2695 const float pageScaleFactor = 1.1684f; |
2690 const int pageWidth = 640; | 2696 const int pageWidth = 640; |
2691 const int pageHeight = 480; | 2697 const int pageHeight = 480; |
2692 | 2698 |
2693 registerMockedHttpURLLoad(firstURL); | 2699 registerMockedHttpURLLoad(firstURL); |
2694 registerMockedHttpURLLoad(secondURL); | 2700 registerMockedHttpURLLoad(secondURL); |
2695 registerMockedHttpURLLoad(thirdURL); | 2701 registerMockedHttpURLLoad(thirdURL); |
2696 | 2702 |
2697 FrameTestHelpers::WebViewHelper webViewHelper; | 2703 FrameTestHelpers::WebViewHelper webViewHelper; |
2698 webViewHelper.initializeAndLoad(m_baseURL + firstURL, true); | 2704 webViewHelper.initializeAndLoad(m_baseURL + firstURL, true); |
2699 webViewHelper.webViewImpl()->resize(WebSize(pageWidth, pageHeight)); | 2705 webViewHelper.webViewImpl()->resize(WebSize(pageWidth, pageHeight)); |
2700 webViewHelper.webViewImpl()->mainFrame()->setScrollOffset(WebSize(pageWidth
/ 4, pageHeight / 4)); | 2706 webViewHelper.webViewImpl()->mainFrame()->setScrollOffset(WebSize(pageWidth
/ 4, pageHeight / 4)); |
2701 webViewHelper.webViewImpl()->setPageScaleFactor(pageScaleFactor); | 2707 webViewHelper.webViewImpl()->setPageScaleFactor(pageScaleFactor); |
2702 | 2708 |
2703 WebSize previousOffset = webViewHelper.webViewImpl()->mainFrame()->scrollOff
set(); | 2709 WebSize previousOffset = webViewHelper.webViewImpl()->mainFrame()->scrollOff
set(); |
2704 float previousScale = webViewHelper.webViewImpl()->pageScaleFactor(); | 2710 float previousScale = webViewHelper.webViewImpl()->pageScaleFactor(); |
2705 | 2711 |
2706 // Reload the page using the cache. | 2712 // Reload the page using the cache. |
2707 Platform::current()->currentThread()->postTask( | 2713 webViewHelper.webViewImpl()->mainFrame()->reloadWithOverrideURL(toKURL(m_bas
eURL + secondURL), false); |
2708 new ReloadWithOverrideURLTask(webViewHelper.webViewImpl()->mainFrame(),
toKURL(m_baseURL + secondURL), false)); | 2714 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
2709 FrameTestHelpers::pumpPendingRequestsDoNotUse(webViewHelper.webViewImpl()->m
ainFrame()); | |
2710 ASSERT_EQ(previousOffset, webViewHelper.webViewImpl()->mainFrame()->scrollOf
fset()); | 2715 ASSERT_EQ(previousOffset, webViewHelper.webViewImpl()->mainFrame()->scrollOf
fset()); |
2711 ASSERT_EQ(previousScale, webViewHelper.webViewImpl()->pageScaleFactor()); | 2716 ASSERT_EQ(previousScale, webViewHelper.webViewImpl()->pageScaleFactor()); |
2712 | 2717 |
2713 // Reload the page while ignoring the cache. | 2718 // Reload the page while ignoring the cache. |
2714 Platform::current()->currentThread()->postTask( | 2719 webViewHelper.webViewImpl()->mainFrame()->reloadWithOverrideURL(toKURL(m_bas
eURL + thirdURL), true); |
2715 new ReloadWithOverrideURLTask(webViewHelper.webViewImpl()->mainFrame(),
toKURL(m_baseURL + thirdURL), true)); | 2720 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
2716 FrameTestHelpers::pumpPendingRequestsDoNotUse(webViewHelper.webViewImpl()->m
ainFrame()); | |
2717 ASSERT_EQ(previousOffset, webViewHelper.webViewImpl()->mainFrame()->scrollOf
fset()); | 2721 ASSERT_EQ(previousOffset, webViewHelper.webViewImpl()->mainFrame()->scrollOf
fset()); |
2718 ASSERT_EQ(previousScale, webViewHelper.webViewImpl()->pageScaleFactor()); | 2722 ASSERT_EQ(previousScale, webViewHelper.webViewImpl()->pageScaleFactor()); |
2719 } | 2723 } |
2720 | 2724 |
2721 TEST_F(WebFrameTest, ReloadWhileProvisional) | 2725 TEST_F(WebFrameTest, ReloadWhileProvisional) |
2722 { | 2726 { |
2723 // Test that reloading while the previous load is still pending does not cau
se the initial | 2727 // Test that reloading while the previous load is still pending does not cau
se the initial |
2724 // request to get lost. | 2728 // request to get lost. |
2725 registerMockedHttpURLLoad("fixed_layout.html"); | 2729 registerMockedHttpURLLoad("fixed_layout.html"); |
2726 | 2730 |
2727 FrameTestHelpers::WebViewHelper webViewHelper; | 2731 FrameTestHelpers::WebViewHelper webViewHelper; |
2728 webViewHelper.initialize(); | 2732 webViewHelper.initialize(); |
2729 WebURLRequest request; | 2733 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "fixed_layout.html"); |
2730 request.initialize(); | |
2731 request.setURL(toKURL(m_baseURL + "fixed_layout.html")); | |
2732 webViewHelper.webView()->mainFrame()->loadRequest(request); | |
2733 // start reload before first request is delivered. | 2734 // start reload before first request is delivered. |
2734 FrameTestHelpers::reloadFrameIgnoringCache(webViewHelper.webView()->mainFram
e()); | 2735 webViewHelper.webView()->mainFrame()->reload(true); |
| 2736 |
| 2737 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
2735 | 2738 |
2736 WebDataSource* dataSource = webViewHelper.webView()->mainFrame()->dataSource
(); | 2739 WebDataSource* dataSource = webViewHelper.webView()->mainFrame()->dataSource
(); |
2737 ASSERT_TRUE(dataSource); | 2740 ASSERT_TRUE(dataSource); |
2738 EXPECT_EQ(toKURL(m_baseURL + "fixed_layout.html"), toKURL(dataSource->reques
t().url().spec())); | 2741 EXPECT_EQ(toKURL(m_baseURL + "fixed_layout.html"), toKURL(dataSource->reques
t().url().spec())); |
2739 } | 2742 } |
2740 | 2743 |
2741 TEST_F(WebFrameTest, AppendRedirects) | 2744 TEST_F(WebFrameTest, AppendRedirects) |
2742 { | 2745 { |
2743 const std::string firstURL = "about:blank"; | 2746 const std::string firstURL = "about:blank"; |
2744 const std::string secondURL = "http://www.test.com"; | 2747 const std::string secondURL = "http://www.test.com"; |
(...skipping 12 matching lines...) Expand all Loading... |
2757 EXPECT_EQ(toKURL(secondURL), toKURL(redirects[1].spec().data())); | 2760 EXPECT_EQ(toKURL(secondURL), toKURL(redirects[1].spec().data())); |
2758 } | 2761 } |
2759 | 2762 |
2760 TEST_F(WebFrameTest, IframeRedirect) | 2763 TEST_F(WebFrameTest, IframeRedirect) |
2761 { | 2764 { |
2762 registerMockedHttpURLLoad("iframe_redirect.html"); | 2765 registerMockedHttpURLLoad("iframe_redirect.html"); |
2763 registerMockedHttpURLLoad("visible_iframe.html"); | 2766 registerMockedHttpURLLoad("visible_iframe.html"); |
2764 | 2767 |
2765 FrameTestHelpers::WebViewHelper webViewHelper; | 2768 FrameTestHelpers::WebViewHelper webViewHelper; |
2766 webViewHelper.initializeAndLoad(m_baseURL + "iframe_redirect.html", true); | 2769 webViewHelper.initializeAndLoad(m_baseURL + "iframe_redirect.html", true); |
2767 // Pump pending requests one more time. The test page loads script that navi
gates. | 2770 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); /
/ Load the iframe. |
2768 FrameTestHelpers::pumpPendingRequestsDoNotUse(webViewHelper.webView()->mainF
rame()); | |
2769 | 2771 |
2770 WebFrame* iframe = webViewHelper.webView()->findFrameByName(WebString::fromU
TF8("ifr")); | 2772 WebFrame* iframe = webViewHelper.webView()->findFrameByName(WebString::fromU
TF8("ifr")); |
2771 ASSERT_TRUE(iframe); | 2773 ASSERT_TRUE(iframe); |
2772 WebDataSource* iframeDataSource = iframe->dataSource(); | 2774 WebDataSource* iframeDataSource = iframe->dataSource(); |
2773 ASSERT_TRUE(iframeDataSource); | 2775 ASSERT_TRUE(iframeDataSource); |
2774 WebVector<WebURL> redirects; | 2776 WebVector<WebURL> redirects; |
2775 iframeDataSource->redirectChain(redirects); | 2777 iframeDataSource->redirectChain(redirects); |
2776 ASSERT_EQ(2U, redirects.size()); | 2778 ASSERT_EQ(2U, redirects.size()); |
2777 EXPECT_EQ(toKURL("about:blank"), toKURL(redirects[0].spec().data())); | 2779 EXPECT_EQ(toKURL("about:blank"), toKURL(redirects[0].spec().data())); |
2778 EXPECT_EQ(toKURL("http://www.test.com/visible_iframe.html"), toKURL(redirect
s[1].spec().data())); | 2780 EXPECT_EQ(toKURL("http://www.test.com/visible_iframe.html"), toKURL(redirect
s[1].spec().data())); |
(...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2899 v8::HandleScope handleScope(v8::Isolate::GetCurrent()); | 2901 v8::HandleScope handleScope(v8::Isolate::GetCurrent()); |
2900 | 2902 |
2901 registerMockedHttpURLLoad("context_notifications_test.html"); | 2903 registerMockedHttpURLLoad("context_notifications_test.html"); |
2902 registerMockedHttpURLLoad("context_notifications_test_frame.html"); | 2904 registerMockedHttpURLLoad("context_notifications_test_frame.html"); |
2903 | 2905 |
2904 ContextLifetimeTestWebFrameClient webFrameClient; | 2906 ContextLifetimeTestWebFrameClient webFrameClient; |
2905 FrameTestHelpers::WebViewHelper webViewHelper; | 2907 FrameTestHelpers::WebViewHelper webViewHelper; |
2906 webViewHelper.initializeAndLoad(m_baseURL + "context_notifications_test.html
", true, &webFrameClient); | 2908 webViewHelper.initializeAndLoad(m_baseURL + "context_notifications_test.html
", true, &webFrameClient); |
2907 | 2909 |
2908 // Refresh, we should get two release notifications and two more create noti
fications. | 2910 // Refresh, we should get two release notifications and two more create noti
fications. |
2909 FrameTestHelpers::reloadFrame(webViewHelper.webView()->mainFrame()); | 2911 webViewHelper.webView()->mainFrame()->reload(false); |
| 2912 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
2910 ASSERT_EQ(4u, webFrameClient.createNotifications.size()); | 2913 ASSERT_EQ(4u, webFrameClient.createNotifications.size()); |
2911 ASSERT_EQ(2u, webFrameClient.releaseNotifications.size()); | 2914 ASSERT_EQ(2u, webFrameClient.releaseNotifications.size()); |
2912 | 2915 |
2913 // The two release notifications we got should be exactly the same as the fi
rst two create notifications. | 2916 // The two release notifications we got should be exactly the same as the fi
rst two create notifications. |
2914 for (size_t i = 0; i < webFrameClient.releaseNotifications.size(); ++i) { | 2917 for (size_t i = 0; i < webFrameClient.releaseNotifications.size(); ++i) { |
2915 EXPECT_TRUE(webFrameClient.releaseNotifications[i]->Equals( | 2918 EXPECT_TRUE(webFrameClient.releaseNotifications[i]->Equals( |
2916 webFrameClient.createNotifications[webFrameClient.createNotifications.
size() - 3 - i])); | 2919 webFrameClient.createNotifications[webFrameClient.createNotifications.
size() - 3 - i])); |
2917 } | 2920 } |
2918 | 2921 |
2919 // The last two create notifications should be for the current frames and co
ntext. | 2922 // The last two create notifications should be for the current frames and co
ntext. |
(...skipping 117 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3037 FrameTestHelpers::WebViewHelper webViewHelper; | 3040 FrameTestHelpers::WebViewHelper webViewHelper; |
3038 webViewHelper.initializeAndLoad("about:blank", true); | 3041 webViewHelper.initializeAndLoad("about:blank", true); |
3039 // We set the size because it impacts line wrapping, which changes the | 3042 // We set the size because it impacts line wrapping, which changes the |
3040 // resulting text value. | 3043 // resulting text value. |
3041 webViewHelper.webView()->resize(WebSize(640, 480)); | 3044 webViewHelper.webView()->resize(WebSize(640, 480)); |
3042 WebFrame* frame = webViewHelper.webView()->mainFrame(); | 3045 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
3043 | 3046 |
3044 // Generate a simple test case. | 3047 // Generate a simple test case. |
3045 const char simpleSource[] = "<div>Foo bar</div><div></div>baz"; | 3048 const char simpleSource[] = "<div>Foo bar</div><div></div>baz"; |
3046 WebCore::KURL testURL = toKURL("about:blank"); | 3049 WebCore::KURL testURL = toKURL("about:blank"); |
3047 FrameTestHelpers::loadHTMLString(frame, simpleSource, testURL); | 3050 frame->loadHTMLString(simpleSource, testURL); |
| 3051 runPendingTasks(); |
3048 | 3052 |
3049 // Make sure it comes out OK. | 3053 // Make sure it comes out OK. |
3050 const std::string expected("Foo bar\nbaz"); | 3054 const std::string expected("Foo bar\nbaz"); |
3051 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); | 3055 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); |
3052 EXPECT_EQ(expected, text.utf8()); | 3056 EXPECT_EQ(expected, text.utf8()); |
3053 | 3057 |
3054 // Try reading the same one with clipping of the text. | 3058 // Try reading the same one with clipping of the text. |
3055 const int length = 5; | 3059 const int length = 5; |
3056 text = frame->contentAsText(length); | 3060 text = frame->contentAsText(length); |
3057 EXPECT_EQ(expected.substr(0, length), text.utf8()); | 3061 EXPECT_EQ(expected.substr(0, length), text.utf8()); |
3058 | 3062 |
3059 // Now do a new test with a subframe. | 3063 // Now do a new test with a subframe. |
3060 const char outerFrameSource[] = "Hello<iframe></iframe> world"; | 3064 const char outerFrameSource[] = "Hello<iframe></iframe> world"; |
3061 FrameTestHelpers::loadHTMLString(frame, outerFrameSource, testURL); | 3065 frame->loadHTMLString(outerFrameSource, testURL); |
| 3066 runPendingTasks(); |
3062 | 3067 |
3063 // Load something into the subframe. | 3068 // Load something into the subframe. |
3064 WebFrame* subframe = frame->firstChild(); | 3069 WebFrame* subframe = frame->firstChild(); |
3065 ASSERT_TRUE(subframe); | 3070 ASSERT_TRUE(subframe); |
3066 FrameTestHelpers::loadHTMLString(subframe, "sub<p>text", testURL); | 3071 subframe->loadHTMLString("sub<p>text", testURL); |
| 3072 runPendingTasks(); |
3067 | 3073 |
3068 text = frame->contentAsText(std::numeric_limits<size_t>::max()); | 3074 text = frame->contentAsText(std::numeric_limits<size_t>::max()); |
3069 EXPECT_EQ("Hello world\n\nsub\ntext", text.utf8()); | 3075 EXPECT_EQ("Hello world\n\nsub\ntext", text.utf8()); |
3070 | 3076 |
3071 // Get the frame text where the subframe separator falls on the boundary of | 3077 // Get the frame text where the subframe separator falls on the boundary of |
3072 // what we'll take. There used to be a crash in this case. | 3078 // what we'll take. There used to be a crash in this case. |
3073 text = frame->contentAsText(12); | 3079 text = frame->contentAsText(12); |
3074 EXPECT_EQ("Hello world", text.utf8()); | 3080 EXPECT_EQ("Hello world", text.utf8()); |
3075 } | 3081 } |
3076 | 3082 |
3077 TEST_F(WebFrameTest, GetFullHtmlOfPage) | 3083 TEST_F(WebFrameTest, GetFullHtmlOfPage) |
3078 { | 3084 { |
3079 FrameTestHelpers::WebViewHelper webViewHelper; | 3085 FrameTestHelpers::WebViewHelper webViewHelper; |
3080 webViewHelper.initializeAndLoad("about:blank", true); | 3086 webViewHelper.initializeAndLoad("about:blank", true); |
3081 WebFrame* frame = webViewHelper.webView()->mainFrame(); | 3087 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
3082 | 3088 |
3083 // Generate a simple test case. | 3089 // Generate a simple test case. |
3084 const char simpleSource[] = "<p>Hello</p><p>World</p>"; | 3090 const char simpleSource[] = "<p>Hello</p><p>World</p>"; |
3085 WebCore::KURL testURL = toKURL("about:blank"); | 3091 WebCore::KURL testURL = toKURL("about:blank"); |
3086 FrameTestHelpers::loadHTMLString(frame, simpleSource, testURL); | 3092 frame->loadHTMLString(simpleSource, testURL); |
| 3093 runPendingTasks(); |
3087 | 3094 |
3088 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); | 3095 WebString text = frame->contentAsText(std::numeric_limits<size_t>::max()); |
3089 EXPECT_EQ("Hello\n\nWorld", text.utf8()); | 3096 EXPECT_EQ("Hello\n\nWorld", text.utf8()); |
3090 | 3097 |
3091 const std::string html = frame->contentAsMarkup().utf8(); | 3098 const std::string html = frame->contentAsMarkup().utf8(); |
3092 | 3099 |
3093 // Load again with the output html. | 3100 // Load again with the output html. |
3094 FrameTestHelpers::loadHTMLString(frame, html, testURL); | 3101 frame->loadHTMLString(WebData(html.c_str(), html.length()), testURL); |
| 3102 runPendingTasks(); |
3095 | 3103 |
3096 EXPECT_EQ(html, frame->contentAsMarkup().utf8()); | 3104 EXPECT_EQ(html, frame->contentAsMarkup().utf8()); |
3097 | 3105 |
3098 text = frame->contentAsText(std::numeric_limits<size_t>::max()); | 3106 text = frame->contentAsText(std::numeric_limits<size_t>::max()); |
3099 EXPECT_EQ("Hello\n\nWorld", text.utf8()); | 3107 EXPECT_EQ("Hello\n\nWorld", text.utf8()); |
3100 | 3108 |
3101 // Test selection check | 3109 // Test selection check |
3102 EXPECT_FALSE(frame->hasSelection()); | 3110 EXPECT_FALSE(frame->hasSelection()); |
3103 frame->executeCommand(WebString::fromUTF8("SelectAll")); | 3111 frame->executeCommand(WebString::fromUTF8("SelectAll")); |
3104 EXPECT_TRUE(frame->hasSelection()); | 3112 EXPECT_TRUE(frame->hasSelection()); |
(...skipping 12 matching lines...) Expand all Loading... |
3117 }; | 3125 }; |
3118 | 3126 |
3119 TEST_F(WebFrameTest, ExecuteScriptDuringDidCreateScriptContext) | 3127 TEST_F(WebFrameTest, ExecuteScriptDuringDidCreateScriptContext) |
3120 { | 3128 { |
3121 registerMockedHttpURLLoad("hello_world.html"); | 3129 registerMockedHttpURLLoad("hello_world.html"); |
3122 | 3130 |
3123 TestExecuteScriptDuringDidCreateScriptContext webFrameClient; | 3131 TestExecuteScriptDuringDidCreateScriptContext webFrameClient; |
3124 FrameTestHelpers::WebViewHelper webViewHelper; | 3132 FrameTestHelpers::WebViewHelper webViewHelper; |
3125 webViewHelper.initializeAndLoad(m_baseURL + "hello_world.html", true, &webFr
ameClient); | 3133 webViewHelper.initializeAndLoad(m_baseURL + "hello_world.html", true, &webFr
ameClient); |
3126 | 3134 |
3127 FrameTestHelpers::reloadFrame(webViewHelper.webView()->mainFrame()); | 3135 webViewHelper.webView()->mainFrame()->reload(); |
| 3136 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
3128 } | 3137 } |
3129 | 3138 |
3130 class FindUpdateWebFrameClient : public FrameTestHelpers::TestWebFrameClient { | 3139 class FindUpdateWebFrameClient : public FrameTestHelpers::TestWebFrameClient { |
3131 public: | 3140 public: |
3132 FindUpdateWebFrameClient() | 3141 FindUpdateWebFrameClient() |
3133 : m_findResultsAreReady(false) | 3142 : m_findResultsAreReady(false) |
3134 , m_count(-1) | 3143 , m_count(-1) |
3135 { | 3144 { |
3136 } | 3145 } |
3137 | 3146 |
(...skipping 935 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4073 private: | 4082 private: |
4074 bool m_commitCalled; | 4083 bool m_commitCalled; |
4075 }; | 4084 }; |
4076 | 4085 |
4077 TEST_F(WebFrameTest, ReplaceNavigationAfterHistoryNavigation) | 4086 TEST_F(WebFrameTest, ReplaceNavigationAfterHistoryNavigation) |
4078 { | 4087 { |
4079 TestSubstituteDataWebFrameClient webFrameClient; | 4088 TestSubstituteDataWebFrameClient webFrameClient; |
4080 | 4089 |
4081 FrameTestHelpers::WebViewHelper webViewHelper; | 4090 FrameTestHelpers::WebViewHelper webViewHelper; |
4082 webViewHelper.initializeAndLoad("about:blank", true, &webFrameClient); | 4091 webViewHelper.initializeAndLoad("about:blank", true, &webFrameClient); |
| 4092 runPendingTasks(); |
4083 WebFrame* frame = webViewHelper.webView()->mainFrame(); | 4093 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
4084 | 4094 |
4085 // Load a url as a history navigation that will return an error. TestSubstit
uteDataWebFrameClient | 4095 // Load a url as a history navigation that will return an error. TestSubstit
uteDataWebFrameClient |
4086 // will start a SubstituteData load in response to the load failure, which s
hould get fully committed. | 4096 // will start a SubstituteData load in response to the load failure, which s
hould get fully committed. |
4087 // Due to https://bugs.webkit.org/show_bug.cgi?id=91685, FrameLoader::didRec
eiveData() wasn't getting | 4097 // Due to https://bugs.webkit.org/show_bug.cgi?id=91685, FrameLoader::didRec
eiveData() wasn't getting |
4088 // called in this case, which resulted in the SubstituteData document not ge
tting displayed. | 4098 // called in this case, which resulted in the SubstituteData document not ge
tting displayed. |
4089 WebURLError error; | 4099 WebURLError error; |
4090 error.reason = 1337; | 4100 error.reason = 1337; |
4091 error.domain = "WebFrameTest"; | 4101 error.domain = "WebFrameTest"; |
4092 std::string errorURL = "http://0.0.0.0"; | 4102 std::string errorURL = "http://0.0.0.0"; |
(...skipping 426 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4519 TEST_F(WebFrameTest, DidAccessInitialDocumentViaJavascriptUrl) | 4529 TEST_F(WebFrameTest, DidAccessInitialDocumentViaJavascriptUrl) |
4520 { | 4530 { |
4521 TestAccessInitialDocumentWebFrameClient webFrameClient; | 4531 TestAccessInitialDocumentWebFrameClient webFrameClient; |
4522 FrameTestHelpers::WebViewHelper webViewHelper; | 4532 FrameTestHelpers::WebViewHelper webViewHelper; |
4523 webViewHelper.initialize(true, &webFrameClient); | 4533 webViewHelper.initialize(true, &webFrameClient); |
4524 runPendingTasks(); | 4534 runPendingTasks(); |
4525 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); | 4535 EXPECT_FALSE(webFrameClient.m_didAccessInitialDocument); |
4526 | 4536 |
4527 // Access the initial document from a javascript: URL. | 4537 // Access the initial document from a javascript: URL. |
4528 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.body.appendChild(document.createTextNode('Modified'))"); | 4538 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.body.appendChild(document.createTextNode('Modified'))"); |
| 4539 runPendingTasks(); |
4529 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); | 4540 EXPECT_TRUE(webFrameClient.m_didAccessInitialDocument); |
4530 } | 4541 } |
4531 | 4542 |
4532 // Fails on the WebKit XP (deps) bot. http://crbug.com/312192 | 4543 // Fails on the WebKit XP (deps) bot. http://crbug.com/312192 |
4533 #if OS(WIN) | 4544 #if OS(WIN) |
4534 TEST_F(WebFrameTest, DISABLED_DidAccessInitialDocumentBodyBeforeModalDialog) | 4545 TEST_F(WebFrameTest, DISABLED_DidAccessInitialDocumentBodyBeforeModalDialog) |
4535 #else | 4546 #else |
4536 TEST_F(WebFrameTest, DidAccessInitialDocumentBodyBeforeModalDialog) | 4547 TEST_F(WebFrameTest, DidAccessInitialDocumentBodyBeforeModalDialog) |
4537 #endif | 4548 #endif |
4538 { | 4549 { |
(...skipping 272 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4811 WebCore::Document* document = webViewHelper.webViewImpl()->page()->mainFrame
()->document(); | 4822 WebCore::Document* document = webViewHelper.webViewImpl()->page()->mainFrame
()->document(); |
4812 WebCore::KURL destination = toKURL(m_baseURL + "hello_world.html"); | 4823 WebCore::KURL destination = toKURL(m_baseURL + "hello_world.html"); |
4813 | 4824 |
4814 // ctrl+click event | 4825 // ctrl+click event |
4815 RefPtrWillBeRawPtr<WebCore::Event> event = WebCore::MouseEvent::create(WebCo
re::EventTypeNames::click, false, false, | 4826 RefPtrWillBeRawPtr<WebCore::Event> event = WebCore::MouseEvent::create(WebCo
re::EventTypeNames::click, false, false, |
4816 document->domWindow(), 0, 0, 0, 0, 0, 0, 0, true, false, false, false, 0
, nullptr, nullptr); | 4827 document->domWindow(), 0, 0, 0, 0, 0, 0, 0, true, false, false, false, 0
, nullptr, nullptr); |
4817 WebCore::FrameLoadRequest frameRequest(document, WebCore::ResourceRequest(de
stination)); | 4828 WebCore::FrameLoadRequest frameRequest(document, WebCore::ResourceRequest(de
stination)); |
4818 frameRequest.setTriggeringEvent(event); | 4829 frameRequest.setTriggeringEvent(event); |
4819 WebCore::UserGestureIndicator gesture(WebCore::DefinitelyProcessingUserGestu
re); | 4830 WebCore::UserGestureIndicator gesture(WebCore::DefinitelyProcessingUserGestu
re); |
4820 webViewHelper.webViewImpl()->page()->mainFrame()->loader().load(frameRequest
); | 4831 webViewHelper.webViewImpl()->page()->mainFrame()->loader().load(frameRequest
); |
4821 FrameTestHelpers::pumpPendingRequestsDoNotUse(webViewHelper.webView()->mainF
rame()); | |
4822 | 4832 |
4823 // decidePolicyForNavigation should be called both for the original request
and the ctrl+click. | 4833 // decidePolicyForNavigation should be called both for the original request
and the ctrl+click. |
4824 EXPECT_EQ(2, webFrameClient.decidePolicyCallCount()); | 4834 EXPECT_EQ(2, webFrameClient.decidePolicyCallCount()); |
4825 } | 4835 } |
4826 | 4836 |
4827 TEST_F(WebFrameTest, BackToReload) | 4837 TEST_F(WebFrameTest, BackToReload) |
4828 { | 4838 { |
4829 registerMockedHttpURLLoad("fragment_middle_click.html"); | 4839 registerMockedHttpURLLoad("fragment_middle_click.html"); |
4830 FrameTestHelpers::WebViewHelper webViewHelper; | 4840 FrameTestHelpers::WebViewHelper webViewHelper; |
4831 webViewHelper.initializeAndLoad(m_baseURL + "fragment_middle_click.html", tr
ue); | 4841 webViewHelper.initializeAndLoad(m_baseURL + "fragment_middle_click.html", tr
ue); |
4832 WebFrame* frame = webViewHelper.webView()->mainFrame(); | 4842 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
4833 const WebCore::FrameLoader& mainFrameLoader = webViewHelper.webViewImpl()->m
ainFrameImpl()->frame()->loader(); | 4843 const WebCore::FrameLoader& mainFrameLoader = webViewHelper.webViewImpl()->m
ainFrameImpl()->frame()->loader(); |
4834 RefPtr<WebCore::HistoryItem> firstItem = mainFrameLoader.currentItem(); | 4844 RefPtr<WebCore::HistoryItem> firstItem = mainFrameLoader.currentItem(); |
4835 EXPECT_TRUE(firstItem); | 4845 EXPECT_TRUE(firstItem); |
4836 | 4846 |
4837 registerMockedHttpURLLoad("white-1x1.png"); | 4847 registerMockedHttpURLLoad("white-1x1.png"); |
4838 FrameTestHelpers::loadFrame(frame, m_baseURL + "white-1x1.png"); | 4848 FrameTestHelpers::loadFrame(frame, m_baseURL + "white-1x1.png"); |
| 4849 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
4839 EXPECT_NE(firstItem.get(), mainFrameLoader.currentItem()); | 4850 EXPECT_NE(firstItem.get(), mainFrameLoader.currentItem()); |
4840 | 4851 |
4841 frame->loadHistoryItem(WebHistoryItem(firstItem.get()), WebHistoryDifferentD
ocumentLoad, WebURLRequest::UseProtocolCachePolicy); | 4852 frame->loadHistoryItem(WebHistoryItem(firstItem.get()), WebHistoryDifferentD
ocumentLoad, WebURLRequest::UseProtocolCachePolicy); |
4842 FrameTestHelpers::pumpPendingRequestsDoNotUse(frame); | 4853 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
4843 EXPECT_EQ(firstItem.get(), mainFrameLoader.currentItem()); | 4854 EXPECT_EQ(firstItem.get(), mainFrameLoader.currentItem()); |
4844 | 4855 |
4845 FrameTestHelpers::reloadFrame(frame); | 4856 frame->reload(); |
| 4857 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
4846 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); | 4858 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); |
4847 } | 4859 } |
4848 | 4860 |
4849 TEST_F(WebFrameTest, BackDuringChildFrameReload) | 4861 TEST_F(WebFrameTest, BackDuringChildFrameReload) |
4850 { | 4862 { |
4851 registerMockedHttpURLLoad("page_with_blank_iframe.html"); | 4863 registerMockedHttpURLLoad("page_with_blank_iframe.html"); |
4852 FrameTestHelpers::WebViewHelper webViewHelper; | 4864 FrameTestHelpers::WebViewHelper webViewHelper; |
4853 webViewHelper.initializeAndLoad(m_baseURL + "page_with_blank_iframe.html", t
rue); | 4865 webViewHelper.initializeAndLoad(m_baseURL + "page_with_blank_iframe.html", t
rue); |
4854 WebFrame* mainFrame = webViewHelper.webView()->mainFrame(); | 4866 WebFrame* mainFrame = webViewHelper.webView()->mainFrame(); |
4855 const WebCore::FrameLoader& mainFrameLoader = webViewHelper.webViewImpl()->m
ainFrameImpl()->frame()->loader(); | 4867 const WebCore::FrameLoader& mainFrameLoader = webViewHelper.webViewImpl()->m
ainFrameImpl()->frame()->loader(); |
4856 WebFrame* childFrame = mainFrame->firstChild(); | 4868 WebFrame* childFrame = mainFrame->firstChild(); |
4857 ASSERT_TRUE(childFrame); | 4869 ASSERT_TRUE(childFrame); |
4858 | 4870 |
4859 // Start a history navigation, then have a different frame commit a navigati
on. | 4871 // Start a history navigation, then have a different frame commit a navigati
on. |
4860 // In this case, reload an about:blank frame, which will commit synchronousl
y. | 4872 // In this case, reload an about:blank frame, which will commit synchronousl
y. |
4861 // After the history navigation completes, both the appropriate document url
and | 4873 // After the history navigation completes, both the appropriate document url
and |
4862 // the current history item should reflect the history navigation. | 4874 // the current history item should reflect the history navigation. |
4863 registerMockedHttpURLLoad("white-1x1.png"); | 4875 registerMockedHttpURLLoad("white-1x1.png"); |
4864 WebHistoryItem item; | 4876 WebHistoryItem item; |
4865 item.initialize(); | 4877 item.initialize(); |
4866 WebURL historyURL(toKURL(m_baseURL + "white-1x1.png")); | 4878 WebURL historyURL(toKURL(m_baseURL + "white-1x1.png")); |
4867 item.setURLString(historyURL.string()); | 4879 item.setURLString(historyURL.string()); |
4868 mainFrame->loadHistoryItem(item, WebHistoryDifferentDocumentLoad, WebURLRequ
est::UseProtocolCachePolicy); | 4880 mainFrame->loadHistoryItem(item, WebHistoryDifferentDocumentLoad, WebURLRequ
est::UseProtocolCachePolicy); |
4869 | 4881 |
4870 FrameTestHelpers::reloadFrame(childFrame); | 4882 childFrame->reload(); |
| 4883 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
4871 EXPECT_EQ(item.urlString(), mainFrame->document().url().string()); | 4884 EXPECT_EQ(item.urlString(), mainFrame->document().url().string()); |
4872 EXPECT_EQ(item.urlString(), WebString(mainFrameLoader.currentItem()->urlStri
ng())); | 4885 EXPECT_EQ(item.urlString(), WebString(mainFrameLoader.currentItem()->urlStri
ng())); |
4873 } | 4886 } |
4874 | 4887 |
4875 TEST_F(WebFrameTest, ReloadPost) | 4888 TEST_F(WebFrameTest, ReloadPost) |
4876 { | 4889 { |
4877 registerMockedHttpURLLoad("reload_post.html"); | 4890 registerMockedHttpURLLoad("reload_post.html"); |
4878 FrameTestHelpers::WebViewHelper webViewHelper; | 4891 FrameTestHelpers::WebViewHelper webViewHelper; |
4879 webViewHelper.initializeAndLoad(m_baseURL + "reload_post.html", true); | 4892 webViewHelper.initializeAndLoad(m_baseURL + "reload_post.html", true); |
4880 WebFrame* frame = webViewHelper.webView()->mainFrame(); | 4893 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
4881 | 4894 |
4882 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.forms[0].submit()"); | 4895 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), "javascrip
t:document.forms[0].submit()"); |
4883 // Pump requests one more time after the javascript URL has executed to | 4896 runPendingTasks(); |
4884 // trigger the actual POST load request. | 4897 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
4885 FrameTestHelpers::pumpPendingRequestsDoNotUse(webViewHelper.webView()->mainF
rame()); | |
4886 EXPECT_EQ(WebString::fromUTF8("POST"), frame->dataSource()->request().httpMe
thod()); | 4898 EXPECT_EQ(WebString::fromUTF8("POST"), frame->dataSource()->request().httpMe
thod()); |
4887 | 4899 |
4888 FrameTestHelpers::reloadFrame(frame); | 4900 frame->reload(); |
| 4901 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
4889 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); | 4902 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); |
4890 EXPECT_EQ(WebNavigationTypeFormResubmitted, frame->dataSource()->navigationT
ype()); | 4903 EXPECT_EQ(WebNavigationTypeFormResubmitted, frame->dataSource()->navigationT
ype()); |
4891 } | 4904 } |
4892 | 4905 |
4893 TEST_F(WebFrameTest, LoadHistoryItemReload) | 4906 TEST_F(WebFrameTest, LoadHistoryItemReload) |
4894 { | 4907 { |
4895 registerMockedHttpURLLoad("fragment_middle_click.html"); | 4908 registerMockedHttpURLLoad("fragment_middle_click.html"); |
4896 FrameTestHelpers::WebViewHelper webViewHelper; | 4909 FrameTestHelpers::WebViewHelper webViewHelper; |
4897 webViewHelper.initializeAndLoad(m_baseURL + "fragment_middle_click.html", tr
ue); | 4910 webViewHelper.initializeAndLoad(m_baseURL + "fragment_middle_click.html", tr
ue); |
4898 WebFrame* frame = webViewHelper.webView()->mainFrame(); | 4911 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
4899 const WebCore::FrameLoader& mainFrameLoader = webViewHelper.webViewImpl()->m
ainFrameImpl()->frame()->loader(); | 4912 const WebCore::FrameLoader& mainFrameLoader = webViewHelper.webViewImpl()->m
ainFrameImpl()->frame()->loader(); |
4900 RefPtr<WebCore::HistoryItem> firstItem = mainFrameLoader.currentItem(); | 4913 RefPtr<WebCore::HistoryItem> firstItem = mainFrameLoader.currentItem(); |
4901 EXPECT_TRUE(firstItem); | 4914 EXPECT_TRUE(firstItem); |
4902 | 4915 |
4903 registerMockedHttpURLLoad("white-1x1.png"); | 4916 registerMockedHttpURLLoad("white-1x1.png"); |
4904 FrameTestHelpers::loadFrame(frame, m_baseURL + "white-1x1.png"); | 4917 FrameTestHelpers::loadFrame(frame, m_baseURL + "white-1x1.png"); |
| 4918 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
4905 EXPECT_NE(firstItem.get(), mainFrameLoader.currentItem()); | 4919 EXPECT_NE(firstItem.get(), mainFrameLoader.currentItem()); |
4906 | 4920 |
4907 // Cache policy overrides should take. | 4921 // Cache policy overrides should take. |
4908 frame->loadHistoryItem(WebHistoryItem(firstItem), WebHistoryDifferentDocumen
tLoad, WebURLRequest::ReloadIgnoringCacheData); | 4922 frame->loadHistoryItem(WebHistoryItem(firstItem), WebHistoryDifferentDocumen
tLoad, WebURLRequest::ReloadIgnoringCacheData); |
4909 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); | 4923 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
4910 EXPECT_EQ(firstItem.get(), mainFrameLoader.currentItem()); | 4924 EXPECT_EQ(firstItem.get(), mainFrameLoader.currentItem()); |
4911 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); | 4925 EXPECT_EQ(WebURLRequest::ReloadIgnoringCacheData, frame->dataSource()->reque
st().cachePolicy()); |
4912 } | 4926 } |
4913 | 4927 |
4914 | 4928 |
4915 class TestCachePolicyWebFrameClient : public FrameTestHelpers::TestWebFrameClien
t { | 4929 class TestCachePolicyWebFrameClient : public WebFrameClient { |
4916 public: | 4930 public: |
4917 explicit TestCachePolicyWebFrameClient(TestCachePolicyWebFrameClient* parent
Client) | 4931 TestCachePolicyWebFrameClient() |
4918 : m_parentClient(parentClient) | 4932 : m_policy(WebURLRequest::UseProtocolCachePolicy) |
4919 , m_policy(WebURLRequest::UseProtocolCachePolicy) | 4933 , m_client(0) |
4920 , m_childClient(0) | |
4921 , m_willSendRequestCallCount(0) | 4934 , m_willSendRequestCallCount(0) |
4922 , m_childFrameCreationCount(0) | 4935 , m_childFrameCreationCount(0) |
4923 { | 4936 { |
4924 } | 4937 } |
4925 | 4938 |
4926 void setChildWebFrameClient(TestCachePolicyWebFrameClient* client) { m_child
Client = client; } | 4939 void setChildWebFrameClient(WebFrameClient* client) { m_client = client; } |
4927 WebURLRequest::CachePolicy cachePolicy() const { return m_policy; } | 4940 WebURLRequest::CachePolicy cachePolicy() const { return m_policy; } |
4928 int willSendRequestCallCount() const { return m_willSendRequestCallCount; } | 4941 int willSendRequestCallCount() const { return m_willSendRequestCallCount; } |
4929 int childFrameCreationCount() const { return m_childFrameCreationCount; } | 4942 int childFrameCreationCount() const { return m_childFrameCreationCount; } |
4930 | 4943 |
4931 virtual WebFrame* createChildFrame(WebLocalFrame* parent, const WebString&) | 4944 virtual WebFrame* createChildFrame(WebLocalFrame* parent, const WebString&) |
4932 { | 4945 { |
4933 ASSERT(m_childClient); | |
4934 m_childFrameCreationCount++; | 4946 m_childFrameCreationCount++; |
4935 WebFrame* frame = WebLocalFrame::create(m_childClient); | 4947 WebFrame* frame = WebLocalFrame::create(m_client); |
4936 parent->appendChild(frame); | 4948 parent->appendChild(frame); |
4937 return frame; | 4949 return frame; |
4938 } | 4950 } |
4939 | 4951 |
4940 virtual void didStartLoading(bool toDifferentDocument) | 4952 virtual void frameDetached(WebFrame* frame) OVERRIDE |
4941 { | 4953 { |
4942 if (m_parentClient) { | 4954 if (frame->parent()) |
4943 m_parentClient->didStartLoading(toDifferentDocument); | 4955 frame->parent()->removeChild(frame); |
4944 return; | 4956 frame->close(); |
4945 } | |
4946 TestWebFrameClient::didStartLoading(toDifferentDocument); | |
4947 } | |
4948 | |
4949 virtual void didStopLoading() | |
4950 { | |
4951 if (m_parentClient) { | |
4952 m_parentClient->didStopLoading(); | |
4953 return; | |
4954 } | |
4955 TestWebFrameClient::didStopLoading(); | |
4956 } | 4957 } |
4957 | 4958 |
4958 virtual void willSendRequest(WebLocalFrame* frame, unsigned, WebURLRequest&
request, const WebURLResponse&) OVERRIDE | 4959 virtual void willSendRequest(WebLocalFrame* frame, unsigned, WebURLRequest&
request, const WebURLResponse&) OVERRIDE |
4959 { | 4960 { |
4960 m_policy = request.cachePolicy(); | 4961 m_policy = request.cachePolicy(); |
4961 m_willSendRequestCallCount++; | 4962 m_willSendRequestCallCount++; |
4962 } | 4963 } |
4963 | 4964 |
4964 private: | 4965 private: |
4965 TestCachePolicyWebFrameClient* m_parentClient; | |
4966 | |
4967 WebURLRequest::CachePolicy m_policy; | 4966 WebURLRequest::CachePolicy m_policy; |
4968 TestCachePolicyWebFrameClient* m_childClient; | 4967 WebFrameClient* m_client; |
4969 int m_willSendRequestCallCount; | 4968 int m_willSendRequestCallCount; |
4970 int m_childFrameCreationCount; | 4969 int m_childFrameCreationCount; |
4971 }; | 4970 }; |
4972 | 4971 |
4973 TEST_F(WebFrameTest, ReloadIframe) | 4972 TEST_F(WebFrameTest, ReloadIframe) |
4974 { | 4973 { |
4975 registerMockedHttpURLLoad("iframe_reload.html"); | 4974 registerMockedHttpURLLoad("iframe_reload.html"); |
4976 registerMockedHttpURLLoad("visible_iframe.html"); | 4975 registerMockedHttpURLLoad("visible_iframe.html"); |
4977 TestCachePolicyWebFrameClient mainClient(0); | 4976 TestCachePolicyWebFrameClient mainClient; |
4978 TestCachePolicyWebFrameClient childClient(&mainClient); | 4977 TestCachePolicyWebFrameClient childClient; |
4979 mainClient.setChildWebFrameClient(&childClient); | 4978 mainClient.setChildWebFrameClient(&childClient); |
4980 | 4979 |
4981 FrameTestHelpers::WebViewHelper webViewHelper; | 4980 FrameTestHelpers::WebViewHelper webViewHelper; |
4982 webViewHelper.initializeAndLoad(m_baseURL + "iframe_reload.html", true, &mai
nClient); | 4981 webViewHelper.initializeAndLoad(m_baseURL + "iframe_reload.html", true, &mai
nClient); |
4983 | 4982 |
4984 WebLocalFrameImpl* mainFrame = webViewHelper.webViewImpl()->mainFrameImpl(); | 4983 WebLocalFrameImpl* mainFrame = webViewHelper.webViewImpl()->mainFrameImpl(); |
4985 RefPtr<WebLocalFrameImpl> childFrame = toWebLocalFrameImpl(mainFrame->firstC
hild()); | 4984 RefPtr<WebLocalFrameImpl> childFrame = toWebLocalFrameImpl(mainFrame->firstC
hild()); |
4986 ASSERT_EQ(childFrame->client(), &childClient); | 4985 ASSERT_EQ(childFrame->client(), &childClient); |
4987 EXPECT_EQ(mainClient.childFrameCreationCount(), 1); | 4986 EXPECT_EQ(mainClient.childFrameCreationCount(), 1); |
4988 EXPECT_EQ(childClient.willSendRequestCallCount(), 1); | 4987 EXPECT_EQ(childClient.willSendRequestCallCount(), 1); |
4989 EXPECT_EQ(childClient.cachePolicy(), WebURLRequest::UseProtocolCachePolicy); | 4988 EXPECT_EQ(childClient.cachePolicy(), WebURLRequest::UseProtocolCachePolicy); |
4990 | 4989 |
4991 FrameTestHelpers::reloadFrame(mainFrame); | 4990 mainFrame->reload(false); |
| 4991 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
4992 | 4992 |
4993 // A new WebFrame should have been created, but the child WebFrameClient sho
uld be reused. | 4993 // A new WebFrame should have been created, but the child WebFrameClient sho
uld be reused. |
4994 ASSERT_NE(childFrame, toWebLocalFrameImpl(mainFrame->firstChild())); | 4994 ASSERT_NE(childFrame, toWebLocalFrameImpl(mainFrame->firstChild())); |
4995 ASSERT_EQ(toWebLocalFrameImpl(mainFrame->firstChild())->client(), &childClie
nt); | 4995 ASSERT_EQ(toWebLocalFrameImpl(mainFrame->firstChild())->client(), &childClie
nt); |
4996 | 4996 |
4997 EXPECT_EQ(mainClient.childFrameCreationCount(), 2); | 4997 EXPECT_EQ(mainClient.childFrameCreationCount(), 2); |
4998 EXPECT_EQ(childClient.willSendRequestCallCount(), 2); | 4998 EXPECT_EQ(childClient.willSendRequestCallCount(), 2); |
4999 EXPECT_EQ(childClient.cachePolicy(), WebURLRequest::ReloadIgnoringCacheData)
; | 4999 EXPECT_EQ(childClient.cachePolicy(), WebURLRequest::ReloadIgnoringCacheData)
; |
5000 } | 5000 } |
5001 | 5001 |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
5036 TEST_F(WebFrameTest, WebNodeImageContents) | 5036 TEST_F(WebFrameTest, WebNodeImageContents) |
5037 { | 5037 { |
5038 FrameTestHelpers::WebViewHelper webViewHelper; | 5038 FrameTestHelpers::WebViewHelper webViewHelper; |
5039 webViewHelper.initializeAndLoad("about:blank", true); | 5039 webViewHelper.initializeAndLoad("about:blank", true); |
5040 WebFrame* frame = webViewHelper.webView()->mainFrame(); | 5040 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
5041 | 5041 |
5042 static const char bluePNG[] = "<img src=\"data:image/png;base64,iVBORw0KGgoA
AAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAGElEQVQYV2NkYPj/n4EIwDiqEF8oUT94AFIQE/cCn90I
AAAAAElFTkSuQmCC\">"; | 5042 static const char bluePNG[] = "<img src=\"data:image/png;base64,iVBORw0KGgoA
AAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAGElEQVQYV2NkYPj/n4EIwDiqEF8oUT94AFIQE/cCn90I
AAAAAElFTkSuQmCC\">"; |
5043 | 5043 |
5044 // Load up the image and test that we can extract the contents. | 5044 // Load up the image and test that we can extract the contents. |
5045 WebCore::KURL testURL = toKURL("about:blank"); | 5045 WebCore::KURL testURL = toKURL("about:blank"); |
5046 FrameTestHelpers::loadHTMLString(frame, bluePNG, testURL); | 5046 frame->loadHTMLString(bluePNG, testURL); |
| 5047 runPendingTasks(); |
5047 | 5048 |
5048 WebNode node = frame->document().body().firstChild(); | 5049 WebNode node = frame->document().body().firstChild(); |
5049 EXPECT_TRUE(node.isElementNode()); | 5050 EXPECT_TRUE(node.isElementNode()); |
5050 WebElement element = node.to<WebElement>(); | 5051 WebElement element = node.to<WebElement>(); |
5051 WebImage image = element.imageContents(); | 5052 WebImage image = element.imageContents(); |
5052 ASSERT_FALSE(image.isNull()); | 5053 ASSERT_FALSE(image.isNull()); |
5053 EXPECT_EQ(image.size().width, 10); | 5054 EXPECT_EQ(image.size().width, 10); |
5054 EXPECT_EQ(image.size().height, 10); | 5055 EXPECT_EQ(image.size().height, 10); |
5055 // FIXME: The rest of this test is disabled since the ImageDecodeCache state
may be inconsistent when this test runs. | 5056 // FIXME: The rest of this test is disabled since the ImageDecodeCache state
may be inconsistent when this test runs. |
5056 // crbug.com/266088 | 5057 // crbug.com/266088 |
5057 // SkBitmap bitmap = image.getSkBitmap(); | 5058 // SkBitmap bitmap = image.getSkBitmap(); |
5058 // SkAutoLockPixels locker(bitmap); | 5059 // SkAutoLockPixels locker(bitmap); |
5059 // EXPECT_EQ(bitmap.getColor(0, 0), SK_ColorBLUE); | 5060 // EXPECT_EQ(bitmap.getColor(0, 0), SK_ColorBLUE); |
5060 } | 5061 } |
5061 | 5062 |
5062 class TestStartStopCallbackWebFrameClient : public FrameTestHelpers::TestWebFram
eClient { | 5063 class TestStartStopCallbackWebFrameClient : public WebFrameClient { |
5063 public: | 5064 public: |
5064 TestStartStopCallbackWebFrameClient() | 5065 TestStartStopCallbackWebFrameClient() |
5065 : m_startLoadingCount(0) | 5066 : m_startLoadingCount(0) |
5066 , m_stopLoadingCount(0) | 5067 , m_stopLoadingCount(0) |
5067 , m_differentDocumentStartCount(0) | 5068 , m_differentDocumentStartCount(0) |
5068 { | 5069 { |
5069 } | 5070 } |
5070 | 5071 |
5071 virtual void didStartLoading(bool toDifferentDocument) OVERRIDE | 5072 virtual void didStartLoading(bool toDifferentDocument) OVERRIDE |
5072 { | 5073 { |
5073 TestWebFrameClient::didStartLoading(toDifferentDocument); | |
5074 m_startLoadingCount++; | 5074 m_startLoadingCount++; |
5075 if (toDifferentDocument) | 5075 if (toDifferentDocument) |
5076 m_differentDocumentStartCount++; | 5076 m_differentDocumentStartCount++; |
5077 } | 5077 } |
5078 | 5078 |
5079 virtual void didStopLoading() OVERRIDE | 5079 virtual void didStopLoading() OVERRIDE |
5080 { | 5080 { |
5081 TestWebFrameClient::didStopLoading(); | |
5082 m_stopLoadingCount++; | 5081 m_stopLoadingCount++; |
5083 } | 5082 } |
5084 | 5083 |
5085 int startLoadingCount() const { return m_startLoadingCount; } | 5084 int startLoadingCount() const { return m_startLoadingCount; } |
5086 int stopLoadingCount() const { return m_stopLoadingCount; } | 5085 int stopLoadingCount() const { return m_stopLoadingCount; } |
5087 int differentDocumentStartCount() const { return m_differentDocumentStartCou
nt; } | 5086 int differentDocumentStartCount() const { return m_differentDocumentStartCou
nt; } |
5088 | 5087 |
5089 private: | 5088 private: |
5090 int m_startLoadingCount; | 5089 int m_startLoadingCount; |
5091 int m_stopLoadingCount; | 5090 int m_stopLoadingCount; |
5092 int m_differentDocumentStartCount; | 5091 int m_differentDocumentStartCount; |
5093 }; | 5092 }; |
5094 | 5093 |
5095 TEST_F(WebFrameTest, PushStateStartsAndStops) | 5094 TEST_F(WebFrameTest, PushStateStartsAndStops) |
5096 { | 5095 { |
5097 registerMockedHttpURLLoad("push_state.html"); | 5096 registerMockedHttpURLLoad("push_state.html"); |
5098 TestStartStopCallbackWebFrameClient client; | 5097 TestStartStopCallbackWebFrameClient client; |
5099 FrameTestHelpers::WebViewHelper webViewHelper; | 5098 FrameTestHelpers::WebViewHelper webViewHelper; |
5100 webViewHelper.initializeAndLoad(m_baseURL + "push_state.html", true, &client
); | 5099 webViewHelper.initializeAndLoad(m_baseURL + "push_state.html", true, &client
); |
| 5100 runPendingTasks(); |
5101 | 5101 |
5102 EXPECT_EQ(client.startLoadingCount(), 2); | 5102 EXPECT_EQ(client.startLoadingCount(), 2); |
5103 EXPECT_EQ(client.stopLoadingCount(), 2); | 5103 EXPECT_EQ(client.stopLoadingCount(), 2); |
5104 EXPECT_EQ(client.differentDocumentStartCount(), 1); | 5104 EXPECT_EQ(client.differentDocumentStartCount(), 1); |
5105 } | 5105 } |
5106 | 5106 |
5107 class TestHistoryWebFrameClient : public FrameTestHelpers::TestWebFrameClient { | 5107 class TestHistoryWebFrameClient : public WebFrameClient { |
5108 public: | 5108 public: |
5109 TestHistoryWebFrameClient() | 5109 TestHistoryWebFrameClient() |
5110 { | 5110 { |
5111 m_replacesCurrentHistoryItem = false; | 5111 m_replacesCurrentHistoryItem = false; |
5112 m_frame = 0; | 5112 m_frame = 0; |
5113 } | 5113 } |
5114 void didStartProvisionalLoad(WebLocalFrame* frame) | 5114 void didStartProvisionalLoad(WebLocalFrame* frame) |
5115 { | 5115 { |
5116 WebDataSource* ds = frame->provisionalDataSource(); | 5116 WebDataSource* ds = frame->provisionalDataSource(); |
5117 m_replacesCurrentHistoryItem = ds->replacesCurrentHistoryItem(); | 5117 m_replacesCurrentHistoryItem = ds->replacesCurrentHistoryItem(); |
(...skipping 11 matching lines...) Expand all Loading... |
5129 // Test which ensures that the first navigation in a subframe will always | 5129 // Test which ensures that the first navigation in a subframe will always |
5130 // result in history entry being replaced and not a new one added. | 5130 // result in history entry being replaced and not a new one added. |
5131 TEST_F(WebFrameTest, DISABLED_FirstFrameNavigationReplacesHistory) | 5131 TEST_F(WebFrameTest, DISABLED_FirstFrameNavigationReplacesHistory) |
5132 { | 5132 { |
5133 registerMockedHttpURLLoad("history.html"); | 5133 registerMockedHttpURLLoad("history.html"); |
5134 registerMockedHttpURLLoad("find.html"); | 5134 registerMockedHttpURLLoad("find.html"); |
5135 | 5135 |
5136 FrameTestHelpers::WebViewHelper webViewHelper; | 5136 FrameTestHelpers::WebViewHelper webViewHelper; |
5137 TestHistoryWebFrameClient client; | 5137 TestHistoryWebFrameClient client; |
5138 webViewHelper.initializeAndLoad("about:blank", true, &client); | 5138 webViewHelper.initializeAndLoad("about:blank", true, &client); |
| 5139 runPendingTasks(); |
5139 EXPECT_TRUE(client.replacesCurrentHistoryItem()); | 5140 EXPECT_TRUE(client.replacesCurrentHistoryItem()); |
5140 | 5141 |
5141 WebFrame* frame = webViewHelper.webView()->mainFrame(); | 5142 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
5142 | 5143 |
5143 FrameTestHelpers::loadFrame(frame, | 5144 FrameTestHelpers::loadFrame(frame, |
5144 "javascript:document.body.appendChild(document.createElement('iframe'))"
); | 5145 "javascript:document.body.appendChild(document.createElement('iframe'))"
); |
| 5146 // Need to call runPendingTasks in order for the JavaScript above to be |
| 5147 // evaluated and executed. |
| 5148 runPendingTasks(); |
5145 WebFrame* iframe = frame->firstChild(); | 5149 WebFrame* iframe = frame->firstChild(); |
5146 EXPECT_EQ(client.frame(), iframe); | 5150 EXPECT_EQ(client.frame(), iframe); |
5147 EXPECT_TRUE(client.replacesCurrentHistoryItem()); | 5151 EXPECT_TRUE(client.replacesCurrentHistoryItem()); |
5148 | 5152 |
5149 FrameTestHelpers::loadFrame(frame, | 5153 FrameTestHelpers::loadFrame(frame, |
5150 "javascript:window.frames[0].location.assign('" + m_baseURL + "history.h
tml')"); | 5154 "javascript:window.frames[0].location.assign('" + m_baseURL + "history.h
tml')"); |
| 5155 runPendingTasks(); |
| 5156 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
5151 EXPECT_EQ(client.frame(), iframe); | 5157 EXPECT_EQ(client.frame(), iframe); |
5152 EXPECT_TRUE(client.replacesCurrentHistoryItem()); | 5158 EXPECT_TRUE(client.replacesCurrentHistoryItem()); |
5153 | 5159 |
5154 FrameTestHelpers::loadFrame(frame, | 5160 FrameTestHelpers::loadFrame(frame, |
5155 "javascript:window.frames[0].location.assign('" + m_baseURL + "find.html
')"); | 5161 "javascript:window.frames[0].location.assign('" + m_baseURL + "find.html
')"); |
| 5162 runPendingTasks(); |
| 5163 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
5156 EXPECT_EQ(client.frame(), iframe); | 5164 EXPECT_EQ(client.frame(), iframe); |
5157 EXPECT_FALSE(client.replacesCurrentHistoryItem()); | 5165 EXPECT_FALSE(client.replacesCurrentHistoryItem()); |
5158 | 5166 |
5159 // Repeat the test, but start out the iframe with initial URL, which is not | 5167 // Repeat the test, but start out the iframe with initial URL, which is not |
5160 // "about:blank". | 5168 // "about:blank". |
5161 FrameTestHelpers::loadFrame(frame, | 5169 FrameTestHelpers::loadFrame(frame, |
5162 "javascript:var f = document.createElement('iframe'); " | 5170 "javascript:var f = document.createElement('iframe'); " |
5163 "f.src = '" + m_baseURL + "history.html';" | 5171 "f.src = '" + m_baseURL + "history.html';" |
5164 "document.body.appendChild(f)"); | 5172 "document.body.appendChild(f)"); |
| 5173 runPendingTasks(); |
| 5174 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
5165 | 5175 |
5166 iframe = frame->firstChild()->nextSibling(); | 5176 iframe = frame->firstChild()->nextSibling(); |
5167 EXPECT_EQ(client.frame(), iframe); | 5177 EXPECT_EQ(client.frame(), iframe); |
5168 EXPECT_TRUE(client.replacesCurrentHistoryItem()); | 5178 EXPECT_TRUE(client.replacesCurrentHistoryItem()); |
5169 | 5179 |
5170 FrameTestHelpers::loadFrame(frame, | 5180 FrameTestHelpers::loadFrame(frame, |
5171 "javascript:window.frames[1].location.assign('" + m_baseURL + "find.html
')"); | 5181 "javascript:window.frames[1].location.assign('" + m_baseURL + "find.html
')"); |
| 5182 runPendingTasks(); |
| 5183 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
5172 EXPECT_EQ(client.frame(), iframe); | 5184 EXPECT_EQ(client.frame(), iframe); |
5173 EXPECT_FALSE(client.replacesCurrentHistoryItem()); | 5185 EXPECT_FALSE(client.replacesCurrentHistoryItem()); |
5174 } | 5186 } |
5175 | 5187 |
5176 // Test verifies that layout will change a layer's scrollable attibutes | 5188 // Test verifies that layout will change a layer's scrollable attibutes |
5177 TEST_F(WebFrameTest, overflowHiddenRewrite) | 5189 TEST_F(WebFrameTest, overflowHiddenRewrite) |
5178 { | 5190 { |
5179 registerMockedHttpURLLoad("non-scrollable.html"); | 5191 registerMockedHttpURLLoad("non-scrollable.html"); |
5180 TestMainFrameUserOrProgrammaticScrollFrameClient client; | 5192 TestMainFrameUserOrProgrammaticScrollFrameClient client; |
5181 OwnPtr<FakeCompositingWebViewClient> fakeCompositingWebViewClient = adoptPtr
(new FakeCompositingWebViewClient()); | 5193 OwnPtr<FakeCompositingWebViewClient> fakeCompositingWebViewClient = adoptPtr
(new FakeCompositingWebViewClient()); |
5182 FrameTestHelpers::WebViewHelper webViewHelper; | 5194 FrameTestHelpers::WebViewHelper webViewHelper; |
5183 webViewHelper.initialize(true, 0, fakeCompositingWebViewClient.get(), &confi
gueCompositingWebView); | 5195 webViewHelper.initialize(true, 0, fakeCompositingWebViewClient.get(), &confi
gueCompositingWebView); |
5184 | 5196 |
5185 webViewHelper.webView()->resize(WebSize(100, 100)); | 5197 webViewHelper.webView()->resize(WebSize(100, 100)); |
5186 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "non-scrollable.html"); | 5198 FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL
+ "non-scrollable.html"); |
| 5199 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
| 5200 webViewHelper.webView()->layout(); |
5187 | 5201 |
5188 WebCore::RenderLayerCompositor* compositor = webViewHelper.webViewImpl()->c
ompositor(); | 5202 WebCore::RenderLayerCompositor* compositor = webViewHelper.webViewImpl()->c
ompositor(); |
5189 ASSERT_TRUE(compositor->scrollLayer()); | 5203 ASSERT_TRUE(compositor->scrollLayer()); |
5190 | 5204 |
5191 // Verify that the WebLayer is not scrollable initially. | 5205 // Verify that the WebLayer is not scrollable initially. |
5192 WebCore::GraphicsLayer* scrollLayer = compositor->scrollLayer(); | 5206 WebCore::GraphicsLayer* scrollLayer = compositor->scrollLayer(); |
5193 WebLayer* webScrollLayer = scrollLayer->platformLayer(); | 5207 WebLayer* webScrollLayer = scrollLayer->platformLayer(); |
5194 ASSERT_FALSE(webScrollLayer->userScrollableHorizontal()); | 5208 ASSERT_FALSE(webScrollLayer->userScrollableHorizontal()); |
5195 ASSERT_FALSE(webScrollLayer->userScrollableVertical()); | 5209 ASSERT_FALSE(webScrollLayer->userScrollableVertical()); |
5196 | 5210 |
5197 // Call javascript to make the layer scrollable, and verify it. | 5211 // Call javascript to make the layer scrollable, and verify it. |
5198 WebLocalFrameImpl* frame = (WebLocalFrameImpl*)webViewHelper.webView()->main
Frame(); | 5212 WebLocalFrameImpl* frame = (WebLocalFrameImpl*)webViewHelper.webView()->main
Frame(); |
5199 frame->executeScript(WebScriptSource("allowScroll();")); | 5213 frame->executeScript(WebScriptSource("allowScroll();")); |
5200 webViewHelper.webView()->layout(); | 5214 webViewHelper.webView()->layout(); |
5201 ASSERT_TRUE(webScrollLayer->userScrollableHorizontal()); | 5215 ASSERT_TRUE(webScrollLayer->userScrollableHorizontal()); |
5202 ASSERT_TRUE(webScrollLayer->userScrollableVertical()); | 5216 ASSERT_TRUE(webScrollLayer->userScrollableVertical()); |
5203 } | 5217 } |
5204 | 5218 |
5205 // Test that currentHistoryItem reflects the current page, not the provisional l
oad. | 5219 // Test that currentHistoryItem reflects the current page, not the provisional l
oad. |
5206 TEST_F(WebFrameTest, CurrentHistoryItem) | 5220 TEST_F(WebFrameTest, CurrentHistoryItem) |
5207 { | 5221 { |
5208 registerMockedHttpURLLoad("fixed_layout.html"); | 5222 registerMockedHttpURLLoad("fixed_layout.html"); |
5209 std::string url = m_baseURL + "fixed_layout.html"; | 5223 std::string url = m_baseURL + "fixed_layout.html"; |
5210 | 5224 |
5211 FrameTestHelpers::WebViewHelper webViewHelper; | 5225 FrameTestHelpers::WebViewHelper webViewHelper; |
5212 webViewHelper.initialize(); | 5226 webViewHelper.initialize(); |
5213 WebFrame* frame = webViewHelper.webView()->mainFrame(); | 5227 WebFrame* frame = webViewHelper.webView()->mainFrame(); |
5214 const WebCore::FrameLoader& mainFrameLoader = webViewHelper.webViewImpl()->m
ainFrameImpl()->frame()->loader(); | 5228 const WebCore::FrameLoader& mainFrameLoader = webViewHelper.webViewImpl()->m
ainFrameImpl()->frame()->loader(); |
5215 WebURLRequest request; | 5229 FrameTestHelpers::loadFrame(frame, url); |
5216 request.initialize(); | |
5217 request.setURL(toKURL(url)); | |
5218 frame->loadRequest(request); | |
5219 | 5230 |
5220 // Before commit, there is no history item. | 5231 // Before commit, there is no history item. |
5221 EXPECT_FALSE(mainFrameLoader.currentItem()); | 5232 EXPECT_FALSE(mainFrameLoader.currentItem()); |
5222 | 5233 |
5223 FrameTestHelpers::pumpPendingRequestsDoNotUse(frame); | 5234 Platform::current()->unitTestSupport()->serveAsynchronousMockedRequests(); |
5224 | 5235 |
5225 // After commit, there is. | 5236 // After commit, there is. |
5226 WebCore::HistoryItem* item = mainFrameLoader.currentItem(); | 5237 WebCore::HistoryItem* item = mainFrameLoader.currentItem(); |
5227 ASSERT_TRUE(item); | 5238 ASSERT_TRUE(item); |
5228 EXPECT_EQ(WTF::String(url.data()), item->urlString()); | 5239 EXPECT_EQ(WTF::String(url.data()), item->urlString()); |
5229 } | 5240 } |
5230 | 5241 |
5231 class FailCreateChildFrame : public FrameTestHelpers::TestWebFrameClient { | 5242 class FailCreateChildFrame : public WebFrameClient { |
5232 public: | 5243 public: |
5233 FailCreateChildFrame() : m_callCount(0) { } | 5244 FailCreateChildFrame() : m_callCount(0) { } |
5234 | 5245 |
5235 virtual WebFrame* createChildFrame(WebLocalFrame* parent, const WebString& f
rameName) OVERRIDE | 5246 virtual WebFrame* createChildFrame(WebLocalFrame* parent, const WebString& f
rameName) OVERRIDE |
5236 { | 5247 { |
5237 ++m_callCount; | 5248 ++m_callCount; |
5238 return 0; | 5249 return 0; |
5239 } | 5250 } |
5240 | 5251 |
| 5252 virtual void frameDetached(WebFrame* frame) OVERRIDE |
| 5253 { |
| 5254 frame->close(); |
| 5255 } |
| 5256 |
5241 int callCount() const { return m_callCount; } | 5257 int callCount() const { return m_callCount; } |
5242 | 5258 |
5243 private: | 5259 private: |
5244 int m_callCount; | 5260 int m_callCount; |
5245 }; | 5261 }; |
5246 | 5262 |
5247 // Test that we don't crash if WebFrameClient::createChildFrame() fails. | 5263 // Test that we don't crash if WebFrameClient::createChildFrame() fails. |
5248 TEST_F(WebFrameTest, CreateChildFrameFailure) | 5264 TEST_F(WebFrameTest, CreateChildFrameFailure) |
5249 { | 5265 { |
5250 registerMockedHttpURLLoad("create_child_frame_fail.html"); | 5266 registerMockedHttpURLLoad("create_child_frame_fail.html"); |
(...skipping 155 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
5406 registerMockedHttpURLLoad("link-manifest-change.html"); | 5422 registerMockedHttpURLLoad("link-manifest-change.html"); |
5407 | 5423 |
5408 ManifestChangeWebFrameClient webFrameClient; | 5424 ManifestChangeWebFrameClient webFrameClient; |
5409 FrameTestHelpers::WebViewHelper webViewHelper; | 5425 FrameTestHelpers::WebViewHelper webViewHelper; |
5410 webViewHelper.initializeAndLoad(m_baseURL + "link-manifest-change.html", tru
e, &webFrameClient); | 5426 webViewHelper.initializeAndLoad(m_baseURL + "link-manifest-change.html", tru
e, &webFrameClient); |
5411 | 5427 |
5412 EXPECT_EQ(14, webFrameClient.manifestChangeCount()); | 5428 EXPECT_EQ(14, webFrameClient.manifestChangeCount()); |
5413 } | 5429 } |
5414 | 5430 |
5415 } // namespace | 5431 } // namespace |
OLD | NEW |