diff options
| author | toasted-nutbread <toasted-nutbread@users.noreply.github.com> | 2020-05-02 13:05:43 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-05-02 13:05:43 -0400 | 
| commit | d4ae9aa501ece99ea6c5e6b8fb01c3005f5b7f03 (patch) | |
| tree | f96211038ffac0be88da912cb40bd3980c212c18 /test/data | |
| parent | d581bffa15419b3b55773f1ed08a2e787e574f1f (diff) | |
DOMTextScanner (#458)
* Create new class for scanning text in a document
* Update test styles
* Add tests
Diffstat (limited to 'test/data')
| -rw-r--r-- | test/data/html/test-dom-text-scanner.html | 393 | ||||
| -rw-r--r-- | test/data/html/test-stylesheet.css | 12 | 
2 files changed, 402 insertions, 3 deletions
| diff --git a/test/data/html/test-dom-text-scanner.html b/test/data/html/test-dom-text-scanner.html new file mode 100644 index 00000000..6b78570a --- /dev/null +++ b/test/data/html/test-dom-text-scanner.html @@ -0,0 +1,393 @@ +<!DOCTYPE html> +<html> +    <head> +        <meta charset="UTF-8"> +        <meta name="viewport" content="width=device-width,initial-scale=1" /> +        <title>Yomichan DOMTextScanner Tests</title> +        <link rel="icon" type="image/gif" href="data:image/gif;base64,R0lGODlhEAAQAKEBAAAAAP///////////yH5BAEKAAIALAAAAAAQABAAAAImFI6Zpt0B4YkS0TCpq07xbmEgcGVRUpLaI46ZG7ppalY0jDCwUAAAOw==" /> +        <link rel="stylesheet" href="test-stylesheet.css" /> +    </head> +<body> + +    <h1>Yomichan DOMTextScanner Tests</h1> + +    <y-test +        data-test-data='{ +            "node": "div:nth-of-type(1)", +            "offset": 0, +            "length": 15, +            "expected": { +                "node": "div:nth-of-type(2)>div::text", +                "offset": 3, +                "content": "小ぢん\nまり1\n小ぢん\nまり2" +            } +        }' +    > +        <y-description>Layout newlines expected due to entering and exiting display:block nodes.</y-description> +<div><div>小ぢん</div>まり1</div> +<div>小ぢん<div>まり2</div></div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div:nth-of-type(1)::text", +            "offset": 0, +            "length": 13, +            "expected": { +                "node": "div:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1\n小ぢんまり2" +            } +        }' +    > +        <y-description>Layout newline expected due to sequential display:block elements.</y-description> +<div>小ぢんまり1</div><div>小ぢんまり2</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div:nth-of-type(1)::text", +            "offset": 0, +            "length": 13, +            "expected": { +                "node": "div:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1\n小ぢんまり2" +            } +        }' +    > +        <y-description>Layout newline expected due to sequential display:block elements separated by a newline.</y-description> +<div>小ぢんまり1</div> +<div>小ぢんまり2</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "span:nth-of-type(1)::text", +            "offset": 0, +            "length": 12, +            "expected": { +                "node": "span:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1小ぢんまり2" +            } +        }' +    > +        <y-description>No newlines expected due to display:inline.</y-description> +<span>小ぢんまり1</span><span>小ぢんまり2</span> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "span:nth-of-type(1)::text", +            "offset": 0, +            "length": 13, +            "expected": { +                "node": "span:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1\n小ぢんまり2" +            } +        }' +    > +        <y-description>No newlines expected due to white-space:normal.</y-description> +<span>小ぢんまり1</span> +<span>小ぢんまり2</span> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "span:nth-of-type(1)::text", +            "offset": 0, +            "length": 13, +            "expected": { +                "node": "span:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1\n小ぢんまり2" +            } +        }' +    > +        <y-description>Newline expected due to white-space:pre.</y-description> +<pre> +<span>小ぢんまり1</span> +<span>小ぢんまり2</span> +</pre> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "span:nth-of-type(1)::text", +            "offset": 0, +            "length": 12, +            "expected": { +                "node": "span:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1小ぢんまり2" +            } +        }' +    > +        <y-description>No newlines expected due to display:inline-block. Actual layout flow cannot be determined by DOM/CSS alone.</y-description> +<span style="display: inline-block;">小ぢんまり1</span><span style="display: inline-block;">小ぢんまり2</span> +    </y-test> + +    <y-test +        style="position: relative;" +        data-test-data='{ +            "node": "div:nth-of-type(1)::text", +            "offset": 0, +            "length": 13, +            "expected": { +                "node": "div:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1\n小ぢんまり2" +            } +        }' +    > +        <y-description>Single newline expected due to display:block layout.</y-description> +<div>小ぢんまり1</div><div style="position: relative;">小ぢんまり2</div> +    </y-test> + +    <y-test +        style="position: relative; overflow: hidden;" +        data-test-data='{ +            "node": "div:nth-of-type(1)::text", +            "offset": 0, +            "length": 14, +            "expected": { +                "node": "div:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1\n\n小ぢんまり2" +            } +        }' +    > +        <y-description>Two newlines expected due to position:absolute causing a significant layout change.</y-description> +<div>小ぢんまり1</div><div style="position: absolute;">小ぢんまり2</div> +    </y-test> + +    <y-test +        style="position: relative; overflow: hidden;" +        data-test-data='{ +            "node": "div:nth-of-type(1)::text", +            "offset": 0, +            "length": 14, +            "expected": { +                "node": "div:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1\n\n小ぢんまり2" +            } +        }' +    > +        <y-description>Two newlines expected due to position:fixed causing a significant layout change.</y-description> +<div>小ぢんまり1</div><div style="position: fixed;">小ぢんまり2</div> +    </y-test> + +    <y-test +        style="position: relative;" +        data-test-data='{ +            "node": "div:nth-of-type(1)::text", +            "offset": 0, +            "length": 14, +            "expected": { +                "node": "div:nth-of-type(2)::text", +                "offset": 6, +                "content": "小ぢんまり1\n\n小ぢんまり2" +            } +        }' +    > +        <y-description>Two newlines expected due to position:sticky being able to cause a significant layout change.</y-description> +<div>小ぢんまり1</div><div style="position: sticky;">小ぢんまり2</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "rt", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::text", +                "offset": 5, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Scanning text starting in an <rt> element. Should start scanning at the start of the <ruby> tag instead.</y-description> +<div><ruby>小<rp>(</rp><rt>こ</rt><rp>)</rp></ruby>ぢんまり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip <script> content.</y-description> +<div>小ぢん<script>/*comment*/</script>まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip <style> content.</y-description> +<div>小ぢん<style>/*comment*/</style>まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip <textarea> content.</y-description> +<div>小ぢん<textarea>textarea content</textarea>まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip <input> content.</y-description> +<div>小ぢん<input value="content" />まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip <button> content.</y-description> +<div>小ぢん<button>content</button>まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip content with font-size:0.</y-description> +<div>小ぢん<span style="font-size: 0;">content</span>まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip content with opacity:0.</y-description> +<div>小ぢん<span style="opacity: 0;">content</span>まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip content with visibility:hidden.</y-description> +<div>小ぢん<span style="visibility: hidden;">content</span>まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip content with display:none.</y-description> +<div>小ぢん<span style="display: none;">content</span>まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Don't skip content with user-select:none.</y-description> +<div>小ぢ<span style="user-select: none;">ん</span>まり1</div> +    </y-test> + +    <y-test +        data-test-data='{ +            "node": "div", +            "offset": 0, +            "length": 6, +            "expected": { +                "node": "div::nth-text(2)", +                "offset": 3, +                "content": "小ぢんまり1" +            } +        }' +    > +        <y-description>Skip content with user-select:none <em>and</em> a transparent color.</y-description> +<div>小ぢん<span style="user-select: none; color: rgba(0, 0, 0, 0);">content</span>まり1</div> +    </y-test> + +</body> +</html>
\ No newline at end of file diff --git a/test/data/html/test-stylesheet.css b/test/data/html/test-stylesheet.css index f63d2481..2e9a2f52 100644 --- a/test/data/html/test-stylesheet.css +++ b/test/data/html/test-stylesheet.css @@ -28,7 +28,9 @@ a, a:visited {      text-decoration: underline;  } -.test { +.test, +y-test { +    display: block;      background-color: #ffffff;      margin: 1em 0;      padding: 0.5em; @@ -36,7 +38,8 @@ a, a:visited {      border-radius: 4px;  } -.test:before { +.test:before, +y-test:before {      content: "Test " counter(test-id);      display: block;      counter-increment: test-id; @@ -45,7 +48,10 @@ a, a:visited {      font-weight: bold;  } -.description { +.description, +y-description {      color: #444444;      font-style: italic; +    display: block; +    padding-bottom: 0.5em;  } |