summaryrefslogtreecommitdiff
path: root/packages/markdown/remark/test/autolinking.test.js
blob: c5cd64657c262bc18457d8b9a11a25194857e091 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
import { renderMarkdown } from '../dist/index.js';
import chai from 'chai';

describe('autolinking', () => {
	describe('plain md', () => {
		it('autolinks URLs starting with a protocol in plain text', async () => {
			const { code } = await renderMarkdown(`See https://example.com for more.`, {});

			chai
				.expect(code.replace(/\n/g, ''))
				.to.equal(`<p>See <a href="https://example.com">https://example.com</a> for more.</p>`);
		});

		it('autolinks URLs starting with "www." in plain text', async () => {
			const { code } = await renderMarkdown(`See www.example.com for more.`, {});

			chai
				.expect(code.trim())
				.to.equal(`<p>See <a href="http://www.example.com">www.example.com</a> for more.</p>`);
		});

		it('does not autolink URLs in code blocks', async () => {
			const { code } = await renderMarkdown(
				'See `https://example.com` or `www.example.com` for more.',
				{}
			);

			chai
				.expect(code.trim())
				.to.equal(
					`<p>See <code>https://example.com</code> or ` +
						`<code>www.example.com</code> for more.</p>`
				);
		});
	});

	describe('astro-flavored md', () => {
		const renderAstroMd = (text) => renderMarkdown(text, { isAstroFlavoredMd: true });

		it('does not autolink URLs in code blocks', async () => {
			const { code } = await renderAstroMd(
				'See `https://example.com` or `www.example.com` for more.',
				{}
			);

			chai
				.expect(code.trim())
				.to.equal(
					`<p>See <code is:raw>https://example.com</code> or ` +
						`<code is:raw>www.example.com</code> for more.</p>`
				);
		});

		it('does not autolink URLs in fenced code blocks', async () => {
			const { code } = await renderAstroMd(
				'Example:\n```\nGo to https://example.com or www.example.com now.\n```'
			);

			chai
				.expect(code)
				.to.contain(`<pre is:raw`)
				.to.contain(`Go to https://example.com or www.example.com now.`);
		});

		it('does not autolink URLs starting with a protocol when nested inside links', async () => {
			const { code } = await renderAstroMd(
				`See [http://example.com](http://example.com) or ` +
					`<a test href="https://example.com">https://example.com</a>`
			);

			chai
				.expect(code.replace(/\n/g, ''))
				.to.equal(
					`<p>See <a href="http://example.com">http://example.com</a> or ` +
						`<a test href="https://example.com">https://example.com</a></p>`
				);
		});

		it('does not autolink URLs starting with "www." when nested inside links', async () => {
			const { code } = await renderAstroMd(
				`See [www.example.com](https://www.example.com) or ` +
					`<a test href="https://www.example.com">www.example.com</a>`
			);

			chai
				.expect(code.replace(/\n/g, ''))
				.to.equal(
					`<p>See <a href="https://www.example.com">www.example.com</a> or ` +
						`<a test href="https://www.example.com">www.example.com</a></p>`
				);
		});

		it('does not autolink URLs when nested several layers deep inside links', async () => {
			const { code } = await renderAstroMd(
				`<a href="https://www.example.com">**Visit _our www.example.com or ` +
					`http://localhost pages_ for more!**</a>`
			);

			chai
				.expect(code.replace(/\n/g, ''))
				.to.equal(
					`<a href="https://www.example.com"><strong>` +
						`Visit <em>our www.example.com or http://localhost pages</em> for more!` +
						`</strong></a>`
				);
		});
	});
});