diff options
Diffstat (limited to 'test/text-source-range.test.js')
| -rw-r--r-- | test/text-source-range.test.js | 80 | 
1 files changed, 80 insertions, 0 deletions
| diff --git a/test/text-source-range.test.js b/test/text-source-range.test.js new file mode 100644 index 00000000..d92198c3 --- /dev/null +++ b/test/text-source-range.test.js @@ -0,0 +1,80 @@ +/* + * Copyright (C) 2024  Yomitan Authors + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program.  If not, see <https://www.gnu.org/licenses/>. + */ + +import {fail} from 'node:assert'; +import {fileURLToPath} from 'node:url'; +import path from 'path'; +import {afterAll, describe, expect, test} from 'vitest'; +import {TextSourceRange} from '../ext/js/dom/text-source-range.js'; +import {setupDomTest} from './fixtures/dom-test.js'; + + +const dirname = path.dirname(fileURLToPath(import.meta.url)); +const textSourceRangeTestEnv = await setupDomTest(path.join(dirname, 'data/html/text-source-range.html')); + + +describe('TextSourceRange', () => { +    const {window, teardown} = textSourceRangeTestEnv; +    afterAll(() => teardown(global)); + +    test('lazy', () => { +        const {document} = window; +        const testElement /** @type {NodeListOf<HTMLElement>} */ = document.getElementById('text-source-range-lazy'); +        if (testElement === null) { +            fail('test element not found'); +        } + +        const range = new Range(); +        range.selectNodeContents(testElement); + +        const source = TextSourceRange.createLazy(range); +        const startLength = source.setStartOffset(200, false); +        const endLength = source.setEndOffset(200, true, false); + +        const text = source.text(); +        const textLength = text.length; + +        expect(startLength).toBeLessThanOrEqual(textLength); +        expect(endLength).toBeLessThan(textLength); +        const count = (text.match(/人/g) || []).length; +        expect(count).toEqual(1); +    }); + +    test('standard', () => { +        const {document} = window; +        const testElement /** @type {NodeListOf<HTMLElement>} */ = document.getElementById('text-source-range'); +        if (testElement === null) { +            fail('test element not found'); +        } + +        const range = new Range(); + +        range.selectNodeContents(testElement); + +        const source = TextSourceRange.create(range); +        const startLength = source.setStartOffset(15, false); +        const endLength = source.setEndOffset(15, true, false); + +        const text = source.text(); +        const textLength = text.length; + +        expect(startLength).toBeLessThan(textLength); +        expect(endLength).toBeLessThan(textLength); +        const count = (text.match(/山/g) || []).length; +        expect(count).toEqual(1); +    }); +}); |