mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-14 18:27:44 +02:00
34c4b832ba
Causes an infinite rendering loop when creating a new note
113 lines
3.1 KiB
TypeScript
113 lines
3.1 KiB
TypeScript
import Note from '@joplin/lib/models/Note';
|
|
import { setupDatabaseAndSynchronizer, switchClient } from '@joplin/lib/testing/test-utils';
|
|
import { renderHook } from '@testing-library/react-hooks';
|
|
import useFormNote, { HookDependencies } from './useFormNote';
|
|
|
|
const defaultFormNoteProps: HookDependencies = {
|
|
syncStarted: false,
|
|
decryptionStarted: false,
|
|
noteId: '',
|
|
isProvisional: false,
|
|
titleInputRef: null,
|
|
editorRef: null,
|
|
onBeforeLoad: ()=>{},
|
|
onAfterLoad: ()=>{},
|
|
};
|
|
|
|
describe('useFormNote', () => {
|
|
beforeEach(async () => {
|
|
await setupDatabaseAndSynchronizer(1);
|
|
await switchClient(1);
|
|
});
|
|
|
|
it('should update note when decryption completes', async () => {
|
|
const testNote = await Note.save({ title: 'Test Note!' });
|
|
|
|
const makeFormNoteProps = (syncStarted: boolean, decryptionStarted: boolean): HookDependencies => {
|
|
return {
|
|
...defaultFormNoteProps,
|
|
syncStarted,
|
|
decryptionStarted,
|
|
noteId: testNote.id,
|
|
};
|
|
};
|
|
|
|
const formNote = renderHook(props => useFormNote(props), {
|
|
initialProps: makeFormNoteProps(true, false),
|
|
});
|
|
await formNote.waitFor(() => {
|
|
expect(formNote.result.current.formNote).toMatchObject({
|
|
encryption_applied: 0,
|
|
title: testNote.title,
|
|
});
|
|
});
|
|
|
|
await Note.save({
|
|
id: testNote.id,
|
|
encryption_cipher_text: 'cipher_text',
|
|
encryption_applied: 1,
|
|
});
|
|
|
|
// Sync starting should cause a re-render
|
|
formNote.rerender(makeFormNoteProps(false, false));
|
|
|
|
await formNote.waitFor(() => {
|
|
expect(formNote.result.current.formNote).toMatchObject({
|
|
encryption_applied: 1,
|
|
});
|
|
});
|
|
|
|
|
|
formNote.rerender(makeFormNoteProps(false, true));
|
|
|
|
await Note.save({
|
|
id: testNote.id,
|
|
encryption_applied: 0,
|
|
title: 'Test Note!',
|
|
});
|
|
|
|
// Ending decryption should also cause a re-render
|
|
formNote.rerender(makeFormNoteProps(false, false));
|
|
|
|
await formNote.waitFor(() => {
|
|
expect(formNote.result.current.formNote).toMatchObject({
|
|
encryption_applied: 0,
|
|
title: 'Test Note!',
|
|
});
|
|
});
|
|
});
|
|
|
|
// It seems this test is crashing the worker on CI (out of memory), so disabling it for now.
|
|
|
|
// it('should reload the note when it is changed outside of the editor', async () => {
|
|
// const note = await Note.save({ title: 'Test Note!' });
|
|
|
|
// const makeFormNoteProps = (dbNote: DbNote): HookDependencies => {
|
|
// return {
|
|
// ...defaultFormNoteProps,
|
|
// noteId: note.id,
|
|
// dbNote,
|
|
// };
|
|
// };
|
|
|
|
// const formNote = renderHook(props => useFormNote(props), {
|
|
// initialProps: makeFormNoteProps({ id: note.id, updated_time: note.updated_time }),
|
|
// });
|
|
|
|
// await formNote.waitFor(() => {
|
|
// expect(formNote.result.current.formNote.title).toBe('Test Note!');
|
|
// });
|
|
|
|
// // Simulate the note being modified outside the editor
|
|
// const modifiedNote = await Note.save({ id: note.id, title: 'Modified' });
|
|
|
|
// // NoteEditor then would update `dbNote`
|
|
// formNote.rerender(makeFormNoteProps({ id: note.id, updated_time: modifiedNote.updated_time }));
|
|
|
|
// await formNote.waitFor(() => {
|
|
// expect(formNote.result.current.formNote.title).toBe('Modified');
|
|
// });
|
|
// });
|
|
|
|
});
|