Index: LayoutTests/fast/multicol/vertical-rl/caret-range-outside-columns.html |
diff --git a/LayoutTests/fast/multicol/vertical-rl/caret-range-outside-columns.html b/LayoutTests/fast/multicol/vertical-rl/caret-range-outside-columns.html |
new file mode 100644 |
index 0000000000000000000000000000000000000000..def88206493f5f12171549b721dc9886823ed46c |
--- /dev/null |
+++ b/LayoutTests/fast/multicol/vertical-rl/caret-range-outside-columns.html |
@@ -0,0 +1,77 @@ |
+<!DOCTYPE html> |
+<style> |
+ body { |
+ margin:0; |
+ } |
+ |
+ /* Need a wrapper to establish the writing mode, thanks to crbug.com/463462 */ |
+ #wrapper { |
+ -webkit-writing-mode: vertical-rl; |
+ padding: 20px 100px; |
+ width: 400px; |
+ height: 350px; |
+ background: green; |
+ } |
+ |
+ #mc { |
+ -webkit-columns: 3; |
+ -webkit-column-gap: 20px; |
+ height: 280px; |
+ font: 20px/1 Ahem; |
+ } |
+ |
+ #log { |
+ position: absolute; |
+ top: 400px; |
+ } |
+</style> |
+<div id="log"> |
+ <p id="description"></p> |
+ <div id="console"></div> |
+</div> |
+<div id="wrapper"> |
+ <div id="mc">xxx xxx xxx xxx xxx xxx xxx xxx xxx</div> |
+</div> |
+<script src="../../../resources/js-test.js"></script> |
+<script> |
+ description("Test that hitting areas outside columns takes us to the right text content inside columns."); |
+ |
+ // Note that this test is very limited (compared to the other caret-range- tests), |
+ // due to platform behavioral differences, and crbug.com/466974 |
+ |
+ debug("To the right of the first column:"); |
+ shouldBe("document.caretRangeFromPoint(550,10).startOffset", "0"); |
+ shouldBe("document.caretRangeFromPoint(550,70).startOffset", "0"); |
+ shouldBe("document.caretRangeFromPoint(550,109).startOffset", "0"); |
+ |
+ debug("Above first column:"); |
+ shouldBe("document.caretRangeFromPoint(550,0).startOffset", "0"); |
+ shouldBe("document.caretRangeFromPoint(490,0).startOffset", "0"); |
+ shouldBe("document.caretRangeFromPoint(470,0).startOffset", "4"); |
+ shouldBe("document.caretRangeFromPoint(450,0).startOffset", "8"); |
+ |
+ debug("Below third column:"); |
+ shouldBe("document.caretRangeFromPoint(490,350).startOffset", "27"); |
+ shouldBe("document.caretRangeFromPoint(470,350).startOffset", "31"); |
+ shouldBe("document.caretRangeFromPoint(450,350).startOffset", "35"); |
+ |
+ debug("In the gap between the first and second columns:"); |
+ shouldBe("document.caretRangeFromPoint(499,109).startOffset", "3"); |
+ shouldBe("document.caretRangeFromPoint(479,109).startOffset", "7"); |
+ shouldBe("document.caretRangeFromPoint(459,109).startOffset", "11"); |
+ shouldBe("document.caretRangeFromPoint(440,109).startOffset", "11"); |
+ shouldBe("document.caretRangeFromPoint(499,110).startOffset", "12"); |
+ shouldBe("document.caretRangeFromPoint(479,110).startOffset", "16"); |
+ shouldBe("document.caretRangeFromPoint(459,110).startOffset", "20"); |
+ shouldBe("document.caretRangeFromPoint(440,110).startOffset", "20"); |
+ |
+ debug("In the gap between the second and third columns:"); |
+ shouldBe("document.caretRangeFromPoint(499,209).startOffset", "15"); |
+ shouldBe("document.caretRangeFromPoint(479,209).startOffset", "19"); |
+ shouldBe("document.caretRangeFromPoint(459,209).startOffset", "23"); |
+ shouldBe("document.caretRangeFromPoint(440,209).startOffset", "23"); |
+ shouldBe("document.caretRangeFromPoint(499,210).startOffset", "24"); |
+ shouldBe("document.caretRangeFromPoint(479,210).startOffset", "28"); |
+ shouldBe("document.caretRangeFromPoint(459,210).startOffset", "32"); |
+ shouldBe("document.caretRangeFromPoint(440,210).startOffset", "32"); |
+</script> |