From 54a3dbb9a0c0f39c425c22201f7851992033c81b Mon Sep 17 00:00:00 2001
From: Richard Hansen
Date: Sun, 24 Jan 2021 00:56:11 -0500
Subject: [PATCH 01/26] lint: Fix some straightforward ESLint errors
---
src/node/hooks/express/openapi.js | 6 +-
tests/backend/specs/api/characterEncoding.js | 2 +
tests/backend/specs/api/importexport.js | 134 +++++++++----------
tests/backend/specs/contentcollector.js | 114 ++++++++--------
4 files changed, 131 insertions(+), 125 deletions(-)
diff --git a/src/node/hooks/express/openapi.js b/src/node/hooks/express/openapi.js
index 344913389..d7059896a 100644
--- a/src/node/hooks/express/openapi.js
+++ b/src/node/hooks/express/openapi.js
@@ -391,9 +391,9 @@ const defaultResponseRefs = {
// convert to a dictionary of operation objects
const operations = {};
-for (const resource in resources) {
- for (const action in resources[resource]) {
- const {operationId, responseSchema, ...operation} = resources[resource][action];
+for (const [resource, actions] of Object.entries(resources)) {
+ for (const [action, spec] of Object.entries(actions)) {
+ const {operationId, responseSchema, ...operation} = spec;
// add response objects
const responses = {...defaultResponseRefs};
diff --git a/tests/backend/specs/api/characterEncoding.js b/tests/backend/specs/api/characterEncoding.js
index e17e90fe4..94c22307d 100644
--- a/tests/backend/specs/api/characterEncoding.js
+++ b/tests/backend/specs/api/characterEncoding.js
@@ -1,3 +1,5 @@
+'use strict';
+
/*
* This file is copied & modified from /tests/backend/specs/api/pad.js
*
diff --git a/tests/backend/specs/api/importexport.js b/tests/backend/specs/api/importexport.js
index b7b45b261..fe61dfa12 100644
--- a/tests/backend/specs/api/importexport.js
+++ b/tests/backend/specs/api/importexport.js
@@ -6,13 +6,11 @@
* TODO: unify those two files, and merge in a single one.
*/
-/* eslint-disable max-len */
-
const common = require('../../common');
-const supertest = require(`${__dirname}/../../../../src/node_modules/supertest`);
-const settings = require(`${__dirname}/../../../../tests/container/loadSettings.js`).loadSettings();
-const api = supertest(`http://${settings.ip}:${settings.port}`);
+const settings = require('../../../container/loadSettings.js').loadSettings();
+const supertest = require('ep_etherpad-lite/node_modules/supertest');
+const api = supertest(`http://${settings.ip}:${settings.port}`);
const apiKey = common.apiKey;
const apiVersion = 1;
@@ -47,16 +45,16 @@ const testImports = {
},
/*
- "prefixcorrectlinenumber when introduced none list item - currently not supported see #3450":{
+ "prefixcorrectlinenumber when introduced none list item - currently not supported see #3450": {
input: '- should be 1
test- should be 2
',
expectedHTML: '- should be 1
test- should be 2
',
- expectedText: '\t1. should be 1\n\ttest\n\t2. should be 2\n\n'
+ expectedText: '\t1. should be 1\n\ttest\n\t2. should be 2\n\n',
}
,
- "newlinesshouldntresetlinenumber #2194":{
+ "newlinesshouldntresetlinenumber #2194": {
input: '- should be 1
test- should be 2
',
expectedHTML: '- should be 1
test- should be 2
',
- expectedText: '\t1. should be 1\n\ttest\n\t2. should be 2\n\n'
+ expectedText: '\t1. should be 1\n\ttest\n\t2. should be 2\n\n',
}
*/
'ignoreAnyTagsOutsideBody': {
@@ -69,88 +67,88 @@ const testImports = {
description: 'Indented lists are represented with tabs and without bullets',
input: '',
expectedHTML: '
',
- expectedText: '\tindent\n\tindent\n\n'
+ expectedText: '\tindent\n\tindent\n\n',
},
- lineWithMultipleSpaces: {
+ 'lineWithMultipleSpaces': {
description: 'Multiple spaces should be collapsed',
input: 'Text with more than one space.
',
expectedHTML: 'Text with more than one space.
',
- expectedText: 'Text with more than one space.\n\n'
+ expectedText: 'Text with more than one space.\n\n',
},
- lineWithMultipleNonBreakingAndNormalSpaces: {
+ 'lineWithMultipleNonBreakingAndNormalSpaces': {
// XXX the HTML between "than" and "one" looks strange
description: 'non-breaking space should be preserved, but can be replaced when it',
input: 'Text with more than one space.
',
expectedHTML: 'Text with more than one space.
',
- expectedText: 'Text with more than one space.\n\n'
+ expectedText: 'Text with more than one space.\n\n',
},
- multiplenbsp: {
+ 'multiplenbsp': {
description: 'Multiple non-breaking space should be preserved',
input: '
',
expectedHTML: '
',
- expectedText: ' \n\n'
+ expectedText: ' \n\n',
},
- multipleNonBreakingSpaceBetweenWords: {
+ 'multipleNonBreakingSpaceBetweenWords': {
description: 'A normal space is always inserted before a word',
input: ' word1 word2 word3
',
expectedHTML: ' word1 word2 word3
',
- expectedText: ' word1 word2 word3\n\n'
+ expectedText: ' word1 word2 word3\n\n',
},
- nonBreakingSpacePreceededBySpaceBetweenWords: {
+ 'nonBreakingSpacePreceededBySpaceBetweenWords': {
description: 'A non-breaking space preceeded by a normal space',
input: ' word1 word2 word3
',
expectedHTML: ' word1 word2 word3
',
- expectedText: ' word1 word2 word3\n\n'
+ expectedText: ' word1 word2 word3\n\n',
},
- nonBreakingSpaceFollowededBySpaceBetweenWords: {
+ 'nonBreakingSpaceFollowededBySpaceBetweenWords': {
description: 'A non-breaking space followed by a normal space',
input: ' word1 word2 word3
',
expectedHTML: ' word1 word2 word3
',
- expectedText: ' word1 word2 word3\n\n'
+ expectedText: ' word1 word2 word3\n\n',
},
- spacesAfterNewline: {
+ 'spacesAfterNewline': {
description: 'Collapse spaces that follow a newline',
- input:'something
something
',
+ input: 'something
something
',
expectedHTML: 'something
something
',
- expectedText: 'something\nsomething\n\n'
+ expectedText: 'something\nsomething\n\n',
},
- spacesAfterNewlineP: {
+ 'spacesAfterNewlineP': {
description: 'Collapse spaces that follow a paragraph',
- input:'something something
',
+ input: 'something something
',
expectedHTML: 'something
something
',
- expectedText: 'something\n\nsomething\n\n'
+ expectedText: 'something\n\nsomething\n\n',
},
- spacesAtEndOfLine: {
+ 'spacesAtEndOfLine': {
description: 'Collapse spaces that preceed/follow a newline',
- input:'something
something
',
+ input: 'something
something
',
expectedHTML: 'something
something
',
- expectedText: 'something\nsomething\n\n'
+ expectedText: 'something\nsomething\n\n',
},
- spacesAtEndOfLineP: {
+ 'spacesAtEndOfLineP': {
description: 'Collapse spaces that preceed/follow a paragraph',
- input:'something something
',
+ input: 'something something
',
expectedHTML: 'something
something
',
- expectedText: 'something\n\nsomething\n\n'
+ expectedText: 'something\n\nsomething\n\n',
},
- nonBreakingSpacesAfterNewlines: {
+ 'nonBreakingSpacesAfterNewlines': {
description: 'Don\'t collapse non-breaking spaces that follow a newline',
- input:'something
something
',
+ input: 'something
something
',
expectedHTML: 'something
something
',
- expectedText: 'something\n something\n\n'
+ expectedText: 'something\n something\n\n',
},
- nonBreakingSpacesAfterNewlinesP: {
+ 'nonBreakingSpacesAfterNewlinesP': {
description: 'Don\'t collapse non-breaking spaces that follow a paragraph',
- input:'something something
',
+ input: 'something something
',
expectedHTML: 'something
something
',
- expectedText: 'something\n\n something\n\n'
+ expectedText: 'something\n\n something\n\n',
},
- collapseSpacesInsideElements: {
+ 'collapseSpacesInsideElements': {
description: 'Preserve only one space when multiple are present',
input: 'Need more space s !
',
expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n'
+ expectedText: 'Need more space s !\n\n',
},
- collapseSpacesAcrossNewlines: {
+ 'collapseSpacesAcrossNewlines': {
description: 'Newlines and multiple spaces across newlines should be collapsed',
input: `
Need
@@ -159,29 +157,29 @@ const testImports = {
s
!
`,
expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n'
+ expectedText: 'Need more space s !\n\n',
},
- multipleNewLinesAtBeginning: {
+ 'multipleNewLinesAtBeginning': {
description: 'Multiple new lines and paragraphs at the beginning should be preserved',
input: '
first line
second line
',
expectedHTML: '
first line
second line
',
- expectedText: '\n\n\n\nfirst line\n\nsecond line\n\n'
+ expectedText: '\n\n\n\nfirst line\n\nsecond line\n\n',
},
- multiLineParagraph:{
- description: "A paragraph with multiple lines should not loose spaces when lines are combined",
- input:`
+ 'multiLineParagraph': {
+ description: 'A paragraph with multiple lines should not loose spaces when lines are combined',
+ input: `
а б в г ґ д е є ж з и і ї й к л м н о
п р с т у ф х ц ч ш щ ю я ь
`,
expectedHTML: 'а б в г ґ д е є ж з и і ї й к л м н о п р с т у ф х ц ч ш щ ю я ь
',
- expectedText: 'а б в г ґ д е є ж з и і ї й к л м н о п р с т у ф х ц ч ш щ ю я ь\n\n'
+ expectedText: 'а б в г ґ д е є ж з и і ї й к л м н о п р с т у ф х ц ч ш щ ю я ь\n\n',
},
- multiLineParagraphWithPre:{
- //XXX why is there before "in"?
- description: "lines in preformatted text should be kept intact",
- input:`
+ 'multiLineParagraphWithPre': {
+ // XXX why is there before "in"?
+ description: 'lines in preformatted text should be kept intact',
+ input: `
а б в г ґ д е є ж з и і ї й к л м н о
multiple
lines
@@ -191,40 +189,40 @@ const testImports = {
ь
`,
expectedHTML: 'а б в г ґ д е є ж з и і ї й к л м н о
multiple
lines
in
pre
п р с т у ф х ц ч ш щ ю я ь
',
- expectedText: 'а б в г ґ д е є ж з и і ї й к л м н о\nmultiple\n lines\n in\n pre\n\nп р с т у ф х ц ч ш щ ю я ь\n\n'
+ expectedText: 'а б в г ґ д е є ж з и і ї й к л м н о\nmultiple\n lines\n in\n pre\n\nп р с т у ф х ц ч ш щ ю я ь\n\n',
},
- preIntroducesASpace: {
- description: "pre should be on a new line not preceeded by a space",
- input:`
+ 'preIntroducesASpace': {
+ description: 'pre should be on a new line not preceeded by a space',
+ input: `
1
preline
`,
expectedHTML: '1
preline
',
- expectedText: '1\npreline\n\n\n'
+ expectedText: '1\npreline\n\n\n',
},
- dontDeleteSpaceInsideElements: {
+ 'dontDeleteSpaceInsideElements': {
description: 'Preserve spaces inside elements',
input: 'Need more space s !
',
expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n'
+ expectedText: 'Need more space s !\n\n',
},
- dontDeleteSpaceOutsideElements: {
+ 'dontDeleteSpaceOutsideElements': {
description: 'Preserve spaces outside elements',
input: 'Need more space s !
',
expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n'
+ expectedText: 'Need more space s !\n\n',
},
- dontDeleteSpaceAtEndOfElement: {
+ 'dontDeleteSpaceAtEndOfElement': {
description: 'Preserve spaces at the end of an element',
input: 'Need more space s !
',
expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n'
+ expectedText: 'Need more space s !\n\n',
},
- dontDeleteSpaceAtBeginOfElements: {
+ 'dontDeleteSpaceAtBeginOfElements': {
description: 'Preserve spaces at the start of an element',
input: 'Need more space s !
',
expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n'
+ expectedText: 'Need more space s !\n\n',
},
};
@@ -315,7 +313,7 @@ describe(__filename, function () {
function endPoint(point, version) {
version = version || apiVersion;
return `/api/${version}/${point}?apikey=${apiKey}`;
-};
+}
function makeid() {
let text = '';
diff --git a/tests/backend/specs/contentcollector.js b/tests/backend/specs/contentcollector.js
index c85904917..83417966d 100644
--- a/tests/backend/specs/contentcollector.js
+++ b/tests/backend/specs/contentcollector.js
@@ -1,18 +1,17 @@
'use strict';
-/* eslint-disable max-len */
/*
- * While importexport tests target the `setHTML` API endpoint, which is nearly identical to what happens
- * when a user manually imports a document via the UI, the contentcollector tests here don't use rehype to process
- * the document. Rehype removes spaces and newĺines were applicable, so the expected results here can
- * differ from importexport.js.
+ * While importexport tests target the `setHTML` API endpoint, which is nearly identical to what
+ * happens when a user manually imports a document via the UI, the contentcollector tests here don't
+ * use rehype to process the document. Rehype removes spaces and newĺines were applicable, so the
+ * expected results here can differ from importexport.js.
*
* If you add tests here, please also add them to importexport.js
*/
-const contentcollector = require('../../../src/static/js/contentcollector');
-const AttributePool = require('../../../src/static/js/AttributePool');
-const cheerio = require('../../../src/node_modules/cheerio');
+const AttributePool = require('ep_etherpad-lite/static/js/AttributePool');
+const cheerio = require('ep_etherpad-lite/node_modules/cheerio');
+const contentcollector = require('ep_etherpad-lite/static/js/contentcollector');
const tests = {
nestedLi: {
@@ -124,74 +123,74 @@ const tests = {
lineWithMultipleSpaces: {
description: 'Multiple spaces should be preserved',
html: 'Text with more than one space.
',
- expectedLineAttribs: [ '+10' ],
- expectedText: ['Text with more than one space.']
+ expectedLineAttribs: ['+10'],
+ expectedText: ['Text with more than one space.'],
},
lineWithMultipleNonBreakingAndNormalSpaces: {
description: 'non-breaking and normal space should be preserved',
html: 'Text with more than one space.
',
- expectedLineAttribs: [ '+10' ],
- expectedText: ['Text with more than one space.']
+ expectedLineAttribs: ['+10'],
+ expectedText: ['Text with more than one space.'],
},
multiplenbsp: {
description: 'Multiple nbsp should be preserved',
html: '
',
- expectedLineAttribs: [ '+2' ],
- expectedText: [' ']
+ expectedLineAttribs: ['+2'],
+ expectedText: [' '],
},
multipleNonBreakingSpaceBetweenWords: {
description: 'Multiple nbsp between words ',
html: ' word1 word2 word3
',
- expectedLineAttribs: [ '+m' ],
- expectedText: [' word1 word2 word3']
+ expectedLineAttribs: ['+m'],
+ expectedText: [' word1 word2 word3'],
},
nonBreakingSpacePreceededBySpaceBetweenWords: {
description: 'A non-breaking space preceeded by a normal space',
html: ' word1 word2 word3
',
- expectedLineAttribs: [ '+l' ],
- expectedText: [' word1 word2 word3']
+ expectedLineAttribs: ['+l'],
+ expectedText: [' word1 word2 word3'],
},
nonBreakingSpaceFollowededBySpaceBetweenWords: {
description: 'A non-breaking space followed by a normal space',
html: ' word1 word2 word3
',
- expectedLineAttribs: [ '+l' ],
- expectedText: [' word1 word2 word3']
+ expectedLineAttribs: ['+l'],
+ expectedText: [' word1 word2 word3'],
},
spacesAfterNewline: {
description: 'Don\'t collapse spaces that follow a newline',
- html:'something
something
',
+ html: 'something
something
',
expectedLineAttribs: ['+9', '+m'],
- expectedText: ['something', ' something']
+ expectedText: ['something', ' something'],
},
spacesAfterNewlineP: {
description: 'Don\'t collapse spaces that follow a empty paragraph',
- html:'something something
',
+ html: 'something something
',
expectedLineAttribs: ['+9', '', '+m'],
- expectedText: ['something', '', ' something']
+ expectedText: ['something', '', ' something'],
},
spacesAtEndOfLine: {
description: 'Don\'t collapse spaces that preceed/follow a newline',
- html:'something
something
',
+ html: 'something
something
',
expectedLineAttribs: ['+l', '+m'],
- expectedText: ['something ', ' something']
+ expectedText: ['something ', ' something'],
},
spacesAtEndOfLineP: {
description: 'Don\'t collapse spaces that preceed/follow a empty paragraph',
- html:'something something
',
+ html: 'something something
',
expectedLineAttribs: ['+l', '', '+m'],
- expectedText: ['something ', '', ' something']
+ expectedText: ['something ', '', ' something'],
},
nonBreakingSpacesAfterNewlines: {
description: 'Don\'t collapse non-breaking spaces that follow a newline',
- html:'something
something
',
+ html: 'something
something
',
expectedLineAttribs: ['+9', '+c'],
- expectedText: ['something', ' something']
+ expectedText: ['something', ' something'],
},
nonBreakingSpacesAfterNewlinesP: {
description: 'Don\'t collapse non-breaking spaces that follow a paragraph',
- html:'something something
',
+ html: 'something something
',
expectedLineAttribs: ['+9', '', '+c'],
- expectedText: ['something', '', ' something']
+ expectedText: ['something', '', ' something'],
},
preserveSpacesInsideElements: {
description: 'Preserve all spaces when multiple are present',
@@ -207,27 +206,27 @@ const tests = {
space
s
!
`,
- expectedLineAttribs: [ '+19*0+4+b' ],
- expectedText: [ 'Need more space s !' ]
+ expectedLineAttribs: ['+19*0+4+b'],
+ expectedText: ['Need more space s !'],
},
multipleNewLinesAtBeginning: {
description: 'Multiple new lines at the beginning should be preserved',
html: '
first line
second line
',
expectedLineAttribs: ['', '', '', '', '+a', '', '+b'],
- expectedText: [ '', '', '', '', 'first line', '', 'second line']
+ expectedText: ['', '', '', '', 'first line', '', 'second line'],
},
- multiLineParagraph:{
- description: "A paragraph with multiple lines should not loose spaces when lines are combined",
- html:`
+ multiLineParagraph: {
+ description: 'A paragraph with multiple lines should not loose spaces when lines are combined',
+ html: `
а б в г ґ д е є ж з и і ї й к л м н о
п р с т у ф х ц ч ш щ ю я ь
`,
- expectedLineAttribs: [ '+1t' ],
- expectedText: ["а б в г ґ д е є ж з и і ї й к л м н о п р с т у ф х ц ч ш щ ю я ь"]
+ expectedLineAttribs: ['+1t'],
+ expectedText: ['а б в г ґ д е є ж з и і ї й к л м н о п р с т у ф х ц ч ш щ ю я ь'],
},
- multiLineParagraphWithPre:{
- description: "lines in preformatted text should be kept intact",
- html:`
+ multiLineParagraphWithPre: {
+ description: 'lines in preformatted text should be kept intact',
+ html: `
а б в г ґ д е є ж з и і ї й к л м н о
multiple
lines
in
@@ -235,41 +234,48 @@ pre
п р с т у ф х ц ч ш щ ю я
ь
`,
- expectedLineAttribs: [ '+11', '+8', '+5', '+2', '+3', '+r' ],
- expectedText: ['а б в г ґ д е є ж з и і ї й к л м н о', 'multiple', 'lines', 'in', 'pre', 'п р с т у ф х ц ч ш щ ю я ь']
+ expectedLineAttribs: ['+11', '+8', '+5', '+2', '+3', '+r'],
+ expectedText: [
+ 'а б в г ґ д е є ж з и і ї й к л м н о',
+ 'multiple',
+ 'lines',
+ 'in',
+ 'pre',
+ 'п р с т у ф х ц ч ш щ ю я ь',
+ ],
},
preIntroducesASpace: {
- description: "pre should be on a new line not preceeded by a space",
- html:`
+ description: 'pre should be on a new line not preceeded by a space',
+ html: `
1
preline
`,
- expectedLineAttribs: [ '+6', '+7' ],
- expectedText: [' 1 ', 'preline']
+ expectedLineAttribs: ['+6', '+7'],
+ expectedText: [' 1 ', 'preline'],
},
dontDeleteSpaceInsideElements: {
description: 'Preserve spaces on the beginning and end of a element',
html: 'Need more space s !
',
expectedLineAttribs: ['+f*0+3+1'],
- expectedText: ['Need more space s !']
+ expectedText: ['Need more space s !'],
},
dontDeleteSpaceOutsideElements: {
description: 'Preserve spaces outside elements',
html: 'Need more space s !
',
expectedLineAttribs: ['+g*0+1+2'],
- expectedText: ['Need more space s !']
+ expectedText: ['Need more space s !'],
},
dontDeleteSpaceAtEndOfElement: {
description: 'Preserve spaces at the end of an element',
html: 'Need more space s !
',
expectedLineAttribs: ['+g*0+2+1'],
- expectedText: ['Need more space s !']
+ expectedText: ['Need more space s !'],
},
dontDeleteSpaceAtBeginOfElements: {
description: 'Preserve spaces at the start of an element',
html: 'Need more space s !
',
expectedLineAttribs: ['+f*0+2+2'],
- expectedText: ['Need more space s !']
+ expectedText: ['Need more space s !'],
},
};
@@ -325,7 +331,7 @@ describe(__filename, function () {
function arraysEqual(a, b) {
if (a === b) return true;
if (a == null || b == null) return false;
- if (a.length != b.length) return false;
+ if (a.length !== b.length) return false;
// If you don't care about the order of the elements inside
// the array, you should sort both arrays here.
From 906b2624edb5e0729c1e42d7b851dc80fff640ca Mon Sep 17 00:00:00 2001
From: Richard Hansen
Date: Sun, 24 Jan 2021 01:28:11 -0500
Subject: [PATCH 02/26] tests: Re-enable import/export test that is now working
---
tests/backend/specs/api/importexport.js | 1 -
1 file changed, 1 deletion(-)
diff --git a/tests/backend/specs/api/importexport.js b/tests/backend/specs/api/importexport.js
index fe61dfa12..870a715b2 100644
--- a/tests/backend/specs/api/importexport.js
+++ b/tests/backend/specs/api/importexport.js
@@ -31,7 +31,6 @@ const testImports = {
input: '',
expectedHTML: '
',
expectedText: '\t* FOO\n\n',
- disabled: true,
},
'prefixcorrectlinenumber': {
input: '- should be 1
- should be 2
',
From 53160f4a21dba880df94461f2def288bcb43ab76 Mon Sep 17 00:00:00 2001
From: Richard Hansen
Date: Sun, 24 Jan 2021 03:30:43 -0500
Subject: [PATCH 03/26] tests: Delete invalid contentcollector test
The HTML spec doesn't allow `` to be a child of `` (it must be
a child of `- ` instead).
---
tests/backend/specs/contentcollector.js | 6 ------
1 file changed, 6 deletions(-)
diff --git a/tests/backend/specs/contentcollector.js b/tests/backend/specs/contentcollector.js
index 83417966d..04970d74d 100644
--- a/tests/backend/specs/contentcollector.js
+++ b/tests/backend/specs/contentcollector.js
@@ -78,12 +78,6 @@ const tests = {
expectedText: ['*should be 1', 'hello', '*should be 1', '*should be 2', ''],
noteToSelf: "Shouldn't include attribute marker in the
line",
},
- bulletListInOL: {
- description: 'A bullet within an OL should not change numbering..',
- html: '
- should be 1
- should be 2
',
- expectedLineAttribs: ['*0*1*2*3+1+b', '*0*4*2*3+1+i', '*0*1*2*5+1+b', ''],
- expectedText: ['*should be 1', '*should be a bullet', '*should be 2', ''],
- },
testP: {
description: 'A single should create a new line',
html: '',
From 32a0df4883d17ea9e8f3871f2785c2916416c3b3 Mon Sep 17 00:00:00 2001
From: Richard Hansen
Date: Sun, 24 Jan 2021 03:31:45 -0500
Subject: [PATCH 04/26] tests: Fix invalid HTML in contentcollector tests
The HTML spec does not permit `` as a child of ``.
---
tests/backend/specs/contentcollector.js | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/tests/backend/specs/contentcollector.js b/tests/backend/specs/contentcollector.js
index 04970d74d..81ac08ed6 100644
--- a/tests/backend/specs/contentcollector.js
+++ b/tests/backend/specs/contentcollector.js
@@ -221,11 +221,11 @@ const tests = {
multiLineParagraphWithPre: {
description: 'lines in preformatted text should be kept intact',
html: `
-а б в г ґ д е є ж з и і ї й к л м н о
multiple
+а б в г ґ д е є ж з и і ї й к л м н оmultiple
lines
in
pre
-
п р с т у ф х ц ч ш щ ю я
+
п р с т у ф х ц ч ш щ ю я
ь
`,
expectedLineAttribs: ['+11', '+8', '+5', '+2', '+3', '+r'],
@@ -242,8 +242,8 @@ pre
description: 'pre should be on a new line not preceeded by a space',
html: `
1
-
preline
-
`,
+preline
+
`,
expectedLineAttribs: ['+6', '+7'],
expectedText: [' 1 ', 'preline'],
},
From dd815892f296c785b3ac98b7bb70b0f4ac6ef474 Mon Sep 17 00:00:00 2001
From: Richard Hansen
Date: Sun, 24 Jan 2021 01:29:24 -0500
Subject: [PATCH 05/26] tests: Delete erroneous `describe()` calls
`describe()` is meant to be used by independent tests, but the tests
in this file are not independent. Add a higher-level `describe()` call
and delete all of the `describe()` calls that wrap a single test.
---
tests/backend/specs/api/importexport.js | 30 ++++++++++---------------
1 file changed, 12 insertions(+), 18 deletions(-)
diff --git a/tests/backend/specs/api/importexport.js b/tests/backend/specs/api/importexport.js
index 870a715b2..fefd146f3 100644
--- a/tests/backend/specs/api/importexport.js
+++ b/tests/backend/specs/api/importexport.js
@@ -227,15 +227,15 @@ const testImports = {
describe(__filename, function () {
Object.keys(testImports).forEach((testName) => {
- const testPadId = makeid();
- const test = testImports[testName];
- if (test.disabled) {
- return xit(`DISABLED: ${testName}`, function (done) {
- done();
- });
- }
- describe(`createPad ${testName}`, function () {
- it('creates a new Pad', function (done) {
+ describe(testName, function () {
+ const testPadId = makeid();
+ const test = testImports[testName];
+ if (test.disabled) {
+ return xit(`DISABLED: ${testName}`, function (done) {
+ done();
+ });
+ }
+ it('createPad', function (done) {
api.get(`${endPoint('createPad')}&padID=${testPadId}`)
.expect((res) => {
if (res.body.code !== 0) throw new Error('Unable to create new Pad');
@@ -243,10 +243,8 @@ describe(__filename, function () {
.expect('Content-Type', /json/)
.expect(200, done);
});
- });
- describe(`setHTML ${testName}`, function () {
- it('Sets the HTML', function (done) {
+ it('setHTML', function (done) {
api.get(`${endPoint('setHTML')}&padID=${testPadId}&html=${encodeURIComponent(test.input)}`)
.expect((res) => {
if (res.body.code !== 0) throw new Error(`Error:${testName}`);
@@ -254,10 +252,8 @@ describe(__filename, function () {
.expect('Content-Type', /json/)
.expect(200, done);
});
- });
- describe(`getHTML ${testName}`, function () {
- it('Gets back the HTML of a Pad', function (done) {
+ it('getHTML', function (done) {
api.get(`${endPoint('getHTML')}&padID=${testPadId}`)
.expect((res) => {
const receivedHtml = res.body.data.html;
@@ -279,10 +275,8 @@ describe(__filename, function () {
.expect('Content-Type', /json/)
.expect(200, done);
});
- });
- describe(`getText ${testName}`, function () {
- it('Gets back the Text of a Pad', function (done) {
+ it('getText', function (done) {
api.get(`${endPoint('getText')}&padID=${testPadId}`)
.expect((res) => {
const receivedText = res.body.data.text;
From fc69ae78aafa2765731fd8410b2535613b50902c Mon Sep 17 00:00:00 2001
From: Richard Hansen
Date: Sun, 24 Jan 2021 01:34:28 -0500
Subject: [PATCH 06/26] tests: Use `assert.deepEqual()` to simplify equality
checks
---
tests/backend/specs/contentcollector.js | 21 +++------------------
1 file changed, 3 insertions(+), 18 deletions(-)
diff --git a/tests/backend/specs/contentcollector.js b/tests/backend/specs/contentcollector.js
index 81ac08ed6..7014cac2a 100644
--- a/tests/backend/specs/contentcollector.js
+++ b/tests/backend/specs/contentcollector.js
@@ -10,6 +10,7 @@
*/
const AttributePool = require('ep_etherpad-lite/static/js/AttributePool');
+const assert = require('assert').strict;
const cheerio = require('ep_etherpad-lite/node_modules/cheerio');
const contentcollector = require('ep_etherpad-lite/static/js/contentcollector');
@@ -298,24 +299,8 @@ describe(__filename, function () {
const recievedText = new Array(result.lines);
const expectedText = testObj.expectedText;
- // Check recieved text matches the expected text
- if (arraysEqual(recievedText[0], expectedText)) {
- // console.log("PASS: Recieved Text did match Expected Text\nRecieved:", recievedText[0], "\nExpected:", testObj.expectedText)
- } else {
- console.error('FAIL: Recieved Text did not match Expected Text\nRecieved:', recievedText[0], '\nExpected:', testObj.expectedText);
- throw new Error();
- }
-
- // Check recieved attributes matches the expected attributes
- if (arraysEqual(recievedAttributes, expectedAttributes)) {
- // console.log("PASS: Recieved Attributes matched Expected Attributes");
- done();
- } else {
- console.error('FAIL', test, testObj.description);
- console.error('FAIL: Recieved Attributes did not match Expected Attributes\nRecieved: ', recievedAttributes, '\nExpected: ', expectedAttributes);
- console.error('FAILING HTML', testObj.html);
- throw new Error();
- }
+ assert.deepEqual(recievedText[0], expectedText);
+ assert.deepEqual(recievedAttributes, expectedAttributes);
});
});
}
From b164f9b4319fb06ea041feea51e1efc2fe272713 Mon Sep 17 00:00:00 2001
From: Richard Hansen
Date: Sun, 24 Jan 2021 01:54:14 -0500
Subject: [PATCH 07/26] tests: Replace "expected" with "want", "received" with
"got"
"Got" and "want" are common terms for testing, plus this fixes a
spelling mistake ("received" was misspelled as "recieved").
---
tests/backend/specs/api/importexport.js | 148 ++++++++++++------------
tests/backend/specs/contentcollector.js | 144 +++++++++++------------
2 files changed, 146 insertions(+), 146 deletions(-)
diff --git a/tests/backend/specs/api/importexport.js b/tests/backend/specs/api/importexport.js
index fefd146f3..1a9e94332 100644
--- a/tests/backend/specs/api/importexport.js
+++ b/tests/backend/specs/api/importexport.js
@@ -17,135 +17,135 @@ const apiVersion = 1;
const testImports = {
'malformed': {
input: '- wtf
',
- expectedHTML: 'wtf
',
- expectedText: 'wtf\n\n',
+ wantHTML: 'wtf
',
+ wantText: 'wtf\n\n',
disabled: true,
},
'nonelistiteminlist #3620': {
input: '',
- expectedHTML: '
',
- expectedText: '\ttest\n\t* FOO\n\n',
+ wantHTML: '
',
+ wantText: '\ttest\n\t* FOO\n\n',
disabled: true,
},
'whitespaceinlist #3620': {
input: '',
- expectedHTML: '
',
- expectedText: '\t* FOO\n\n',
+ wantHTML: '
',
+ wantText: '\t* FOO\n\n',
},
'prefixcorrectlinenumber': {
input: '- should be 1
- should be 2
',
- expectedHTML: '- should be 1
- should be 2
',
- expectedText: '\t1. should be 1\n\t2. should be 2\n\n',
+ wantHTML: '- should be 1
- should be 2
',
+ wantText: '\t1. should be 1\n\t2. should be 2\n\n',
},
'prefixcorrectlinenumbernested': {
input: '- should be 1
- foo
- should be 2
',
- expectedHTML: '- should be 1
- foo
- should be 2
',
- expectedText: '\t1. should be 1\n\t\t1.1. foo\n\t2. should be 2\n\n',
+ wantHTML: '- should be 1
- foo
- should be 2
',
+ wantText: '\t1. should be 1\n\t\t1.1. foo\n\t2. should be 2\n\n',
},
/*
"prefixcorrectlinenumber when introduced none list item - currently not supported see #3450": {
input: '- should be 1
test- should be 2
',
- expectedHTML: '- should be 1
test- should be 2
',
- expectedText: '\t1. should be 1\n\ttest\n\t2. should be 2\n\n',
+ wantHTML: '- should be 1
test- should be 2
',
+ wantText: '\t1. should be 1\n\ttest\n\t2. should be 2\n\n',
}
,
"newlinesshouldntresetlinenumber #2194": {
input: '- should be 1
test- should be 2
',
- expectedHTML: '- should be 1
test- should be 2
',
- expectedText: '\t1. should be 1\n\ttest\n\t2. should be 2\n\n',
+ wantHTML: '- should be 1
test- should be 2
',
+ wantText: '\t1. should be 1\n\ttest\n\t2. should be 2\n\n',
}
*/
'ignoreAnyTagsOutsideBody': {
description: 'Content outside body should be ignored',
input: 'titleempty
',
- expectedHTML: 'empty
',
- expectedText: 'empty\n\n',
+ wantHTML: 'empty
',
+ wantText: 'empty\n\n',
},
'indentedListsAreNotBullets': {
description: 'Indented lists are represented with tabs and without bullets',
input: '',
- expectedHTML: '
',
- expectedText: '\tindent\n\tindent\n\n',
+ wantHTML: '
',
+ wantText: '\tindent\n\tindent\n\n',
},
'lineWithMultipleSpaces': {
description: 'Multiple spaces should be collapsed',
input: 'Text with more than one space.
',
- expectedHTML: 'Text with more than one space.
',
- expectedText: 'Text with more than one space.\n\n',
+ wantHTML: 'Text with more than one space.
',
+ wantText: 'Text with more than one space.\n\n',
},
'lineWithMultipleNonBreakingAndNormalSpaces': {
// XXX the HTML between "than" and "one" looks strange
description: 'non-breaking space should be preserved, but can be replaced when it',
input: 'Text with more than one space.
',
- expectedHTML: 'Text with more than one space.
',
- expectedText: 'Text with more than one space.\n\n',
+ wantHTML: 'Text with more than one space.
',
+ wantText: 'Text with more than one space.\n\n',
},
'multiplenbsp': {
description: 'Multiple non-breaking space should be preserved',
input: '
',
- expectedHTML: '
',
- expectedText: ' \n\n',
+ wantHTML: '
',
+ wantText: ' \n\n',
},
'multipleNonBreakingSpaceBetweenWords': {
description: 'A normal space is always inserted before a word',
input: ' word1 word2 word3
',
- expectedHTML: ' word1 word2 word3
',
- expectedText: ' word1 word2 word3\n\n',
+ wantHTML: ' word1 word2 word3
',
+ wantText: ' word1 word2 word3\n\n',
},
'nonBreakingSpacePreceededBySpaceBetweenWords': {
description: 'A non-breaking space preceeded by a normal space',
input: ' word1 word2 word3
',
- expectedHTML: ' word1 word2 word3
',
- expectedText: ' word1 word2 word3\n\n',
+ wantHTML: ' word1 word2 word3
',
+ wantText: ' word1 word2 word3\n\n',
},
'nonBreakingSpaceFollowededBySpaceBetweenWords': {
description: 'A non-breaking space followed by a normal space',
input: ' word1 word2 word3
',
- expectedHTML: ' word1 word2 word3
',
- expectedText: ' word1 word2 word3\n\n',
+ wantHTML: ' word1 word2 word3
',
+ wantText: ' word1 word2 word3\n\n',
},
'spacesAfterNewline': {
description: 'Collapse spaces that follow a newline',
input: 'something
something
',
- expectedHTML: 'something
something
',
- expectedText: 'something\nsomething\n\n',
+ wantHTML: 'something
something
',
+ wantText: 'something\nsomething\n\n',
},
'spacesAfterNewlineP': {
description: 'Collapse spaces that follow a paragraph',
input: 'something something
',
- expectedHTML: 'something
something
',
- expectedText: 'something\n\nsomething\n\n',
+ wantHTML: 'something
something
',
+ wantText: 'something\n\nsomething\n\n',
},
'spacesAtEndOfLine': {
description: 'Collapse spaces that preceed/follow a newline',
input: 'something
something
',
- expectedHTML: 'something
something
',
- expectedText: 'something\nsomething\n\n',
+ wantHTML: 'something
something
',
+ wantText: 'something\nsomething\n\n',
},
'spacesAtEndOfLineP': {
description: 'Collapse spaces that preceed/follow a paragraph',
input: 'something something
',
- expectedHTML: 'something
something
',
- expectedText: 'something\n\nsomething\n\n',
+ wantHTML: 'something
something
',
+ wantText: 'something\n\nsomething\n\n',
},
'nonBreakingSpacesAfterNewlines': {
description: 'Don\'t collapse non-breaking spaces that follow a newline',
input: 'something
something
',
- expectedHTML: 'something
something
',
- expectedText: 'something\n something\n\n',
+ wantHTML: 'something
something
',
+ wantText: 'something\n something\n\n',
},
'nonBreakingSpacesAfterNewlinesP': {
description: 'Don\'t collapse non-breaking spaces that follow a paragraph',
input: 'something something
',
- expectedHTML: 'something
something
',
- expectedText: 'something\n\n something\n\n',
+ wantHTML: 'something
something
',
+ wantText: 'something\n\n something\n\n',
},
'collapseSpacesInsideElements': {
description: 'Preserve only one space when multiple are present',
input: 'Need more space s !
',
- expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n',
+ wantHTML: 'Need more space s !
',
+ wantText: 'Need more space s !\n\n',
},
'collapseSpacesAcrossNewlines': {
description: 'Newlines and multiple spaces across newlines should be collapsed',
@@ -155,14 +155,14 @@ const testImports = {
space
s
!
`,
- expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n',
+ wantHTML: 'Need more space s !
',
+ wantText: 'Need more space s !\n\n',
},
'multipleNewLinesAtBeginning': {
description: 'Multiple new lines and paragraphs at the beginning should be preserved',
input: '
first line
second line
',
- expectedHTML: '
first line
second line
',
- expectedText: '\n\n\n\nfirst line\n\nsecond line\n\n',
+ wantHTML: '
first line
second line
',
+ wantText: '\n\n\n\nfirst line\n\nsecond line\n\n',
},
'multiLineParagraph': {
description: 'A paragraph with multiple lines should not loose spaces when lines are combined',
@@ -172,8 +172,8 @@ const testImports = {
п р с т у ф х ц ч ш щ ю я ь
`,
- expectedHTML: 'а б в г ґ д е є ж з и і ї й к л м н о п р с т у ф х ц ч ш щ ю я ь
',
- expectedText: 'а б в г ґ д е є ж з и і ї й к л м н о п р с т у ф х ц ч ш щ ю я ь\n\n',
+ wantHTML: 'а б в г ґ д е є ж з и і ї й к л м н о п р с т у ф х ц ч ш щ ю я ь
',
+ wantText: 'а б в г ґ д е є ж з и і ї й к л м н о п р с т у ф х ц ч ш щ ю я ь\n\n',
},
'multiLineParagraphWithPre': {
// XXX why is there before "in"?
@@ -187,8 +187,8 @@ const testImports = {
п р с т у ф х ц ч ш щ ю я
ь
`,
- expectedHTML: 'а б в г ґ д е є ж з и і ї й к л м н о
multiple
lines
in
pre
п р с т у ф х ц ч ш щ ю я ь
',
- expectedText: 'а б в г ґ д е є ж з и і ї й к л м н о\nmultiple\n lines\n in\n pre\n\nп р с т у ф х ц ч ш щ ю я ь\n\n',
+ wantHTML: 'а б в г ґ д е є ж з и і ї й к л м н о
multiple
lines
in
pre
п р с т у ф х ц ч ш щ ю я ь
',
+ wantText: 'а б в г ґ д е є ж з и і ї й к л м н о\nmultiple\n lines\n in\n pre\n\nп р с т у ф х ц ч ш щ ю я ь\n\n',
},
'preIntroducesASpace': {
description: 'pre should be on a new line not preceeded by a space',
@@ -196,32 +196,32 @@ const testImports = {
1
preline
`,
- expectedHTML: '1
preline
',
- expectedText: '1\npreline\n\n\n',
+ wantHTML: '1
preline
',
+ wantText: '1\npreline\n\n\n',
},
'dontDeleteSpaceInsideElements': {
description: 'Preserve spaces inside elements',
input: 'Need more space s !
',
- expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n',
+ wantHTML: 'Need more space s !
',
+ wantText: 'Need more space s !\n\n',
},
'dontDeleteSpaceOutsideElements': {
description: 'Preserve spaces outside elements',
input: 'Need more space s !
',
- expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n',
+ wantHTML: 'Need more space s !
',
+ wantText: 'Need more space s !\n\n',
},
'dontDeleteSpaceAtEndOfElement': {
description: 'Preserve spaces at the end of an element',
input: 'Need more space s !
',
- expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n',
+ wantHTML: 'Need more space s !
',
+ wantText: 'Need more space s !\n\n',
},
'dontDeleteSpaceAtBeginOfElements': {
description: 'Preserve spaces at the start of an element',
input: 'Need more space s !
',
- expectedHTML: 'Need more space s !
',
- expectedText: 'Need more space s !\n\n',
+ wantHTML: 'Need more space s !
',
+ wantText: 'Need more space s !\n\n',
},
};
@@ -256,17 +256,17 @@ describe(__filename, function () {
it('getHTML', function (done) {
api.get(`${endPoint('getHTML')}&padID=${testPadId}`)
.expect((res) => {
- const receivedHtml = res.body.data.html;
- if (receivedHtml !== test.expectedHTML) {
+ const gotHtml = res.body.data.html;
+ if (gotHtml !== test.wantHTML) {
throw new Error(`HTML received from export is not the one we were expecting.
Test Name:
${testName}
- Received:
- ${JSON.stringify(receivedHtml)}
+ Got:
+ ${JSON.stringify(gotHtml)}
- Expected:
- ${JSON.stringify(test.expectedHTML)}
+ Want:
+ ${JSON.stringify(test.wantHTML)}
Which is a different version of the originally imported one:
${test.input}`);
@@ -279,17 +279,17 @@ describe(__filename, function () {
it('getText', function (done) {
api.get(`${endPoint('getText')}&padID=${testPadId}`)
.expect((res) => {
- const receivedText = res.body.data.text;
- if (receivedText !== test.expectedText) {
+ const gotText = res.body.data.text;
+ if (gotText !== test.wantText) {
throw new Error(`Text received from export is not the one we were expecting.
Test Name:
${testName}
- Received:
- ${JSON.stringify(receivedText)}
+ Got:
+ ${JSON.stringify(gotText)}
- Expected:
- ${JSON.stringify(test.expectedText)}
+ Want:
+ ${JSON.stringify(test.wantText)}
Which is a different version of the originally imported one:
${test.input}`);
diff --git a/tests/backend/specs/contentcollector.js b/tests/backend/specs/contentcollector.js
index 7014cac2a..c9ebb7482 100644
--- a/tests/backend/specs/contentcollector.js
+++ b/tests/backend/specs/contentcollector.js
@@ -18,17 +18,17 @@ const tests = {
nestedLi: {
description: 'Complex nested Li',
html: '- one
- 1.1
- two
',
- expectedLineAttribs: [
+ wantLineAttribs: [
'*0*1*2*3+1+3', '*0*4*2*5+1+3', '*0*1*2*5+1+3',
],
- expectedText: [
+ wantText: [
'*one', '*1.1', '*two',
],
},
complexNest: {
description: 'Complex list of different types',
html: '- item
- item1
- item2
',
- expectedLineAttribs: [
+ wantLineAttribs: [
'*0*1*2+1+3',
'*0*1*2+1+3',
'*0*1*2+1+1',
@@ -40,7 +40,7 @@ const tests = {
'*0*6*2*7+1+5',
'*0*6*2*7+1+5',
],
- expectedText: [
+ wantText: [
'*one',
'*two',
'*0',
@@ -56,142 +56,142 @@ const tests = {
ul: {
description: 'Tests if uls properly get attributes',
html: 'div
foo
',
- expectedLineAttribs: ['*0*1*2+1+1', '*0*1*2+1+1', '+3', '+3'],
- expectedText: ['*a', '*b', 'div', 'foo'],
+ wantLineAttribs: ['*0*1*2+1+1', '*0*1*2+1+1', '+3', '+3'],
+ wantText: ['*a', '*b', 'div', 'foo'],
},
ulIndented: {
description: 'Tests if indented uls properly get attributes',
html: 'foo
',
- expectedLineAttribs: ['*0*1*2+1+1', '*0*3*2+1+1', '*0*1*2+1+1', '+3'],
- expectedText: ['*a', '*b', '*a', 'foo'],
+ wantLineAttribs: ['*0*1*2+1+1', '*0*3*2+1+1', '*0*1*2+1+1', '+3'],
+ wantText: ['*a', '*b', '*a', 'foo'],
},
ol: {
description: 'Tests if ols properly get line numbers when in a normal OL',
html: '- a
- b
- c
test
',
- expectedLineAttribs: ['*0*1*2*3+1+1', '*0*1*2*3+1+1', '*0*1*2*3+1+1', '+4'],
- expectedText: ['*a', '*b', '*c', 'test'],
+ wantLineAttribs: ['*0*1*2*3+1+1', '*0*1*2*3+1+1', '*0*1*2*3+1+1', '+4'],
+ wantText: ['*a', '*b', '*c', 'test'],
noteToSelf: 'Ensure empty P does not induce line attribute marker, wont this break the editor?',
},
lineDoBreakInOl: {
description: 'A single completely empty line break within an ol should reset count if OL is closed off..',
html: '- should be 1
hello
- should be 1
- should be 2
',
- expectedLineAttribs: ['*0*1*2*3+1+b', '+5', '*0*1*2*4+1+b', '*0*1*2*4+1+b', ''],
- expectedText: ['*should be 1', 'hello', '*should be 1', '*should be 2', ''],
+ wantLineAttribs: ['*0*1*2*3+1+b', '+5', '*0*1*2*4+1+b', '*0*1*2*4+1+b', ''],
+ wantText: ['*should be 1', 'hello', '*should be 1', '*should be 2', ''],
noteToSelf: "Shouldn't include attribute marker in the line",
},
testP: {
description: 'A single
should create a new line',
html: '',
- expectedLineAttribs: ['', ''],
- expectedText: ['', ''],
+ wantLineAttribs: ['', ''],
+ wantText: ['', ''],
noteToSelf: 'should create a line break but not break numbering',
},
nestedOl: {
description: 'Tests if ols properly get line numbers when in a normal OL',
html: 'a- b
- c
notlistfoo
',
- expectedLineAttribs: ['+1', '*0*1*2*3+1+1', '*0*4*2*5+1+1', '+7', '+3'],
- expectedText: ['a', '*b', '*c', 'notlist', 'foo'],
+ wantLineAttribs: ['+1', '*0*1*2*3+1+1', '*0*4*2*5+1+1', '+7', '+3'],
+ wantText: ['a', '*b', '*c', 'notlist', 'foo'],
noteToSelf: 'Ensure empty P does not induce line attribute marker, wont this break the editor?',
},
nestedOl2: {
description: 'First item being an UL then subsequent being OL will fail',
html: '',
- expectedLineAttribs: ['+1', '*0*1*2*3+1+1', '*0*4*2*5+1+1'],
- expectedText: ['a', '*b', '*c'],
+ wantLineAttribs: ['+1', '*0*1*2*3+1+1', '*0*4*2*5+1+1'],
+ wantText: ['a', '*b', '*c'],
noteToSelf: 'Ensure empty P does not induce line attribute marker, wont this break the editor?',
disabled: true,
},
lineDontBreakOL: {
description: 'A single completely empty line break within an ol should NOT reset count',
html: '- should be 1
- should be 2
- should be 3
',
- expectedLineAttribs: [],
- expectedText: ['*should be 1', '*should be 2', '*should be 3'],
+ wantLineAttribs: [],
+ wantText: ['*should be 1', '*should be 2', '*should be 3'],
noteToSelf: "should create a line break but not break numbering -- This is what I can't get working!",
disabled: true,
},
ignoreAnyTagsOutsideBody: {
description: 'Content outside body should be ignored',
html: 'titleempty
',
- expectedLineAttribs: ['+5'],
- expectedText: ['empty'],
+ wantLineAttribs: ['+5'],
+ wantText: ['empty'],
},
lineWithMultipleSpaces: {
description: 'Multiple spaces should be preserved',
html: 'Text with more than one space.
',
- expectedLineAttribs: ['+10'],
- expectedText: ['Text with more than one space.'],
+ wantLineAttribs: ['+10'],
+ wantText: ['Text with more than one space.'],
},
lineWithMultipleNonBreakingAndNormalSpaces: {
description: 'non-breaking and normal space should be preserved',
html: 'Text with more than one space.
',
- expectedLineAttribs: ['+10'],
- expectedText: ['Text with more than one space.'],
+ wantLineAttribs: ['+10'],
+ wantText: ['Text with more than one space.'],
},
multiplenbsp: {
description: 'Multiple nbsp should be preserved',
html: '
',
- expectedLineAttribs: ['+2'],
- expectedText: [' '],
+ wantLineAttribs: ['+2'],
+ wantText: [' '],
},
multipleNonBreakingSpaceBetweenWords: {
description: 'Multiple nbsp between words ',
html: ' word1 word2 word3
',
- expectedLineAttribs: ['+m'],
- expectedText: [' word1 word2 word3'],
+ wantLineAttribs: ['+m'],
+ wantText: [' word1 word2 word3'],
},
nonBreakingSpacePreceededBySpaceBetweenWords: {
description: 'A non-breaking space preceeded by a normal space',
html: ' word1 word2 word3
',
- expectedLineAttribs: ['+l'],
- expectedText: [' word1 word2 word3'],
+ wantLineAttribs: ['+l'],
+ wantText: [' word1 word2 word3'],
},
nonBreakingSpaceFollowededBySpaceBetweenWords: {
description: 'A non-breaking space followed by a normal space',
html: ' word1 word2 word3
',
- expectedLineAttribs: ['+l'],
- expectedText: [' word1 word2 word3'],
+ wantLineAttribs: ['+l'],
+ wantText: [' word1 word2 word3'],
},
spacesAfterNewline: {
description: 'Don\'t collapse spaces that follow a newline',
html: 'something
something
',
- expectedLineAttribs: ['+9', '+m'],
- expectedText: ['something', ' something'],
+ wantLineAttribs: ['+9', '+m'],
+ wantText: ['something', ' something'],
},
spacesAfterNewlineP: {
description: 'Don\'t collapse spaces that follow a empty paragraph',
html: 'something something
',
- expectedLineAttribs: ['+9', '', '+m'],
- expectedText: ['something', '', ' something'],
+ wantLineAttribs: ['+9', '', '+m'],
+ wantText: ['something', '', ' something'],
},
spacesAtEndOfLine: {
description: 'Don\'t collapse spaces that preceed/follow a newline',
html: 'something
something
',
- expectedLineAttribs: ['+l', '+m'],
- expectedText: ['something ', ' something'],
+ wantLineAttribs: ['+l', '+m'],
+ wantText: ['something ', ' something'],
},
spacesAtEndOfLineP: {
description: 'Don\'t collapse spaces that preceed/follow a empty paragraph',
html: 'something something
',
- expectedLineAttribs: ['+l', '', '+m'],
- expectedText: ['something ', '', ' something'],
+ wantLineAttribs: ['+l', '', '+m'],
+ wantText: ['something ', '', ' something'],
},
nonBreakingSpacesAfterNewlines: {
description: 'Don\'t collapse non-breaking spaces that follow a newline',
html: 'something
something
',
- expectedLineAttribs: ['+9', '+c'],
- expectedText: ['something', ' something'],
+ wantLineAttribs: ['+9', '+c'],
+ wantText: ['something', ' something'],
},
nonBreakingSpacesAfterNewlinesP: {
description: 'Don\'t collapse non-breaking spaces that follow a paragraph',
html: 'something something
',
- expectedLineAttribs: ['+9', '', '+c'],
- expectedText: ['something', '', ' something'],
+ wantLineAttribs: ['+9', '', '+c'],
+ wantText: ['something', '', ' something'],
},
preserveSpacesInsideElements: {
description: 'Preserve all spaces when multiple are present',
html: 'Need more space s !
',
- expectedLineAttribs: ['+h*0+4+2'],
- expectedText: ['Need more space s !'],
+ wantLineAttribs: ['+h*0+4+2'],
+ wantText: ['Need more space s !'],
},
preserveSpacesAcrossNewlines: {
description: 'Newlines and multiple spaces across newlines should be preserved',
@@ -201,14 +201,14 @@ const tests = {
space
s
!