mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-02 12:47:41 +02:00
109 lines
3.2 KiB
JavaScript
109 lines
3.2 KiB
JavaScript
|
require('app-module-path').addPath(__dirname);
|
||
|
|
||
|
const { asyncTest, setupDatabaseAndSynchronizer, switchClient } = require('test-utils.js');
|
||
|
const { shim } = require('lib/shim');
|
||
|
const { enexXmlToHtml } = require('lib/import-enex-html-gen.js');
|
||
|
|
||
|
jasmine.DEFAULT_TIMEOUT_INTERVAL = 60 * 60 * 1000; // Can run for a while since everything is in the same test unit
|
||
|
|
||
|
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',
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* 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);
|
||
|
const actualOutput = await enexXmlToHtml(enexInput, options.resources);
|
||
|
|
||
|
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,
|
||
|
}],
|
||
|
});
|
||
|
|
||
|
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');
|
||
|
});
|
||
|
}));
|
||
|
|
||
|
});
|