1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-11 18:24:43 +02:00

Desktop, Cli: Fix importing certain ENEX notes that include invalid tables

This commit is contained in:
Laurent Cozic 2023-12-31 15:07:12 +00:00
parent 4048d83dd7
commit 00eee19077
3 changed files with 31 additions and 19 deletions

View File

@ -1,4 +1,5 @@
<table> <table>
<div></div> <!-- INVALID! -->
<tr> <tr>
<td>one</td> <td>one</td>
<td>two</td> <td>two</td>

View File

@ -142,22 +142,28 @@ describe('import-enex-md-gen', () => {
expect(all[0].mime).toBe('application/zip'); expect(all[0].mime).toBe('application/zip');
}); });
it('should keep importing notes when one of them is corrupted', async () => { // Disabled for now because the ENEX parser has become so error-tolerant
const filePath = `${enexSampleBaseDir}/ImportTestCorrupt.enex`; // that it's no longer possible to generate a note that would generate a
const errors: any[] = []; // failure.
const consoleSpy = jest.spyOn(console, 'warn').mockImplementation(jest.fn());
await importEnex('', filePath, {
onError: (error: any) => errors.push(error),
});
consoleSpy.mockRestore();
const notes = await Note.all();
expect(notes.length).toBe(2);
// Check that an error was recorded and that it includes the title // it('should keep importing notes when one of them is corrupted', async () => {
// of the note, so that it can be found back by the user // const filePath = `${enexSampleBaseDir}/ImportTestCorrupt.enex`;
expect(errors.length).toBe(1); // const errors: any[] = [];
expect(errors[0].message.includes('Note 2')).toBe(true); // const consoleSpy = jest.spyOn(console, 'warn').mockImplementation(jest.fn());
}); // await importEnex('', filePath, {
// onError: (error: any) => errors.push(error),
// });
// consoleSpy.mockRestore();
// const notes:NoteEntity[] = await Note.all();
// expect(notes.length).toBe(2);
// expect(notes.find(n => n.title === 'Note 1')).toBeTruthy();
// expect(notes.find(n => n.title === 'Note 3')).toBeTruthy();
// // Check that an error was recorded and that it includes the title
// // of the note, so that it can be found back by the user
// expect(errors.length).toBe(1);
// expect(errors[0].message.includes('Note 2')).toBe(true);
// });
it('should throw an error and stop if the outer XML is invalid', async () => { it('should throw an error and stop if the outer XML is invalid', async () => {
await expectThrow(async () => importEnexFile('invalid_html.enex')); await expectThrow(async () => importEnexFile('invalid_html.enex'));

View File

@ -1241,6 +1241,14 @@ function drawTable(table: Section) {
continue; continue;
} }
if (typeof tr === 'string') {
// A <TABLE> tag should only have <TR> tags as direct children.
// However certain Evernote notes can contain other random tags
// such as empty DIVs. In that case we just skip the content.
// See test "table_with_invalid_content.html".
continue;
}
const isHeader = tr.isHeader; const isHeader = tr.isHeader;
const line = []; const line = [];
const headerLine = []; const headerLine = [];
@ -1249,10 +1257,7 @@ function drawTable(table: Section) {
const td = tr.lines[tdIndex]; const td = tr.lines[tdIndex];
if (typeof td === 'string') { if (typeof td === 'string') {
// A <TR> tag should only have <TD> tags as direct children. // Same comment as above the <TR> tags.
// However certain Evernote notes can contain other random tags
// such as empty DIVs. In that case we just skip the content.
// See test "table_with_invalid_content.html".
continue; continue;
} }