Markdown parser, done right. 100% CommonMark support, extensions, syntax plugins & high speed
https://markdown-it.github.io/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
255 lines
7.4 KiB
255 lines
7.4 KiB
'use strict';
|
|
|
|
|
|
var assert = require('assert');
|
|
var markdownit = require('../');
|
|
|
|
|
|
describe('Utils', function () {
|
|
|
|
it('fromCodePoint', function () {
|
|
var fromCodePoint = require('../lib/common/utils').fromCodePoint;
|
|
|
|
assert.strictEqual(fromCodePoint(0x20), ' ');
|
|
assert.strictEqual(fromCodePoint(0x1F601), '😁');
|
|
});
|
|
|
|
it('isValidEntityCode', function () {
|
|
var isValidEntityCode = require('../lib/common/utils').isValidEntityCode;
|
|
|
|
assert.strictEqual(isValidEntityCode(0x20), true);
|
|
assert.strictEqual(isValidEntityCode(0xD800), false);
|
|
assert.strictEqual(isValidEntityCode(0xFDD0), false);
|
|
assert.strictEqual(isValidEntityCode(0x1FFFF), false);
|
|
assert.strictEqual(isValidEntityCode(0x1FFFE), false);
|
|
assert.strictEqual(isValidEntityCode(0x00), false);
|
|
assert.strictEqual(isValidEntityCode(0x0B), false);
|
|
assert.strictEqual(isValidEntityCode(0x0E), false);
|
|
assert.strictEqual(isValidEntityCode(0x7F), false);
|
|
});
|
|
|
|
it('replaceEntities', function () {
|
|
var replaceEntities = require('../lib/common/utils').replaceEntities;
|
|
|
|
assert.strictEqual(replaceEntities('&'), '&');
|
|
assert.strictEqual(replaceEntities(' '), ' ');
|
|
assert.strictEqual(replaceEntities(' '), ' ');
|
|
assert.strictEqual(replaceEntities('&&'), '&&');
|
|
|
|
assert.strictEqual(replaceEntities('&am;'), '&am;');
|
|
assert.strictEqual(replaceEntities('�'), '�');
|
|
});
|
|
|
|
it('assign', function () {
|
|
var assign = require('../lib/common/utils').assign;
|
|
|
|
assert.deepEqual(assign({ a: 1 }, null, { b: 2 }), { a: 1, b: 2 });
|
|
assert.throws(function () {
|
|
assign({}, 123);
|
|
});
|
|
});
|
|
|
|
});
|
|
|
|
|
|
describe('API', function () {
|
|
|
|
it('constructor', function () {
|
|
assert.throws(function () {
|
|
var md = markdownit('bad preset');
|
|
md.render('123');
|
|
});
|
|
});
|
|
|
|
it('configure coverage', function () {
|
|
var md = markdownit();
|
|
|
|
// conditions coverage
|
|
md.configure({});
|
|
|
|
assert.strictEqual(md.render('123'), '<p>123</p>\n');
|
|
});
|
|
|
|
it('plugin', function () {
|
|
var succeeded = false;
|
|
|
|
function plugin(self, opts) { if (opts === 'bar') { succeeded = true; } }
|
|
|
|
var md = markdownit();
|
|
|
|
md.use(plugin, 'foo');
|
|
assert.strictEqual(succeeded, false);
|
|
md.use(plugin, 'bar');
|
|
assert.strictEqual(succeeded, true);
|
|
});
|
|
|
|
it('highlight', function () {
|
|
var md = markdownit({
|
|
highlight: function (str) {
|
|
return '==' + str + '==';
|
|
}
|
|
});
|
|
|
|
assert.strictEqual(md.render('```\nhl\n```'), '<pre><code>==hl\n==</code></pre>\n');
|
|
});
|
|
|
|
it('highlight escape by default', function () {
|
|
var md = markdownit({
|
|
highlight: function () {
|
|
return '';
|
|
}
|
|
});
|
|
|
|
assert.strictEqual(md.render('```\n&\n```'), '<pre><code>&\n</code></pre>\n');
|
|
});
|
|
|
|
it('force hardbreaks', function () {
|
|
var md = markdownit({ breaks: true });
|
|
|
|
assert.strictEqual(md.render('a\nb'), '<p>a<br>\nb</p>\n');
|
|
md.set({ xhtmlOut: true });
|
|
assert.strictEqual(md.render('a\nb'), '<p>a<br />\nb</p>\n');
|
|
});
|
|
|
|
it('xhtmlOut enabled', function () {
|
|
var md = markdownit({ xhtmlOut: true });
|
|
|
|
assert.strictEqual(md.render('---'), '<hr />\n');
|
|
assert.strictEqual(md.render('![]()'), '<p><img src="" alt="" /></p>\n');
|
|
assert.strictEqual(md.render('a \\\nb'), '<p>a <br />\nb</p>\n');
|
|
});
|
|
|
|
it('xhtmlOut disabled', function () {
|
|
var md = markdownit();
|
|
|
|
assert.strictEqual(md.render('---'), '<hr>\n');
|
|
assert.strictEqual(md.render('![]()'), '<p><img src="" alt=""></p>\n');
|
|
assert.strictEqual(md.render('a \\\nb'), '<p>a <br>\nb</p>\n');
|
|
});
|
|
|
|
it('bulk enable/disable rules in different chains', function () {
|
|
var md = markdownit();
|
|
|
|
var was = {
|
|
core: md.core.ruler.getRules('').length,
|
|
block: md.block.ruler.getRules('').length,
|
|
inline: md.inline.ruler.getRules('').length
|
|
};
|
|
|
|
// Disable 2 rule in each chain & compare result
|
|
md.disable([ 'block', 'inline', 'code', 'fence', 'emphasis', 'entity' ]);
|
|
|
|
var now = {
|
|
core: md.core.ruler.getRules('').length + 2,
|
|
block: md.block.ruler.getRules('').length + 2,
|
|
inline: md.inline.ruler.getRules('').length + 2
|
|
};
|
|
|
|
assert.deepEqual(was, now);
|
|
|
|
// Enable the same rules back
|
|
md.enable([ 'block', 'inline', 'code', 'fence', 'emphasis', 'entity' ]);
|
|
|
|
var back = {
|
|
core: md.core.ruler.getRules('').length,
|
|
block: md.block.ruler.getRules('').length,
|
|
inline: md.inline.ruler.getRules('').length
|
|
};
|
|
|
|
assert.deepEqual(was, back);
|
|
});
|
|
|
|
it('bulk enable/dusable with errors control', function () {
|
|
var md = markdownit();
|
|
|
|
assert.throws(function () {
|
|
md.enable([ 'link', 'code', 'invalid' ]);
|
|
});
|
|
assert.throws(function () {
|
|
md.disable([ 'link', 'code', 'invalid' ]);
|
|
});
|
|
assert.doesNotThrow(function () {
|
|
md.enable([ 'link', 'code' ]);
|
|
});
|
|
assert.doesNotThrow(function () {
|
|
md.disable([ 'link', 'code' ]);
|
|
});
|
|
});
|
|
|
|
});
|
|
|
|
|
|
describe('Misc', function () {
|
|
|
|
it('Should strip (or replace) NULL characters', function () {
|
|
var md = markdownit();
|
|
|
|
assert.strictEqual(md.render('foo\u0000bar'), '<p>foo\uFFFDbar</p>\n');
|
|
});
|
|
|
|
it('Should correctly parse strings without tailing \\n', function () {
|
|
var md = markdownit();
|
|
|
|
assert.strictEqual(md.render('123'), '<p>123</p>\n');
|
|
assert.strictEqual(md.render('123\n'), '<p>123</p>\n');
|
|
});
|
|
|
|
it('Should quickly exit on empty string', function () {
|
|
var md = markdownit();
|
|
|
|
assert.strictEqual(md.render(''), '');
|
|
});
|
|
|
|
it('Should parse inlines only', function () {
|
|
var md = markdownit();
|
|
|
|
assert.strictEqual(md.renderInline('a *b* c'), 'a <em>b</em> c');
|
|
});
|
|
|
|
it('Renderer should have pluggable inline and block rules', function () {
|
|
var md = markdownit();
|
|
|
|
md.renderer.rules.em_open = function () { return '<it>'; };
|
|
md.renderer.rules.em_close = function () { return '</it>'; };
|
|
md.renderer.rules.paragraph_open = function () { return '<par>'; };
|
|
md.renderer.rules.paragraph_close = function () { return '</par>'; };
|
|
|
|
assert.strictEqual(md.render('*b*'), '<par><it>b</it></par>');
|
|
});
|
|
|
|
it('Zero preset should disable everything', function () {
|
|
var md = markdownit('zero');
|
|
|
|
assert.strictEqual(md.render('___foo___'), '<p>___foo___</p>\n');
|
|
assert.strictEqual(md.renderInline('___foo___'), '___foo___');
|
|
|
|
md.enable('emphasis');
|
|
|
|
assert.strictEqual(md.render('___foo___'), '<p><strong><em>foo</em></strong></p>\n');
|
|
assert.strictEqual(md.renderInline('___foo___'), '<strong><em>foo</em></strong>');
|
|
});
|
|
|
|
it('Should correctly check block termination rules ahen those are disabled (#13)', function () {
|
|
var md = markdownit('zero');
|
|
|
|
assert.strictEqual(md.render('foo\nbar'), '<p>foo\nbar</p>\n');
|
|
});
|
|
|
|
});
|
|
|
|
|
|
describe('Links validation', function () {
|
|
|
|
it('Override validator, disable everything', function () {
|
|
var md = markdownit({ linkify: true });
|
|
|
|
md.inline.validateLink = function () { return false; };
|
|
|
|
assert.strictEqual(md.render('foo@example.com'), '<p>foo@example.com</p>\n');
|
|
assert.strictEqual(md.render('http://example.com'), '<p>http://example.com</p>\n');
|
|
assert.strictEqual(md.render('<foo@example.com>'), '<p><foo@example.com></p>\n');
|
|
assert.strictEqual(md.render('<http://example.com>'), '<p><http://example.com></p>\n');
|
|
assert.strictEqual(md.render('[test](http://example.com)'), '<p>[test](http://example.com)</p>\n');
|
|
});
|
|
|
|
});
|
|
|