mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-24 10:27:10 +02:00
3d8577a689
- For now, supports Markdown-it plugins - Also fixed slow rendering of notes in some cases - Simplified how Markdown-It plugins are created and cleaned MdToHtml code commit89576de289
Merge:c75aa21f
5292fc14
Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:23:00 2020 +0100 Merge branch 'release-1.3' into plugin_content_scripts commitc75aa21ffd
Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:19:52 2020 +0100 Fixed tests commit075187729d
Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:11:53 2020 +0100 Fixed tests commit14696b8c65
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 23:27:58 2020 +0100 Fixed slow rendering of note commit61c09f5bf8
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 22:35:21 2020 +0100 Clean up commit9f7ea7d865
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 20:05:31 2020 +0100 Updated doc commit98bf3bde8d
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 19:56:34 2020 +0100 Finished converting plugins commitfe90d92e01
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 17:52:02 2020 +0100 Simplified how Markdown-It plugins are created commit47c7b864cb
Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 16:40:11 2020 +0100 Clean up rules commitd927a238bb
Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 14:29:40 2020 +0100 Fixed tests commit388a56c5dd
Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 14:00:47 2020 +0100 Add support for content scripts
143 lines
4.4 KiB
TypeScript
143 lines
4.4 KiB
TypeScript
const os = require('os');
|
|
const { filename } = require('lib/path-utils');
|
|
const { asyncTest, setupDatabaseAndSynchronizer, switchClient } = require('test-utils.js');
|
|
const shim = require('lib/shim').default;
|
|
const MdToHtml = require('lib/joplin-renderer/MdToHtml').default;
|
|
const { themeStyle } = require('lib/theme');
|
|
|
|
function newTestMdToHtml(options:any = null) {
|
|
options = {
|
|
ResourceModel: {
|
|
isResourceUrl: () => false,
|
|
},
|
|
fsDriver: shim.fsDriver(),
|
|
...options,
|
|
};
|
|
|
|
return new MdToHtml(options);
|
|
}
|
|
|
|
describe('MdToHtml', function() {
|
|
|
|
beforeEach(async (done:Function) => {
|
|
await setupDatabaseAndSynchronizer(1);
|
|
await switchClient(1);
|
|
done();
|
|
});
|
|
|
|
it('should convert from Markdown to Html', asyncTest(async () => {
|
|
const basePath = `${__dirname}/md_to_html`;
|
|
const files = await shim.fsDriver().readDirStats(basePath);
|
|
const mdToHtml = newTestMdToHtml();
|
|
|
|
for (let i = 0; i < files.length; i++) {
|
|
const mdFilename = files[i].path;
|
|
if (mdFilename.indexOf('.md') < 0) continue;
|
|
|
|
const mdFilePath = `${basePath}/${mdFilename}`;
|
|
const htmlPath = `${basePath}/${filename(mdFilePath)}.html`;
|
|
|
|
// if (mdFilename !== 'sanitize_9.md') continue;
|
|
|
|
const mdToHtmlOptions:any = {
|
|
bodyOnly: true,
|
|
};
|
|
|
|
if (mdFilename === 'checkbox_alternative.md') {
|
|
mdToHtmlOptions.plugins = {
|
|
checkbox: {
|
|
checkboxRenderingType: 2,
|
|
},
|
|
};
|
|
}
|
|
|
|
const markdown = await shim.fsDriver().readFile(mdFilePath);
|
|
let expectedHtml = await shim.fsDriver().readFile(htmlPath);
|
|
|
|
const result = await mdToHtml.render(markdown, null, mdToHtmlOptions);
|
|
let actualHtml = result.html;
|
|
|
|
if (os.EOL === '\r\n') {
|
|
expectedHtml = expectedHtml.replace(/\r\n/g, '\n');
|
|
actualHtml = actualHtml.replace(/\r\n/g, '\n');
|
|
}
|
|
|
|
if (actualHtml !== expectedHtml) {
|
|
console.info('');
|
|
console.info(`Error converting file: ${mdFilename}`);
|
|
console.info('--------------------------------- Got:');
|
|
console.info(actualHtml);
|
|
console.info('--------------------------------- Raw:');
|
|
console.info(actualHtml.split('\n'));
|
|
console.info('--------------------------------- Expected:');
|
|
console.info(expectedHtml.split('\n'));
|
|
console.info('--------------------------------------------');
|
|
console.info('');
|
|
|
|
expect(false).toBe(true);
|
|
// return;
|
|
} else {
|
|
expect(true).toBe(true);
|
|
}
|
|
}
|
|
}));
|
|
|
|
it('should return enabled plugin assets', asyncTest(async () => {
|
|
const pluginOptions:any = {};
|
|
const pluginNames = MdToHtml.pluginNames();
|
|
|
|
for (const n of pluginNames) pluginOptions[n] = { enabled: false };
|
|
|
|
{
|
|
const mdToHtml = newTestMdToHtml({ pluginOptions: pluginOptions });
|
|
const assets = await mdToHtml.allAssets(themeStyle(1));
|
|
expect(assets.length).toBe(1); // Base note style should always be returned
|
|
}
|
|
|
|
{
|
|
pluginOptions['checkbox'].enabled = true;
|
|
const mdToHtml = newTestMdToHtml({ pluginOptions: pluginOptions });
|
|
|
|
const assets = await mdToHtml.allAssets(themeStyle(1));
|
|
expect(assets.length).toBe(2);
|
|
expect(assets[1].mime).toBe('text/css');
|
|
|
|
const content = await shim.fsDriver().readFile(assets[1].path);
|
|
expect(content.indexOf('joplin-checklist') >= 0).toBe(true);
|
|
}
|
|
}));
|
|
|
|
it('should wrapped the rendered Markdown', asyncTest(async () => {
|
|
const mdToHtml = newTestMdToHtml();
|
|
|
|
// In this case, the HTML contains both the style and
|
|
// the rendered markdown wrapped in a DIV.
|
|
const result = await mdToHtml.render('just **testing**');
|
|
expect(result.cssStrings.length).toBeGreaterThan(0);
|
|
expect(result.html.indexOf('rendered-md') >= 0).toBe(true);
|
|
}));
|
|
|
|
it('should return the rendered body only', asyncTest(async () => {
|
|
const mdToHtml = newTestMdToHtml();
|
|
|
|
// In this case, the HTML contains only the rendered markdown,
|
|
// with no wrapper and no style.
|
|
// The style is instead in the cssStrings property.
|
|
const result = await mdToHtml.render('just **testing**', null, { bodyOnly: true });
|
|
expect(result.cssStrings.length).toBeGreaterThan(0);
|
|
expect(result.html.trim()).toBe('just <strong>testing</strong>');
|
|
}));
|
|
|
|
it('should split HTML and CSS', asyncTest(async () => {
|
|
const mdToHtml = newTestMdToHtml();
|
|
|
|
// It is similar to the bodyOnly option, excepts that
|
|
// the rendered Markdown is wrapped in a DIV
|
|
const result = await mdToHtml.render('just **testing**', null, { splitted: true });
|
|
expect(result.cssStrings.length).toBeGreaterThan(0);
|
|
expect(result.html.trim()).toBe('<div id="rendered-md"><p>just <strong>testing</strong></p>\n</div>');
|
|
}));
|
|
|
|
|
|
});
|