// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "base/string_util.h" #include "base/utf_string_conversions.h" #include "testing/gtest/include/gtest/gtest.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebData.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebFrame.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebString.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebURL.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebView.h" #include "webkit/tools/test_shell/test_shell_test.h" using WebKit::WebFrame; using WebKit::WebString; using WebKit::WebView; class WebFrameTest : public TestShellTest { }; TEST_F(WebFrameTest, GetContentAsPlainText) { WebView* view = test_shell_->webView(); WebFrame* frame = view->mainFrame(); // Generate a simple test case. const char simple_source[] = "<div>Foo bar</div><div></div>baz"; GURL test_url("http://foo/"); frame->loadHTMLString(simple_source, test_url); test_shell_->WaitTestFinished(); // Make sure it comes out OK. const string16 expected(ASCIIToUTF16("Foo bar\nbaz")); string16 text = frame->contentAsText(std::numeric_limits<size_t>::max()); EXPECT_EQ(expected, text); // Try reading the same one with clipping of the text. const int len = 5; text = frame->contentAsText(len); EXPECT_EQ(expected.substr(0, len), text); // Now do a new test with a subframe. const char outer_frame_source[] = "Hello<iframe></iframe> world"; frame->loadHTMLString(outer_frame_source, test_url); test_shell_->WaitTestFinished(); // Load something into the subframe. WebFrame* subframe = frame->findChildByExpression( WebString::fromUTF8("/html/body/iframe")); ASSERT_TRUE(subframe); subframe->loadHTMLString("sub<p>text", test_url); test_shell_->WaitTestFinished(); text = frame->contentAsText(std::numeric_limits<size_t>::max()); EXPECT_EQ("Hello world\n\nsub\ntext", UTF16ToUTF8(text)); // Get the frame text where the subframe separator falls on the boundary of // what we'll take. There used to be a crash in this case. text = frame->contentAsText(12); EXPECT_EQ("Hello world", UTF16ToUTF8(text)); } TEST_F(WebFrameTest, GetFullHtmlOfPage) { WebView* view = test_shell_->webView(); WebFrame* frame = view->mainFrame(); // Generate a simple test case. const char simple_source[] = "<p>Hello</p><p>World</p>"; GURL test_url("http://hello/"); frame->loadHTMLString(simple_source, test_url); test_shell_->WaitTestFinished(); string16 text = frame->contentAsText(std::numeric_limits<size_t>::max()); EXPECT_EQ("Hello\n\nWorld", UTF16ToUTF8(text)); const std::string html = frame->contentAsMarkup().utf8(); // Load again with the output html. frame->loadHTMLString(html, test_url); test_shell_->WaitTestFinished(); EXPECT_EQ(html, UTF16ToUTF8(frame->contentAsMarkup())); text = frame->contentAsText(std::numeric_limits<size_t>::max()); EXPECT_EQ("Hello\n\nWorld", UTF16ToUTF8(text)); // Test selection check EXPECT_FALSE(frame->hasSelection()); frame->executeCommand(WebString::fromUTF8("SelectAll")); EXPECT_TRUE(frame->hasSelection()); frame->executeCommand(WebString::fromUTF8("Unselect")); EXPECT_FALSE(frame->hasSelection()); WebString selection_html = frame->selectionAsMarkup(); EXPECT_TRUE(selection_html.isEmpty()); }