| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "components/test_runner/layout_dump.h" | 5 #include "components/test_runner/layout_dump.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/strings/stringprintf.h" | 8 #include "base/strings/stringprintf.h" |
| 9 #include "third_party/WebKit/public/platform/WebSize.h" | 9 #include "third_party/WebKit/public/platform/WebSize.h" |
| 10 #include "third_party/WebKit/public/platform/WebString.h" | 10 #include "third_party/WebKit/public/platform/WebString.h" |
| 11 #include "third_party/WebKit/public/web/WebDocument.h" | 11 #include "third_party/WebKit/public/web/WebDocument.h" |
| 12 #include "third_party/WebKit/public/web/WebElement.h" | 12 #include "third_party/WebKit/public/web/WebElement.h" |
| 13 #include "third_party/WebKit/public/web/WebFrame.h" | 13 #include "third_party/WebKit/public/web/WebFrame.h" |
| 14 #include "third_party/WebKit/public/web/WebFrameContentDumper.h" |
| 14 #include "third_party/WebKit/public/web/WebLocalFrame.h" | 15 #include "third_party/WebKit/public/web/WebLocalFrame.h" |
| 15 | 16 |
| 16 namespace test_runner { | 17 namespace test_runner { |
| 17 | 18 |
| 18 using blink::WebFrame; | 19 using blink::WebFrame; |
| 20 using blink::WebFrameContentDumper; |
| 19 using blink::WebLocalFrame; | 21 using blink::WebLocalFrame; |
| 20 using blink::WebSize; | 22 using blink::WebSize; |
| 21 | 23 |
| 22 namespace { | 24 namespace { |
| 23 | 25 |
| 24 std::string DumpFrameHeaderIfNeeded(WebFrame* frame) { | 26 std::string DumpFrameHeaderIfNeeded(WebFrame* frame) { |
| 25 std::string result; | 27 std::string result; |
| 26 | 28 |
| 27 // Add header for all but the main frame. Skip empty frames. | 29 // Add header for all but the main frame. Skip empty frames. |
| 28 if (frame->parent() && !frame->document().documentElement().isNull()) { | 30 if (frame->parent() && !frame->document().documentElement().isNull()) { |
| (...skipping 23 matching lines...) Expand all Loading... |
| 52 } // namespace | 54 } // namespace |
| 53 | 55 |
| 54 std::string DumpLayout(WebLocalFrame* frame, const LayoutDumpFlags& flags) { | 56 std::string DumpLayout(WebLocalFrame* frame, const LayoutDumpFlags& flags) { |
| 55 DCHECK(frame); | 57 DCHECK(frame); |
| 56 std::string result; | 58 std::string result; |
| 57 | 59 |
| 58 switch (flags.main_dump_mode) { | 60 switch (flags.main_dump_mode) { |
| 59 case LayoutDumpMode::DUMP_AS_TEXT: | 61 case LayoutDumpMode::DUMP_AS_TEXT: |
| 60 result = DumpFrameHeaderIfNeeded(frame); | 62 result = DumpFrameHeaderIfNeeded(frame); |
| 61 if (flags.dump_as_printed && frame->document().isHTMLDocument()) { | 63 if (flags.dump_as_printed && frame->document().isHTMLDocument()) { |
| 62 result += | 64 result += WebFrameContentDumper::dumpLayoutTreeAsText( |
| 63 frame->layoutTreeAsText(WebFrame::LayoutAsTextPrinting).utf8(); | 65 frame, WebFrameContentDumper::LayoutAsTextPrinting) |
| 66 .utf8(); |
| 64 } else { | 67 } else { |
| 65 result += frame->document().contentAsTextForTesting().utf8(); | 68 result += frame->document().contentAsTextForTesting().utf8(); |
| 66 } | 69 } |
| 67 result += "\n"; | 70 result += "\n"; |
| 68 break; | 71 break; |
| 69 case LayoutDumpMode::DUMP_AS_MARKUP: | 72 case LayoutDumpMode::DUMP_AS_MARKUP: |
| 70 DCHECK(!flags.dump_as_printed); | 73 DCHECK(!flags.dump_as_printed); |
| 71 result = DumpFrameHeaderIfNeeded(frame); | 74 result = DumpFrameHeaderIfNeeded(frame); |
| 72 result += frame->contentAsMarkup().utf8(); | 75 result += WebFrameContentDumper::dumpAsMarkup(frame).utf8(); |
| 73 result += "\n"; | 76 result += "\n"; |
| 74 break; | 77 break; |
| 75 case LayoutDumpMode::DUMP_SCROLL_POSITIONS: | 78 case LayoutDumpMode::DUMP_SCROLL_POSITIONS: |
| 76 if (frame->parent() == nullptr) { | 79 if (frame->parent() == nullptr) { |
| 77 WebFrame::LayoutAsTextControls layout_text_behavior = | 80 WebFrameContentDumper::LayoutAsTextControls layout_text_behavior = |
| 78 WebFrame::LayoutAsTextNormal; | 81 WebFrameContentDumper::LayoutAsTextNormal; |
| 79 if (flags.dump_as_printed) | 82 if (flags.dump_as_printed) |
| 80 layout_text_behavior |= WebFrame::LayoutAsTextPrinting; | 83 layout_text_behavior |= WebFrameContentDumper::LayoutAsTextPrinting; |
| 81 if (flags.debug_render_tree) | 84 if (flags.debug_render_tree) |
| 82 layout_text_behavior |= WebFrame::LayoutAsTextDebug; | 85 layout_text_behavior |= WebFrameContentDumper::LayoutAsTextDebug; |
| 83 if (flags.dump_line_box_trees) | 86 if (flags.dump_line_box_trees) |
| 84 layout_text_behavior |= WebFrame::LayoutAsTextWithLineTrees; | 87 layout_text_behavior |= |
| 85 result = frame->layoutTreeAsText(layout_text_behavior).utf8(); | 88 WebFrameContentDumper::LayoutAsTextWithLineTrees; |
| 89 result = WebFrameContentDumper::dumpLayoutTreeAsText( |
| 90 frame, layout_text_behavior) |
| 91 .utf8(); |
| 86 } | 92 } |
| 87 result += DumpFrameScrollPosition(frame); | 93 result += DumpFrameScrollPosition(frame); |
| 88 break; | 94 break; |
| 89 default: | 95 default: |
| 90 DCHECK(false) << static_cast<int>(flags.main_dump_mode); | 96 DCHECK(false) << static_cast<int>(flags.main_dump_mode); |
| 91 result = ""; | 97 result = ""; |
| 92 break; | 98 break; |
| 93 } | 99 } |
| 94 | 100 |
| 95 return result; | 101 return result; |
| 96 } | 102 } |
| 97 | 103 |
| 98 } // namespace test_runner | 104 } // namespace test_runner |
| OLD | NEW |