2021-05-21 15:17:21 +02:00
|
|
|
import htmlUtils from './htmlUtils';
|
2019-07-14 16:00:02 +01:00
|
|
|
|
2023-02-20 12:02:29 -03:00
|
|
|
describe('htmlUtils', () => {
|
2019-07-14 16:00:02 +01:00
|
|
|
|
2022-11-15 10:23:50 +00:00
|
|
|
|
2019-07-14 16:00:02 +01:00
|
|
|
|
2020-12-01 18:05:24 +00:00
|
|
|
it('should extract image URLs', (async () => {
|
2019-07-14 16:00:02 +01:00
|
|
|
const testCases = [
|
|
|
|
['<img src="http://test.com/img.png"/>', ['http://test.com/img.png']],
|
|
|
|
['<img src="http://test.com/img.png"/> <img src="http://test.com/img2.png"/>', ['http://test.com/img.png', 'http://test.com/img2.png']],
|
2019-07-21 00:18:51 +01:00
|
|
|
['<img src="http://test.com/img.png" alt="testing" >', ['http://test.com/img.png']],
|
2020-02-12 18:15:16 +00:00
|
|
|
['<img src=""/> <img src="http://test.com/img2.png"/>', ['http://test.com/img2.png']],
|
2019-07-21 00:18:51 +01:00
|
|
|
['nothing here', []],
|
|
|
|
['', []],
|
2019-07-14 16:00:02 +01:00
|
|
|
];
|
|
|
|
|
|
|
|
for (let i = 0; i < testCases.length; i++) {
|
2021-01-30 12:19:43 +00:00
|
|
|
const md = testCases[i][0] as string;
|
|
|
|
const expected = testCases[i][1] as string[];
|
2019-07-14 16:00:02 +01:00
|
|
|
|
|
|
|
expect(htmlUtils.extractImageUrls(md).join(' ')).toBe(expected.join(' '));
|
|
|
|
}
|
2019-09-23 23:23:10 +01:00
|
|
|
}));
|
2019-07-14 16:00:02 +01:00
|
|
|
|
2020-12-01 18:05:24 +00:00
|
|
|
it('should replace image URLs', (async () => {
|
2019-07-21 00:18:51 +01:00
|
|
|
const testCases = [
|
|
|
|
['<img src="http://test.com/img.png"/>', ['http://other.com/img2.png'], '<img src="http://other.com/img2.png"/>'],
|
|
|
|
['<img src="http://test.com/img.png"/> <img src="http://test.com/img2.png"/>', ['http://other.com/img2.png', 'http://other.com/img3.png'], '<img src="http://other.com/img2.png"/> <img src="http://other.com/img3.png"/>'],
|
|
|
|
['<img src="http://test.com/img.png" alt="testing" >', ['http://other.com/img.png'], '<img src="http://other.com/img.png" alt="testing" >'],
|
|
|
|
];
|
|
|
|
|
2021-01-30 12:19:43 +00:00
|
|
|
const callback = (urls: string[]) => {
|
2019-07-21 00:18:51 +01:00
|
|
|
let i = -1;
|
|
|
|
|
2021-01-30 12:19:43 +00:00
|
|
|
return function(_src: string) {
|
2019-07-21 00:18:51 +01:00
|
|
|
i++;
|
|
|
|
return urls[i];
|
2019-07-30 09:35:42 +02:00
|
|
|
};
|
|
|
|
};
|
2019-07-21 00:18:51 +01:00
|
|
|
|
|
|
|
for (let i = 0; i < testCases.length; i++) {
|
2021-01-30 12:19:43 +00:00
|
|
|
const md = testCases[i][0] as string;
|
|
|
|
const r = htmlUtils.replaceImageUrls(md, callback(testCases[i][1] as string[]));
|
|
|
|
expect(r.trim()).toBe((testCases[i][2] as string).trim());
|
2019-07-21 00:18:51 +01:00
|
|
|
}
|
2019-09-23 23:23:10 +01:00
|
|
|
}));
|
2019-07-21 00:18:51 +01:00
|
|
|
|
2020-12-01 18:05:24 +00:00
|
|
|
it('should encode attributes', (async () => {
|
2019-07-15 20:43:28 +00:00
|
|
|
const testCases = [
|
|
|
|
[{ a: 'one', b: 'two' }, 'a="one" b="two"'],
|
|
|
|
[{ a: 'one&two' }, 'a="one&two"'],
|
|
|
|
];
|
|
|
|
|
|
|
|
for (let i = 0; i < testCases.length; i++) {
|
|
|
|
const attrs = testCases[i][0];
|
|
|
|
const expected = testCases[i][1];
|
|
|
|
expect(htmlUtils.attributesHtml(attrs)).toBe(expected);
|
|
|
|
}
|
2019-09-23 23:23:10 +01:00
|
|
|
}));
|
2019-07-15 20:43:28 +00:00
|
|
|
|
2020-12-01 18:05:24 +00:00
|
|
|
it('should prepend a base URL', (async () => {
|
2019-07-21 00:18:51 +01:00
|
|
|
const testCases = [
|
|
|
|
[
|
|
|
|
'<a href="a.html">Something</a>',
|
|
|
|
'http://test.com',
|
|
|
|
'<a href="http://test.com/a.html">Something</a>',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'<a href="a.html">a</a> <a href="b.html">b</a>',
|
|
|
|
'http://test.com',
|
|
|
|
'<a href="http://test.com/a.html">a</a> <a href="http://test.com/b.html">b</a>',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'<a href="a.html">a</a> <a href="b.html">b</a>',
|
|
|
|
'http://test.com',
|
|
|
|
'<a href="http://test.com/a.html">a</a> <a href="http://test.com/b.html">b</a>',
|
|
|
|
],
|
|
|
|
];
|
2019-07-19 18:18:05 +01:00
|
|
|
|
2019-07-21 00:18:51 +01:00
|
|
|
for (let i = 0; i < testCases.length; i++) {
|
|
|
|
const html = testCases[i][0];
|
|
|
|
const baseUrl = testCases[i][1];
|
|
|
|
const expected = testCases[i][2];
|
|
|
|
expect(htmlUtils.prependBaseUrl(html, baseUrl)).toBe(expected);
|
|
|
|
}
|
2019-09-23 23:23:10 +01:00
|
|
|
}));
|
2019-07-19 18:18:05 +01:00
|
|
|
|
2019-07-30 09:35:42 +02:00
|
|
|
});
|