Skip to content

Commit

Permalink
Fix tests
Browse files Browse the repository at this point in the history
  • Loading branch information
Skalakid committed Jan 19, 2024
1 parent 7dd23be commit 4072b1c
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 18 deletions.
2 changes: 1 addition & 1 deletion parser/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,7 @@ function parseTreeToTextAndRanges(tree: StackItem): [string, Range[]] {
}

function sortRanges(ranges: Range[]) {
return ranges.sort((a, b) => a[1] - b[1] || b[2] - a[2] || a[0].localeCompare(b[0]) || 0); // sort by location to properly handle bold+italic
return ranges.sort((a, b) => a[1] - b[1] || b[2] - a[2] || 0); // sort by location to properly handle bold+italic
}

function parseExpensiMarkToRanges(markdown: string): Range[] {
Expand Down
2 changes: 1 addition & 1 deletion parser/react-native-live-markdown-parser.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

36 changes: 23 additions & 13 deletions src/__tests__/index.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,11 @@ const toBeParsedAsHTML: MatcherFunction<[expectedHTML: string]> = function (actu
throw new Error('These must be of type number!');
}
let expected = expectedHTML;
const [, ranges]: [string, Array<[MarkdownType, number, number]>] = (global as any).parseMarkdownToTextAndRanges(actual);
const markdownRanges = ranges.map((range) => {
const ranges = global.parseExpensiMarkToRanges(actual);
const markdownRanges: MarkdownTypes.MarkdownRange[] = ranges.map((range) => {
const [type, startIndex, length] = range;
return {
type,
type: type as MarkdownType,
startIndex,
length,
};
Expand Down Expand Up @@ -73,15 +73,15 @@ test('strikethrough', () => {

describe('mention', () => {
test('normal', () => {
expect('@here Hello!').toBeParsedAsHTML('<span class="mention">@here</span> Hello!');
expect('@here Hello!').toBeParsedAsHTML('<span class="mention-here">@here</span> Hello!');
});

test('with punctation marks', () => {
expect('@here!').toBeParsedAsHTML('<span class="mention">@here</span>!');
expect('@here!').toBeParsedAsHTML('<span class="mention-here">@here</span>!');
});

test('at the beginning of a heading', () => {
expect('# @here').toBeParsedAsHTML('<span class="syntax"># </span><span class="h1"><span class="mention">@here</span></span>');
expect('# @here').toBeParsedAsHTML('<span class="syntax"># </span><span class="mention-here"><span class="h1">@here</span></span>');
});
});

Expand All @@ -95,7 +95,7 @@ describe('mention-user', () => {
});

test('at the beginning of a heading', () => {
expect('# @mail@mail.com').toBeParsedAsHTML('<span class="syntax"># </span><span class="h1"><span class="mention-user">@mail@mail.com</span></span>');
expect('# @mail@mail.com').toBeParsedAsHTML('<span class="syntax"># </span><span class="mention-user"><span class="h1">@mail@mail.com</span></span>');
});
});

Expand All @@ -111,7 +111,9 @@ describe('link', () => {
});

test('link with same label as href', () => {
expect('[https://example.com](https://example.com)').toBeParsedAsHTML('<span class="link">[https://example.co</span>m](https://example.com)');
expect('[https://example.com](https://example.com)').toBeParsedAsHTML(
'<span class="syntax">[</span>https://example.com<span class="syntax">](</span><span class="link">https://example.com</span><span class="syntax">)</span>',
);
});

test('link with query string', () => {
Expand All @@ -133,19 +135,27 @@ describe('email', () => {

describe('email with same label as address', () => {
test('label and address without "mailto:"', () => {
expect('[someone@example.com](someone@example.com)').toBeParsedAsHTML('<span class="link">[someone@example.co</span>m](someone@example.com)');
expect('[someone@example.com](someone@example.com)').toBeParsedAsHTML(
'<span class="syntax">[</span>someone@example.com<span class="syntax">](</span><span class="link">someone@example.com</span><span class="syntax">)</span>',
);
});

test('label with "mailto:"', () => {
expect('[mailto:someone@example.com](someone@example.com)').toBeParsedAsHTML('<span class="link">[mailto:someone@exa</span>mple.com](someone@example.com)');
expect('[mailto:someone@example.com](someone@example.com)').toBeParsedAsHTML(
'<span class="syntax">[</span>mailto:someone@example.com<span class="syntax">](</span><span class="link">someone@example.com</span><span class="syntax">)</span>',
);
});

test('address with "mailto:"', () => {
expect('[someone@example.com](mailto:someone@example.com)').toBeParsedAsHTML('<span class="link">[someone@example.co</span>m](mailto:someone@example.com)');
expect('[someone@example.com](mailto:someone@example.com)').toBeParsedAsHTML(
'<span class="syntax">[</span>someone@example.com<span class="syntax">](</span><span class="link">mailto:someone@example.com</span><span class="syntax">)</span>',
);
});

test('label and address with "mailto:"', () => {
expect('[mailto:someone@example.com](mailto:someone@example.com)').toBeParsedAsHTML('<span class="link">[mailto:someone@exa</span>mple.com](mailto:someone@example.com)');
expect('[mailto:someone@example.com](mailto:someone@example.com)').toBeParsedAsHTML(
'<span class="syntax">[</span>mailto:someone@example.com<span class="syntax">](</span><span class="link">mailto:someone@example.com</span><span class="syntax">)</span>',
);
});
});

Expand All @@ -154,7 +164,7 @@ test('inline code', () => {
});

test('codeblock', () => {
expect('```\nHello world!\n```').toBeParsedAsHTML('<span class="syntax">```</span><br><span class="pre">Hello world!\n</span><span class="syntax">```</span>');
expect('```\nHello world!\n```').toBeParsedAsHTML('<span class="syntax">```</span><span class="pre"><br>Hello world!<br></span><span class="syntax">```</span>');
});

describe('quote', () => {
Expand Down
7 changes: 4 additions & 3 deletions src/web/parserUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -133,19 +133,19 @@ function parseRangesToHTMLNodes(text: string, ranges: MarkdownRange[], markdownS
addStyling(span, range.type, markdownStyle);
}

if (stack.length > 0 && nextRangeStartIndex < endOfCurrentRange) {
if (stack.length > 0 && nextRangeStartIndex < endOfCurrentRange && range.type !== 'syntax') {
// tag nesting
currentRoot.node.appendChild(span);
nestedStack.push({node: span, endIndex: endOfCurrentRange});
lastRangeEndIndex = range.startIndex;
} else {
addSubstringAsTextNode(span, text, range.startIndex, endOfCurrentRange);
addTextWithNewlines(span, text, range.startIndex, endOfCurrentRange);
currentRoot.node.appendChild(span);
lastRangeEndIndex = endOfCurrentRange;

// end of tag nesting
while (nestedStack.length - 1 > 0 && nextRangeStartIndex >= currentRoot.endIndex) {
addSubstringAsTextNode(currentRoot.node, text, lastRangeEndIndex, currentRoot.endIndex);
addTextWithNewlines(currentRoot.node, text, lastRangeEndIndex, currentRoot.endIndex);
const prevRoot = nestedStack.pop();
if (!prevRoot) {
break;
Expand Down Expand Up @@ -176,6 +176,7 @@ function parseText(target: HTMLElement, text: string, markdownStyle: PartialMark
cursorPosition = CursorUtils.getCurrentCursorPosition(target).start;
}
const ranges = global.parseExpensiMarkToRanges(text);

const markdownRanges: MarkdownRange[] = ranges.map((range) => {
const [type, startIndex, length] = range;
return {
Expand Down

0 comments on commit 4072b1c

Please sign in to comment.