mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-08 13:06:15 +02:00
83 lines
3.0 KiB
TypeScript
83 lines
3.0 KiB
TypeScript
import defaultResourceModel from '../defaultResourceModel';
|
|
import linkReplacement from './linkReplacement';
|
|
import { describe, test, expect } from '@jest/globals';
|
|
|
|
describe('linkReplacement', () => {
|
|
|
|
test('should handle non-resource links', () => {
|
|
const r = linkReplacement('https://example.com/test').html;
|
|
expect(r).toBe('<a data-from-md href=\'https://example.com/test\' onclick=\'postMessage("https://example.com/test", { resourceId: "" }); return false;\'>');
|
|
});
|
|
|
|
test('should handle non-resource links - simple rendering', () => {
|
|
const r = linkReplacement('https://example.com/test', { linkRenderingType: 2 }).html;
|
|
expect(r).toBe('<a data-from-md href=\'https://example.com/test\'>');
|
|
});
|
|
|
|
test('should handle non-resource links with single quotes in it', () => {
|
|
// Handles a link such as:
|
|
// [Google](https://www.goo'onclick=javascript:alert(/1/);f=')
|
|
const r = linkReplacement('https://www.goo\'onclick=javascript:alert(/1/);f=\'', { linkRenderingType: 1 }).html;
|
|
expect(r).toBe('<a data-from-md href=\'https://www.goo'onclick=javascript:alert(/1/);f='\' onclick=\'postMessage("https://www.goo%27onclick=javascript:alert(/1/);f=%27", { resourceId: "" }); return false;\'>');
|
|
});
|
|
|
|
test('should handle resource links - downloaded status', () => {
|
|
const resourceId = 'f6afba55bdf74568ac94f8d1e3578d2c';
|
|
|
|
const r = linkReplacement(`:/${resourceId}`, {
|
|
ResourceModel: defaultResourceModel,
|
|
resources: {
|
|
[resourceId]: {
|
|
item: {},
|
|
localState: {
|
|
fetch_status: 2, // FETCH_STATUS_DONE
|
|
},
|
|
},
|
|
},
|
|
}).html;
|
|
|
|
expect(r).toBe(`<a data-from-md data-resource-id='${resourceId}' href='#' onclick='postMessage("joplin://${resourceId}", { resourceId: "${resourceId}" }); return false;'><span class="resource-icon fa-joplin"></span>`);
|
|
});
|
|
|
|
test('should handle resource links - idle status', () => {
|
|
const resourceId = 'f6afba55bdf74568ac94f8d1e3578d2c';
|
|
|
|
const r = linkReplacement(`:/${resourceId}`, {
|
|
ResourceModel: defaultResourceModel,
|
|
resources: {
|
|
[resourceId]: {
|
|
item: {},
|
|
localState: {
|
|
fetch_status: 0, // FETCH_STATUS_IDLE
|
|
},
|
|
},
|
|
},
|
|
}).html;
|
|
|
|
// Since the icon is embedded as SVG, we only check for the prefix
|
|
const expectedPrefix = `<a class="not-loaded-resource resource-status-notDownloaded" data-resource-id="${resourceId}"><img src="data:image/svg+xml;utf8`;
|
|
expect(r.indexOf(expectedPrefix)).toBe(0);
|
|
});
|
|
|
|
test('should create ontouch listeners to handle longpress', () => {
|
|
const resourceId = 'e6afba55bdf74568ac94f8d1e3578d2c';
|
|
|
|
const linkHtml = linkReplacement(`:/${resourceId}`, {
|
|
ResourceModel: defaultResourceModel,
|
|
resources: {
|
|
[resourceId]: {
|
|
item: {},
|
|
localState: {
|
|
fetch_status: 2, // FETCH_STATUS_DONE
|
|
},
|
|
},
|
|
},
|
|
enableLongPress: true,
|
|
}).html;
|
|
|
|
expect(linkHtml).toContain('ontouchstart');
|
|
expect(linkHtml).toContain('ontouchend');
|
|
expect(linkHtml).toContain('ontouchcancel');
|
|
});
|
|
});
|