2018-05-17 17:21:19 -07:00
|
|
|
import * as assert from 'assert';
|
2021-04-01 18:36:11 -07:00
|
|
|
import * as mfm from 'mfm-js';
|
2017-02-11 08:03:57 -08:00
|
|
|
|
2022-09-17 11:27:08 -07:00
|
|
|
import { toHtml } from '../../src/mfm/to-html.js';
|
|
|
|
import { fromHtml } from '../../src/mfm/from-html.js';
|
2018-11-20 12:11:00 -08:00
|
|
|
|
2021-04-01 18:36:11 -07:00
|
|
|
describe('toHtml', () => {
|
|
|
|
it('br', () => {
|
|
|
|
const input = 'foo\nbar\nbaz';
|
|
|
|
const output = '<p><span>foo<br>bar<br>baz</span></p>';
|
|
|
|
assert.equal(toHtml(mfm.parse(input)), output);
|
2018-11-20 12:11:00 -08:00
|
|
|
});
|
2020-05-15 16:40:17 -07:00
|
|
|
|
2021-04-01 18:36:11 -07:00
|
|
|
it('br alt', () => {
|
|
|
|
const input = 'foo\r\nbar\rbaz';
|
|
|
|
const output = '<p><span>foo<br>bar<br>baz</span></p>';
|
|
|
|
assert.equal(toHtml(mfm.parse(input)), output);
|
2020-05-15 16:40:17 -07:00
|
|
|
});
|
2016-12-29 20:28:56 -08:00
|
|
|
});
|
2020-11-07 07:38:50 -08:00
|
|
|
|
|
|
|
describe('fromHtml', () => {
|
2021-09-25 09:57:38 -07:00
|
|
|
it('p', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a</p><p>b</p>'), 'a\n\nb');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('block element', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<div>a</div><div>b</div>'), 'a\nb');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('inline element', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<ul><li>a</li><li>b</li></ul>'), 'a\nb');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('block code', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<pre><code>a\nb</code></pre>'), '```\na\nb\n```');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('inline code', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<code>a</code>'), '`a`');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('quote', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<blockquote>a\nb</blockquote>'), '> a\n> b');
|
|
|
|
});
|
|
|
|
|
2020-11-07 07:38:50 -08:00
|
|
|
it('br', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>abc<br><br/>d</p>'), 'abc\n\nd');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('link with different text', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a href="https://example.com/b">c</a> d</p>'), 'a [c](https://example.com/b) d');
|
|
|
|
});
|
|
|
|
|
2021-02-06 04:44:46 -08:00
|
|
|
it('link with different text, but not encoded', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a href="https://example.com/ä">c</a> d</p>'), 'a [c](<https://example.com/ä>) d');
|
|
|
|
});
|
|
|
|
|
2020-11-07 07:38:50 -08:00
|
|
|
it('link with same text', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a href="https://example.com/b">https://example.com/b</a> d</p>'), 'a https://example.com/b d');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('link with same text, but not encoded', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a href="https://example.com/ä">https://example.com/ä</a> d</p>'), 'a <https://example.com/ä> d');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('link with no url', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a href="b">c</a> d</p>'), 'a [c](b) d');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('link without href', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a>c</a> d</p>'), 'a c d');
|
|
|
|
});
|
|
|
|
|
2021-02-06 04:44:46 -08:00
|
|
|
it('link without text', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a href="https://example.com/b"></a> d</p>'), 'a https://example.com/b d');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('link without both', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a></a> d</p>'), 'a d');
|
|
|
|
});
|
|
|
|
|
2020-11-07 07:38:50 -08:00
|
|
|
it('mention', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a href="https://example.com/@user" class="u-url mention">@user</a> d</p>'), 'a @user@example.com d');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('hashtag', () => {
|
|
|
|
assert.deepStrictEqual(fromHtml('<p>a <a href="https://example.com/tags/a">#a</a> d</p>', ['#a']), 'a #a d');
|
|
|
|
});
|
|
|
|
});
|