mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-04-25 01:46:14 -04:00
Converted tests to typescript. (#6181)
* Converted tests to typescript. * Run all tests. * Fixed tests. * Removed cypress from every installation. * Use cache for libreoffice. * Fixed cypress install. * Fixed cypress install.
This commit is contained in:
parent
4bd27a1c79
commit
546ede284c
45 changed files with 912 additions and 734 deletions
143
src/tests/backend/specs/Pad.ts
Normal file
143
src/tests/backend/specs/Pad.ts
Normal file
|
@ -0,0 +1,143 @@
|
|||
'use strict';
|
||||
|
||||
import {PadType} from "../../../node/types/PadType";
|
||||
|
||||
const Pad = require('../../../node/db/Pad');
|
||||
import { strict as assert } from 'assert';
|
||||
import {MapArrayType} from "../../../node/types/MapType";
|
||||
const authorManager = require('../../../node/db/AuthorManager');
|
||||
const common = require('../common');
|
||||
const padManager = require('../../../node/db/PadManager');
|
||||
const plugins = require('../../../static/js/pluginfw/plugin_defs');
|
||||
const settings = require('../../../node/utils/Settings');
|
||||
|
||||
describe(__filename, function () {
|
||||
const backups:MapArrayType<any> = {};
|
||||
let pad: PadType|null;
|
||||
let padId: string;
|
||||
|
||||
before(async function () {
|
||||
backups.hooks = {
|
||||
padDefaultContent: plugins.hooks.padDefaultContent,
|
||||
};
|
||||
backups.defaultPadText = settings.defaultPadText;
|
||||
});
|
||||
|
||||
beforeEach(async function () {
|
||||
backups.hooks.padDefaultContent = [];
|
||||
padId = common.randomString();
|
||||
assert(!(await padManager.doesPadExist(padId)));
|
||||
});
|
||||
|
||||
afterEach(async function () {
|
||||
Object.assign(plugins.hooks, backups.hooks);
|
||||
if (pad != null) await pad.remove();
|
||||
pad = null;
|
||||
});
|
||||
|
||||
describe('cleanText', function () {
|
||||
const testCases = [
|
||||
['', ''],
|
||||
['\n', '\n'],
|
||||
['x', 'x'],
|
||||
['x\n', 'x\n'],
|
||||
['x\ny\n', 'x\ny\n'],
|
||||
['x\ry\n', 'x\ny\n'],
|
||||
['x\r\ny\n', 'x\ny\n'],
|
||||
['x\r\r\ny\n', 'x\n\ny\n'],
|
||||
];
|
||||
for (const [input, want] of testCases) {
|
||||
it(`${JSON.stringify(input)} -> ${JSON.stringify(want)}`, async function () {
|
||||
assert.equal(Pad.cleanText(input), want);
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
describe('padDefaultContent hook', function () {
|
||||
it('runs when a pad is created without specific text', async function () {
|
||||
const p = new Promise<void>((resolve) => {
|
||||
plugins.hooks.padDefaultContent.push({hook_fn: () => resolve()});
|
||||
});
|
||||
pad = await padManager.getPad(padId);
|
||||
await p;
|
||||
});
|
||||
|
||||
it('not run if pad is created with specific text', async function () {
|
||||
plugins.hooks.padDefaultContent.push(
|
||||
{hook_fn: () => { throw new Error('should not be called'); }});
|
||||
pad = await padManager.getPad(padId, '');
|
||||
});
|
||||
|
||||
it('defaults to settings.defaultPadText', async function () {
|
||||
const p = new Promise<void>((resolve, reject) => {
|
||||
plugins.hooks.padDefaultContent.push({hook_fn: async (hookName:string, ctx:any) => {
|
||||
try {
|
||||
assert.equal(ctx.type, 'text');
|
||||
assert.equal(ctx.content, settings.defaultPadText);
|
||||
} catch (err) {
|
||||
return reject(err);
|
||||
}
|
||||
resolve();
|
||||
}});
|
||||
});
|
||||
pad = await padManager.getPad(padId);
|
||||
await p;
|
||||
});
|
||||
|
||||
it('passes the pad object', async function () {
|
||||
const gotP = new Promise((resolve) => {
|
||||
plugins.hooks.padDefaultContent.push({hook_fn: async (hookName:string, {pad}:{
|
||||
pad: PadType,
|
||||
}) => resolve(pad)});
|
||||
});
|
||||
pad = await padManager.getPad(padId);
|
||||
assert.equal(await gotP, pad);
|
||||
});
|
||||
|
||||
it('passes empty authorId if not provided', async function () {
|
||||
const gotP = new Promise((resolve) => {
|
||||
plugins.hooks.padDefaultContent.push(
|
||||
{hook_fn: async (hookName:string, {authorId}:{
|
||||
authorId: string,
|
||||
}) => resolve(authorId)});
|
||||
});
|
||||
pad = await padManager.getPad(padId);
|
||||
assert.equal(await gotP, '');
|
||||
});
|
||||
|
||||
it('passes provided authorId', async function () {
|
||||
const want = await authorManager.getAuthor4Token(`t.${padId}`);
|
||||
const gotP = new Promise((resolve) => {
|
||||
plugins.hooks.padDefaultContent.push(
|
||||
{hook_fn: async (hookName: string, {authorId}:{
|
||||
authorId: string,
|
||||
}) => resolve(authorId)});
|
||||
});
|
||||
pad = await padManager.getPad(padId, null, want);
|
||||
assert.equal(await gotP, want);
|
||||
});
|
||||
|
||||
it('uses provided content', async function () {
|
||||
const want = 'hello world';
|
||||
assert.notEqual(want, settings.defaultPadText);
|
||||
plugins.hooks.padDefaultContent.push({hook_fn: async (hookName:string, ctx:any) => {
|
||||
ctx.type = 'text';
|
||||
ctx.content = want;
|
||||
}});
|
||||
pad = await padManager.getPad(padId);
|
||||
assert.equal(pad!.text(), `${want}\n`);
|
||||
});
|
||||
|
||||
it('cleans provided content', async function () {
|
||||
const input = 'foo\r\nbar\r\tbaz';
|
||||
const want = 'foo\nbar\n baz';
|
||||
assert.notEqual(want, settings.defaultPadText);
|
||||
plugins.hooks.padDefaultContent.push({hook_fn: async (hookName:string, ctx:any) => {
|
||||
ctx.type = 'text';
|
||||
ctx.content = input;
|
||||
}});
|
||||
pad = await padManager.getPad(padId);
|
||||
assert.equal(pad!.text(), `${want}\n`);
|
||||
});
|
||||
});
|
||||
});
|
Loading…
Add table
Add a link
Reference in a new issue