2019-09-23 23:18:30 +02:00
|
|
|
|
2020-11-05 18:58:23 +02:00
|
|
|
const { asyncTest, setupDatabaseAndSynchronizer, switchClient } = require('./test-utils.js');
|
|
|
|
const shim = require('@joplinapp/lib/shim').default;
|
|
|
|
const { enexXmlToHtml } = require('@joplinapp/lib/import-enex-html-gen.js');
|
2020-10-22 16:55:29 +02:00
|
|
|
const cleanHtml = require('clean-html');
|
2019-09-23 23:18:30 +02:00
|
|
|
|
|
|
|
process.on('unhandledRejection', (reason, p) => {
|
|
|
|
console.warn('Unhandled Rejection at: Promise', p, 'reason:', reason);
|
|
|
|
});
|
|
|
|
|
|
|
|
const fileWithPath = (filename) =>
|
|
|
|
`${__dirname}/enex_to_html/${filename}`;
|
|
|
|
|
|
|
|
const audioResource = {
|
|
|
|
filename: 'audio test',
|
|
|
|
id: '9168ee833d03c5ea7c730ac6673978c1',
|
|
|
|
mime: 'audio/x-m4a',
|
|
|
|
size: 82011,
|
|
|
|
title: 'audio test',
|
|
|
|
};
|
|
|
|
|
2020-10-22 16:55:29 +02:00
|
|
|
// All the test HTML files are beautified ones, so we need to run
|
|
|
|
// this before the comparison. Before, beautifying was done by `enexXmlToHtml`
|
|
|
|
// but that was removed due to problems with the clean-html package.
|
|
|
|
const beautifyHtml = (html) => {
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
try {
|
|
|
|
cleanHtml.clean(html, { wrap: 0 }, (...cleanedHtml) => resolve(cleanedHtml.join('')));
|
|
|
|
} catch (error) {
|
|
|
|
console.warn(`Could not clean HTML - the "unclean" version will be used: ${error.message}: ${html.trim().substr(0, 512).replace(/[\n\r]/g, ' ')}...`);
|
|
|
|
resolve([html].join(''));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2019-09-23 23:18:30 +02:00
|
|
|
/**
|
|
|
|
* Tests the importer for a single note, checking that the result of
|
|
|
|
* processing the given `.enex` input file matches the contents of the given
|
|
|
|
* `.html` file.
|
|
|
|
*
|
|
|
|
* Note that this does not test the importing of an entire exported `.enex`
|
|
|
|
* archive, but rather a single node of such a file. Thus, the test data files
|
|
|
|
* (e.g. `./enex_to_html/code1.enex`) correspond to the contents of a single
|
|
|
|
* `<note>...</note>` node in an `.enex` file already extracted from
|
|
|
|
* `<content><![CDATA[...]]</content>`.
|
|
|
|
*/
|
|
|
|
const compareOutputToExpected = (options) => {
|
|
|
|
const inputFile = fileWithPath(`${options.testName}.enex`);
|
|
|
|
const outputFile = fileWithPath(`${options.testName}.html`);
|
|
|
|
const testTitle = `should convert from Enex to Html: ${options.testName}`;
|
|
|
|
|
|
|
|
it(testTitle, asyncTest(async () => {
|
|
|
|
const enexInput = await shim.fsDriver().readFile(inputFile);
|
|
|
|
const expectedOutput = await shim.fsDriver().readFile(outputFile);
|
2020-10-22 16:55:29 +02:00
|
|
|
const actualOutput = await beautifyHtml(await enexXmlToHtml(enexInput, options.resources));
|
2019-09-23 23:18:30 +02:00
|
|
|
|
|
|
|
expect(actualOutput).toEqual(expectedOutput);
|
|
|
|
}));
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('EnexToHtml', function() {
|
|
|
|
beforeEach(async (done) => {
|
|
|
|
await setupDatabaseAndSynchronizer(1);
|
|
|
|
await switchClient(1);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
compareOutputToExpected({
|
|
|
|
testName: 'checklist-list',
|
|
|
|
resources: [],
|
|
|
|
});
|
|
|
|
|
|
|
|
compareOutputToExpected({
|
|
|
|
testName: 'svg',
|
|
|
|
resources: [],
|
|
|
|
});
|
|
|
|
|
|
|
|
compareOutputToExpected({
|
|
|
|
testName: 'en-media--image',
|
|
|
|
resources: [{
|
|
|
|
filename: '',
|
|
|
|
id: '89ce7da62c6b2832929a6964237e98e9', // Mock id
|
|
|
|
mime: 'image/jpeg',
|
|
|
|
size: 50347,
|
|
|
|
title: '',
|
|
|
|
}],
|
|
|
|
});
|
|
|
|
|
|
|
|
compareOutputToExpected({
|
|
|
|
testName: 'en-media--audio',
|
|
|
|
resources: [audioResource],
|
|
|
|
});
|
|
|
|
|
|
|
|
compareOutputToExpected({
|
|
|
|
testName: 'attachment',
|
|
|
|
resources: [{
|
|
|
|
filename: 'attachment-1',
|
|
|
|
id: '21ca2b948f222a38802940ec7e2e5de3',
|
|
|
|
mime: 'application/pdf', // Any non-image/non-audio mime type will do
|
|
|
|
size: 1000,
|
|
|
|
}],
|
|
|
|
});
|
|
|
|
|
2020-06-15 18:10:51 +02:00
|
|
|
// it('fails when not given a matching resource', asyncTest(async () => {
|
|
|
|
// // To test the promise-unexpectedly-resolved case, add `audioResource` to the array.
|
|
|
|
// const resources = [];
|
|
|
|
// const inputFile = fileWithPath('en-media--image.enex');
|
|
|
|
// const enexInput = await shim.fsDriver().readFile(inputFile);
|
|
|
|
// const promisedOutput = enexXmlToHtml(enexInput, resources);
|
|
|
|
|
|
|
|
// promisedOutput.then(() => {
|
|
|
|
// // Promise should not be resolved
|
|
|
|
// expect(false).toEqual(true);
|
|
|
|
// }, (reason) => {
|
|
|
|
// expect(reason)
|
|
|
|
// .toBe('Hash with no associated resource: 89ce7da62c6b2832929a6964237e98e9');
|
|
|
|
// });
|
|
|
|
// }));
|
2019-09-23 23:18:30 +02:00
|
|
|
|
|
|
|
});
|