fix accidental write to global variable

properly show pending tests
log test name in suite
better log output for received/expected strings
This commit is contained in:
webzwo0i 2020-12-18 06:30:03 +01:00 committed by John McLear
parent d9b7aa489d
commit c989a8e279

View file

@ -1,3 +1,4 @@
'use strict';
/* /*
* ACHTUNG: there is a copied & modified version of this file in * ACHTUNG: there is a copied & modified version of this file in
* <basedir>/tests/container/spacs/api/pad.js * <basedir>/tests/container/spacs/api/pad.js
@ -5,6 +6,8 @@
* TODO: unify those two files, and merge in a single one. * TODO: unify those two files, and merge in a single one.
*/ */
/* eslint-disable max-len */
const common = require('../../common'); const common = require('../../common');
const supertest = require(`${__dirname}/../../../../src/node_modules/supertest`); const supertest = require(`${__dirname}/../../../../src/node_modules/supertest`);
const settings = require(`${__dirname}/../../../../tests/container/loadSettings.js`).loadSettings(); const settings = require(`${__dirname}/../../../../tests/container/loadSettings.js`).loadSettings();
@ -12,7 +15,6 @@ const api = supertest(`http://${settings.ip}:${settings.port}`);
const apiKey = common.apiKey; const apiKey = common.apiKey;
const apiVersion = 1; const apiVersion = 1;
const lastEdited = '';
const testImports = { const testImports = {
'malformed': { 'malformed': {
@ -59,8 +61,13 @@ const testImports = {
describe(__filename, function () { describe(__filename, function () {
Object.keys(testImports).forEach((testName) => { Object.keys(testImports).forEach((testName) => {
const testPadId = makeid(); const testPadId = makeid();
test = testImports[testName]; const test = testImports[testName];
describe('createPad', function () { if (test.disabled) {
return xit(`DISABLED: ${testName}`, function (done) {
done();
});
}
describe(`createPad ${testName}`, function () {
it('creates a new Pad', function (done) { it('creates a new Pad', function (done) {
api.get(`${endPoint('createPad')}&padID=${testPadId}`) api.get(`${endPoint('createPad')}&padID=${testPadId}`)
.expect((res) => { .expect((res) => {
@ -71,9 +78,9 @@ describe(__filename, function () {
}); });
}); });
describe('setHTML', function () { describe(`setHTML ${testName}`, function () {
it('Sets the HTML', function (done) { it('Sets the HTML', function (done) {
api.get(`${endPoint('setHTML')}&padID=${testPadId}&html=${test.input}`) api.get(`${endPoint('setHTML')}&padID=${testPadId}&html=${encodeURIComponent(test.input)}`)
.expect((res) => { .expect((res) => {
if (res.body.code !== 0) throw new Error(`Error:${testName}`); if (res.body.code !== 0) throw new Error(`Error:${testName}`);
}) })
@ -82,7 +89,7 @@ describe(__filename, function () {
}); });
}); });
describe('getHTML', function () { describe(`getHTML ${testName}`, function () {
it('Gets back the HTML of a Pad', function (done) { it('Gets back the HTML of a Pad', function (done) {
api.get(`${endPoint('getHTML')}&padID=${testPadId}`) api.get(`${endPoint('getHTML')}&padID=${testPadId}`)
.expect((res) => { .expect((res) => {
@ -93,10 +100,10 @@ describe(__filename, function () {
${testName} ${testName}
Received: Received:
${receivedHtml} ${JSON.stringify(receivedHtml)}
Expected: Expected:
${test.expectedHTML} ${JSON.stringify(test.expectedHTML)}
Which is a different version of the originally imported one: Which is a different version of the originally imported one:
${test.input}`); ${test.input}`);
@ -107,7 +114,7 @@ describe(__filename, function () {
}); });
}); });
describe('getText', function () { describe(`getText ${testName}`, function () {
it('Gets back the Text of a Pad', function (done) { it('Gets back the Text of a Pad', function (done) {
api.get(`${endPoint('getText')}&padID=${testPadId}`) api.get(`${endPoint('getText')}&padID=${testPadId}`)
.expect((res) => { .expect((res) => {
@ -118,10 +125,10 @@ describe(__filename, function () {
${testName} ${testName}
Received: Received:
${receivedText} ${JSON.stringify(receivedText)}
Expected: Expected:
${test.expectedText} ${JSON.stringify(test.expectedText)}
Which is a different version of the originally imported one: Which is a different version of the originally imported one:
${test.input}`); ${test.input}`);
@ -135,7 +142,7 @@ describe(__filename, function () {
}); });
var endPoint = function (point, version) { function endPoint(point, version) {
version = version || apiVersion; version = version || apiVersion;
return `/api/${version}/${point}?apikey=${apiKey}`; return `/api/${version}/${point}?apikey=${apiKey}`;
}; };
@ -149,32 +156,3 @@ function makeid() {
} }
return text; return text;
} }
function generateLongText() {
let text = '';
const possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
for (let i = 0; i < 80000; i++) {
text += possible.charAt(Math.floor(Math.random() * possible.length));
}
return text;
}
// Need this to compare arrays (listSavedRevisions test)
Array.prototype.equals = function (array) {
// if the other array is a falsy value, return
if (!array) return false;
// compare lengths - can save a lot of time
if (this.length != array.length) return false;
for (let i = 0, l = this.length; i < l; i++) {
// Check if we have nested arrays
if (this[i] instanceof Array && array[i] instanceof Array) {
// recurse into the nested arrays
if (!this[i].equals(array[i])) return false;
} else if (this[i] != array[i]) {
// Warning - two different object instances will never be equal: {x:20} != {x:20}
return false;
}
}
return true;
};