0
Fork 0
mirror of https://github.com/fastmail/Squire.git synced 2024-12-22 15:23:29 -05:00

Add non-null assertions to element queries in spec

This commit is contained in:
Callum Skeet 2023-07-31 11:17:16 +10:00
parent a74ec739b9
commit 54914dd5d5

View file

@ -26,7 +26,7 @@ describe('Squire RTE', () => {
}); });
function selectAll(editor) { function selectAll(editor) {
document.getSelection().removeAllRanges(); document.getSelection()!.removeAllRanges();
const range = document.createRange(); const range = document.createRange();
range.setStart(editor._root.childNodes.item(0), 0); range.setStart(editor._root.childNodes.item(0), 0);
range.setEnd( range.setEnd(
@ -53,57 +53,57 @@ describe('Squire RTE', () => {
it('returns false when range inside other format', () => { it('returns false when range inside other format', () => {
const range = document.createRange(); const range = document.createRange();
range.setStart(document.querySelector('i').childNodes[0], 1); range.setStart(document.querySelector('i')!.childNodes[0], 1);
range.setEnd(document.querySelector('i').childNodes[0], 2); range.setEnd(document.querySelector('i')!.childNodes[0], 2);
editor.setSelection(range); editor.setSelection(range);
expect(editor.hasFormat('b')).toBe(false); expect(editor.hasFormat('b')).toBe(false);
}); });
it('returns false when range covers anything outside format', () => { it('returns false when range covers anything outside format', () => {
const range = document.createRange(); const range = document.createRange();
range.setStart(document.querySelector('b').previousSibling, 2); range.setStart(document.querySelector('b')!.previousSibling!, 2);
range.setEnd(document.querySelector('b').childNodes[0], 8); range.setEnd(document.querySelector('b')!.childNodes[0], 8);
editor.setSelection(range); editor.setSelection(range);
expect(editor.hasFormat('b')).toBe(false); expect(editor.hasFormat('b')).toBe(false);
}); });
it('returns true when range inside format', () => { it('returns true when range inside format', () => {
const range = document.createRange(); const range = document.createRange();
range.setStart(document.querySelector('b').childNodes[0], 2); range.setStart(document.querySelector('b')!.childNodes[0], 2);
range.setEnd(document.querySelector('b').childNodes[0], 8); range.setEnd(document.querySelector('b')!.childNodes[0], 8);
editor.setSelection(range); editor.setSelection(range);
expect(editor.hasFormat('b')).toBe(true); expect(editor.hasFormat('b')).toBe(true);
}); });
it('returns true when range covers start of format', () => { it('returns true when range covers start of format', () => {
const range = document.createRange(); const range = document.createRange();
range.setStartBefore(document.querySelector('b')); range.setStartBefore(document.querySelector('b')!);
range.setEnd(document.querySelector('b').childNodes[0], 8); range.setEnd(document.querySelector('b')!.childNodes[0], 8);
editor.setSelection(range); editor.setSelection(range);
expect(editor.hasFormat('b')).toBe(true); expect(editor.hasFormat('b')).toBe(true);
}); });
it('returns true when range covers start of format, even in weird cases', () => { it('returns true when range covers start of format, even in weird cases', () => {
const range = document.createRange(); const range = document.createRange();
const prev = document.querySelector('b').previousSibling as Text; const prev = document.querySelector('b')!.previousSibling as Text;
range.setStart(prev, prev.length); range.setStart(prev, prev.length);
range.setEnd(document.querySelector('b').childNodes[0], 8); range.setEnd(document.querySelector('b')!.childNodes[0], 8);
editor.setSelection(range); editor.setSelection(range);
expect(editor.hasFormat('b')).toBe(true); expect(editor.hasFormat('b')).toBe(true);
}); });
it('returns true when range covers end of format', () => { it('returns true when range covers end of format', () => {
const range = document.createRange(); const range = document.createRange();
range.setStart(document.querySelector('b').childNodes[0], 2); range.setStart(document.querySelector('b')!.childNodes[0], 2);
range.setEndAfter(document.querySelector('b')); range.setEndAfter(document.querySelector('b')!);
editor.setSelection(range); editor.setSelection(range);
expect(editor.hasFormat('b')).toBe(true); expect(editor.hasFormat('b')).toBe(true);
}); });
it('returns true when range covers end of format, even in weird cases', () => { it('returns true when range covers end of format, even in weird cases', () => {
const range = document.createRange(); const range = document.createRange();
range.setStart(document.querySelector('b').childNodes[0], 2); range.setStart(document.querySelector('b')!.childNodes[0], 2);
const next = document.querySelector('b').nextSibling; const next = document.querySelector('b')!.nextSibling!;
range.setEnd(next, 0); range.setEnd(next, 0);
editor.setSelection(range); editor.setSelection(range);
expect(editor.hasFormat('b')).toBe(true); expect(editor.hasFormat('b')).toBe(true);
@ -111,8 +111,8 @@ describe('Squire RTE', () => {
it('returns true when range covers all of format', () => { it('returns true when range covers all of format', () => {
const range = document.createRange(); const range = document.createRange();
range.setStartBefore(document.querySelector('b')); range.setStartBefore(document.querySelector('b')!);
range.setEndAfter(document.querySelector('b')); range.setEndAfter(document.querySelector('b')!);
editor.setSelection(range); editor.setSelection(range);
expect(editor.hasFormat('b')).toBe(true); expect(editor.hasFormat('b')).toBe(true);
}); });
@ -153,14 +153,14 @@ describe('Squire RTE', () => {
range.setStart( range.setStart(
editor._root editor._root
.getElementsByTagName('i') .getElementsByTagName('i')
.item(0) .item(0)!
.childNodes.item(0), .childNodes.item(0),
3, 3,
); );
range.setEnd( range.setEnd(
editor._root editor._root
.getElementsByTagName('i') .getElementsByTagName('i')
.item(0) .item(0)!
.childNodes.item(0), .childNodes.item(0),
8, 8,
); );
@ -176,7 +176,7 @@ describe('Squire RTE', () => {
expect(editor._root.innerHTML).toBe(startHTML); expect(editor._root.innerHTML).toBe(startHTML);
const range = document.createRange(); const range = document.createRange();
range.setStart( range.setStart(
document.getElementsByTagName('i').item(0).childNodes.item(0), document.getElementsByTagName('i').item(0)!.childNodes.item(0),
13, 13,
); );
range.setEnd( range.setEnd(
@ -211,11 +211,11 @@ describe('Squire RTE', () => {
expect(editor._root.innerHTML).toBe(startHTML); expect(editor._root.innerHTML).toBe(startHTML);
const range = document.createRange(); const range = document.createRange();
range.setStart( range.setStart(
document.getElementsByTagName('i').item(0).childNodes.item(0), document.getElementsByTagName('i').item(0)!.childNodes.item(0),
4, 4,
); );
range.setEnd( range.setEnd(
document.getElementsByTagName('i').item(0).childNodes.item(0), document.getElementsByTagName('i').item(0)!.childNodes.item(0),
18, 18,
); );
editor.removeAllFormatting(range); editor.removeAllFormatting(range);
@ -230,10 +230,10 @@ describe('Squire RTE', () => {
editor.setHTML(startHTML); editor.setHTML(startHTML);
expect(editor._root.innerHTML).toBe(startHTML); expect(editor._root.innerHTML).toBe(startHTML);
const range = document.createRange(); const range = document.createRange();
range.setStart(document.getElementsByTagName('td').item(1), 0); range.setStart(document.getElementsByTagName('td').item(1)!, 0);
range.setEnd( range.setEnd(
document.getElementsByTagName('td').item(2), document.getElementsByTagName('td').item(2)!,
document.getElementsByTagName('td').item(2).childNodes.length, document.getElementsByTagName('td').item(2)!.childNodes.length,
); );
editor.removeAllFormatting(range); editor.removeAllFormatting(range);
expect(editor._root.innerHTML).toBe( expect(editor._root.innerHTML).toBe(
@ -347,7 +347,7 @@ describe('Squire RTE', () => {
expect(editor._root.innerHTML).toBe(startHTML); expect(editor._root.innerHTML).toBe(startHTML);
const range = document.createRange(); const range = document.createRange();
const textNode = document.getElementsByTagName('li').item(1) const textNode = document.getElementsByTagName('li').item(1)!
.childNodes[0].childNodes[0]; .childNodes[0].childNodes[0];
range.setStart(textNode, 0); range.setStart(textNode, 0);
range.setEnd(textNode, 0); range.setEnd(textNode, 0);
@ -366,7 +366,7 @@ describe('Squire RTE', () => {
expect(editor._root.innerHTML).toBe(startHTML); expect(editor._root.innerHTML).toBe(startHTML);
const range = document.createRange(); const range = document.createRange();
const textNode = document.getElementsByTagName('li').item(1) const textNode = document.getElementsByTagName('li').item(1)!
.childNodes[0].childNodes[0]; .childNodes[0].childNodes[0];
range.setStart(textNode, 0); range.setStart(textNode, 0);
range.setEnd(textNode, 0); range.setEnd(textNode, 0);
@ -386,7 +386,7 @@ describe('Squire RTE', () => {
expect(editor._root.innerHTML).toBe(startHTML); expect(editor._root.innerHTML).toBe(startHTML);
const range = document.createRange(); const range = document.createRange();
const textNode = document.getElementsByTagName('li').item(1) const textNode = document.getElementsByTagName('li').item(1)!
.childNodes[0].childNodes[0]; .childNodes[0].childNodes[0];
range.setStart(textNode, 0); range.setStart(textNode, 0);
range.setEnd(textNode, 0); range.setEnd(textNode, 0);
@ -405,7 +405,7 @@ describe('Squire RTE', () => {
expect(editor._root.innerHTML).toBe(startHTML); expect(editor._root.innerHTML).toBe(startHTML);
const range = document.createRange(); const range = document.createRange();
const textNode = document.getElementsByTagName('li').item(1) const textNode = document.getElementsByTagName('li').item(1)!
.childNodes[0].childNodes[0]; .childNodes[0].childNodes[0];
range.setStart(textNode, 0); range.setStart(textNode, 0);
range.setEnd(textNode, 0); range.setEnd(textNode, 0);
@ -426,7 +426,7 @@ describe('Squire RTE', () => {
expect(editor._root.innerHTML).toBe(startHTML); expect(editor._root.innerHTML).toBe(startHTML);
const range = document.createRange(); const range = document.createRange();
const textNode = document.getElementsByTagName('li').item(1) const textNode = document.getElementsByTagName('li').item(1)!
.childNodes[0].childNodes[0]; .childNodes[0].childNodes[0];
range.setStart(textNode, 0); range.setStart(textNode, 0);
range.setEnd(textNode, 0); range.setEnd(textNode, 0);
@ -493,7 +493,7 @@ describe('Squire RTE', () => {
Object.keys(LINK_MAP).forEach((input) => { Object.keys(LINK_MAP).forEach((input) => {
it('should auto convert links to anchor: ' + input, () => { it('should auto convert links to anchor: ' + input, () => {
editor.insertHTML(input); editor.insertHTML(input);
const link = document.querySelector('a'); const link = document.querySelector('a')!;
expect(link.href).toBe(LINK_MAP[input]); expect(link.href).toBe(LINK_MAP[input]);
editor.setHTML(''); editor.setHTML('');
}); });
@ -503,7 +503,7 @@ describe('Squire RTE', () => {
editor.insertHTML(` editor.insertHTML(`
dew@fre.fr dewdwe @dew dew@fre.fr dewdwe @dew
`); `);
const link = document.querySelector('a'); const link = document.querySelector('a')!;
expect(link.textContent).toBe('dew@fre.fr'); expect(link.textContent).toBe('dew@fre.fr');
expect(link.href).toBe('mailto:dew@fre.fr'); expect(link.href).toBe('mailto:dew@fre.fr');
editor.setHTML(''); editor.setHTML('');