summaryrefslogtreecommitdiffstats
path: root/webkit/glue
diff options
context:
space:
mode:
authorjnd@chromium.org <jnd@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-05-12 19:25:46 +0000
committerjnd@chromium.org <jnd@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-05-12 19:25:46 +0000
commit01804b55e214f78aec2618b811a5ffa7079104dd (patch)
tree15d1a68a3c81f7fd009b66cfc7916833f3bfc2cd /webkit/glue
parent565359937e9e467592590e1d8cd37c9407a7e2c9 (diff)
downloadchromium_src-01804b55e214f78aec2618b811a5ffa7079104dd.zip
chromium_src-01804b55e214f78aec2618b811a5ffa7079104dd.tar.gz
chromium_src-01804b55e214f78aec2618b811a5ffa7079104dd.tar.bz2
Fix DomSerializerTests disabled for WebKit merge 43114:43242
The bug is because WebCore now always inserts a HEAD element to a HTML DOM. BUG=11478. Review URL: http://codereview.chromium.org/115251 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@15886 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/glue')
-rw-r--r--webkit/glue/dom_serializer.cc10
-rw-r--r--webkit/glue/dom_serializer.h3
-rw-r--r--webkit/glue/dom_serializer_unittest.cc104
3 files changed, 80 insertions, 37 deletions
diff --git a/webkit/glue/dom_serializer.cc b/webkit/glue/dom_serializer.cc
index dedf92b..631c210 100644
--- a/webkit/glue/dom_serializer.cc
+++ b/webkit/glue/dom_serializer.cc
@@ -163,6 +163,12 @@ DomSerializer::SerializeDomParam::SerializeDomParam(
is_html_document = doc->isHTMLDocument();
}
+// Static
+std::wstring DomSerializer::GenerateMetaCharsetDeclaration(
+ const std::wstring& charset) {
+ return StringPrintf(kDefaultMetaContent, charset.c_str());
+}
+
// Static.
std::string DomSerializer::GenerateMarkOfTheWebDeclaration(
const GURL& url) {
@@ -265,8 +271,8 @@ WebCore::String DomSerializer::PostActionAfterSerializeOpenTag(
// See http://bugs.webkit.org/show_bug.cgi?id=16621.
// First we generate new content for writing correct META element.
std::wstring str_meta =
- StringPrintf(kDefaultMetaContent,
- ASCIIToWide(param->text_encoding.name()).c_str());
+ GenerateMetaCharsetDeclaration(
+ ASCIIToWide(param->text_encoding.name()));
result += StdWStringToString(str_meta);
param->has_added_contents_before_end = true;
diff --git a/webkit/glue/dom_serializer.h b/webkit/glue/dom_serializer.h
index 62b6702..fc6d0ef 100644
--- a/webkit/glue/dom_serializer.h
+++ b/webkit/glue/dom_serializer.h
@@ -57,6 +57,9 @@ class DomSerializer {
const std::vector<FilePath>& local_paths,
const FilePath& local_directory_name);
+ // Generate the META for charset declaration.
+ static std::wstring GenerateMetaCharsetDeclaration(
+ const std::wstring& charset);
// Generate the MOTW declaration.
static std::string GenerateMarkOfTheWebDeclaration(const GURL& url);
// Generate the default base tag declaration.
diff --git a/webkit/glue/dom_serializer_unittest.cc b/webkit/glue/dom_serializer_unittest.cc
index 76a576e..66200f8 100644
--- a/webkit/glue/dom_serializer_unittest.cc
+++ b/webkit/glue/dom_serializer_unittest.cc
@@ -308,8 +308,8 @@ TEST_F(DomSerializerTests, SerialzeXMLDocWithBuiltInEntities) {
page_file_path = page_file_path.AppendASCII("dom_serializer");
page_file_path = page_file_path.AppendASCII("note.xml");
// Read original contents for later comparison.
- std::string orginal_contents;
- ASSERT_TRUE(file_util::ReadFileToString(page_file_path, &orginal_contents));
+ std::string original_contents;
+ ASSERT_TRUE(file_util::ReadFileToString(page_file_path, &original_contents));
// Get file URL.
GURL file_url = net::FilePathToFileURL(page_file_path);
ASSERT_TRUE(file_url.SchemeIsFile());
@@ -321,7 +321,7 @@ TEST_F(DomSerializerTests, SerialzeXMLDocWithBuiltInEntities) {
ASSERT_TRUE(HasSerializedFrame(file_url));
const std::string& serialized_contents =
GetSerializedContentForFrame(file_url);
- ASSERT_EQ(orginal_contents, serialized_contents);
+ ASSERT_EQ(original_contents, serialized_contents);
}
// When serializing DOM, we add MOTW declaration before html tag.
@@ -330,8 +330,8 @@ TEST_F(DomSerializerTests, SerialzeHTMLDOMWithAddingMOTW) {
page_file_path = page_file_path.AppendASCII("dom_serializer");
page_file_path = page_file_path.AppendASCII("youtube_2.htm");
// Read original contents for later comparison .
- std::string orginal_contents;
- ASSERT_TRUE(file_util::ReadFileToString(page_file_path, &orginal_contents));
+ std::string original_contents;
+ ASSERT_TRUE(file_util::ReadFileToString(page_file_path, &original_contents));
// Get file URL.
GURL file_url = net::FilePathToFileURL(page_file_path);
ASSERT_TRUE(file_url.SchemeIsFile());
@@ -342,7 +342,7 @@ TEST_F(DomSerializerTests, SerialzeHTMLDOMWithAddingMOTW) {
// The encoding of original contents is ISO-8859-1, so we convert the MOTW
// declaration to ASCII and search whether original contents has it or not.
ASSERT_TRUE(std::string::npos ==
- orginal_contents.find(motw_declaration));
+ original_contents.find(motw_declaration));
// Load the test file.
LoadPageFromURL(file_url);
// Do serialization.
@@ -486,18 +486,20 @@ TEST_F(DomSerializerTests,
}
// Test situation of html entities in text when serializing HTML DOM.
-TEST_F(DomSerializerTests, DISABLED_SerialzeHTMLDOMWithEntitiesInText) {
+TEST_F(DomSerializerTests, SerialzeHTMLDOMWithEntitiesInText) {
FilePath page_file_path = data_dir_;
- page_file_path = page_file_path.AppendASCII("dom_serializer");
- page_file_path = page_file_path.AppendASCII("htmlentities_in_text.htm");
- // Read original contents for later comparison .
- std::string orginal_contents;
- ASSERT_TRUE(file_util::ReadFileToString(page_file_path, &orginal_contents));
- // Get file URL.
+ page_file_path = page_file_path.AppendASCII(
+ "dom_serializer/htmlentities_in_text.htm");
+ // Get file URL. The URL is dummy URL to identify the following loading
+ // actions. The test content is in constant:original_contents.
GURL file_url = net::FilePathToFileURL(page_file_path);
ASSERT_TRUE(file_url.SchemeIsFile());
- // Load the test file.
- LoadPageFromURL(file_url);
+ // Test contents.
+ static const char* const original_contents =
+ "<HTML><BODY>&amp;&lt;&gt;\"\'</BODY></HTML>";
+ // Load the test contents.
+ LoadContents(original_contents, file_url, "");
+
// Get BODY's text content in DOM.
WebFrameImpl* web_frame =
webkit_glue::GetWebFrameImplFromWebViewForSpecificURL(
@@ -516,29 +518,48 @@ TEST_F(DomSerializerTests, DISABLED_SerialzeHTMLDOMWithEntitiesInText) {
ASSERT_TRUE(HasSerializedFrame(file_url));
const std::string& serialized_contents =
GetSerializedContentForFrame(file_url);
+ // Compare the serialized contents with original contents to make sure
+ // they are same.
// Because we add MOTW when serializing DOM, so before comparison, we also
// need to add MOTW to original_contents.
- std::string motw_declaration =
- webkit_glue::DomSerializer::GenerateMarkOfTheWebDeclaration(file_url);
- orginal_contents = motw_declaration + orginal_contents;
- ASSERT_EQ(orginal_contents, serialized_contents);
+ std::string original_str =
+ webkit_glue::DomSerializer::GenerateMarkOfTheWebDeclaration(file_url);
+ original_str += original_contents;
+ // Since WebCore now inserts a new HEAD element if there is no HEAD element
+ // when creating BODY element. (Please see HTMLParser::bodyCreateErrorCheck.)
+ // We need to append the HEAD content and corresponding META content if we
+ // find WebCore-generated HEAD element.
+ if (doc->head()) {
+ WebCore::String encoding = web_frame->frame()->loader()->encoding();
+ std::string htmlTag("<HTML>");
+ std::string::size_type pos = original_str.find(htmlTag);
+ ASSERT_NE(std::string::npos, pos);
+ pos += htmlTag.length();
+ std::string head_part("<HEAD>");
+ head_part += WideToASCII(
+ webkit_glue::DomSerializer::GenerateMetaCharsetDeclaration(
+ webkit_glue::StringToStdWString(encoding)));
+ head_part += "</HEAD>";
+ original_str.insert(pos, head_part);
+ }
+ ASSERT_EQ(original_str, serialized_contents);
}
// Test situation of html entities in attribute value when serializing
// HTML DOM.
-TEST_F(DomSerializerTests, DISABLED_SerialzeHTMLDOMWithEntitiesInAttributeValue) {
+TEST_F(DomSerializerTests, SerialzeHTMLDOMWithEntitiesInAttributeValue) {
FilePath page_file_path = data_dir_;
- page_file_path = page_file_path.AppendASCII("dom_serializer");
- page_file_path =
- page_file_path.AppendASCII("htmlentities_in_attribute_value.htm");
- // Read original contents for later comparison.
- std::string orginal_contents;
- ASSERT_TRUE(file_util::ReadFileToString(page_file_path, &orginal_contents));
- // Get file URL.
+ page_file_path = page_file_path.AppendASCII(
+ "dom_serializer/htmlentities_in_attribute_value.htm");
+ // Get file URL. The URL is dummy URL to identify the following loading
+ // actions. The test content is in constant:original_contents.
GURL file_url = net::FilePathToFileURL(page_file_path);
ASSERT_TRUE(file_url.SchemeIsFile());
- // Load the test file.
- LoadPageFromURL(file_url);
+ // Test contents.
+ static const char* const original_contents =
+ "<HTML><BODY title=\"&amp;&lt;&gt;&quot;&#39;\"></BODY></HTML>";
+ // Load the test contents.
+ LoadContents(original_contents, file_url, "");
// Get value of BODY's title attribute in DOM.
WebFrameImpl* web_frame =
webkit_glue::GetWebFrameImplFromWebViewForSpecificURL(
@@ -557,12 +578,25 @@ TEST_F(DomSerializerTests, DISABLED_SerialzeHTMLDOMWithEntitiesInAttributeValue)
ASSERT_TRUE(HasSerializedFrame(file_url));
const std::string& serialized_contents =
GetSerializedContentForFrame(file_url);
- // Because we add MOTW when serializing DOM, so before comparison, we also
- // need to add MOTW to original_contents.
- std::string motw_declaration =
- webkit_glue::DomSerializer::GenerateMarkOfTheWebDeclaration(file_url);
- orginal_contents = motw_declaration + orginal_contents;
- ASSERT_EQ(serialized_contents, orginal_contents);
+ // Compare the serialized contents with original contents to make sure
+ // they are same.
+ std::string original_str =
+ webkit_glue::DomSerializer::GenerateMarkOfTheWebDeclaration(file_url);
+ original_str += original_contents;
+ if (doc->head()) {
+ WebCore::String encoding = web_frame->frame()->loader()->encoding();
+ std::string htmlTag("<HTML>");
+ std::string::size_type pos = original_str.find(htmlTag);
+ ASSERT_NE(std::string::npos, pos);
+ pos += htmlTag.length();
+ std::string head_part("<HEAD>");
+ head_part += WideToASCII(
+ webkit_glue::DomSerializer::GenerateMetaCharsetDeclaration(
+ webkit_glue::StringToStdWString(encoding)));
+ head_part += "</HEAD>";
+ original_str.insert(pos, head_part);
+ }
+ ASSERT_EQ(original_str, serialized_contents);
}
// Test situation of non-standard HTML entities when serializing HTML DOM.