diff --git a/packages/editor/CodeMirror/CodeMirror5Emulation/CodeMirror5Emulation.test.ts b/packages/editor/CodeMirror/CodeMirror5Emulation/CodeMirror5Emulation.test.ts index c5ab4609a..c6809efde 100644 --- a/packages/editor/CodeMirror/CodeMirror5Emulation/CodeMirror5Emulation.test.ts +++ b/packages/editor/CodeMirror/CodeMirror5Emulation/CodeMirror5Emulation.test.ts @@ -108,4 +108,22 @@ describe('CodeMirror5Emulation', () => { // additional times if its option hasn't updated. expect(onOtherOptionUpdate).toHaveBeenCalledTimes(1); }); + + it('defineExtension should override previous extensions with the same name', () => { + const codeMirror = makeCodeMirrorEmulation('Test...'); + const testExtensionFn1 = jest.fn(); + const testExtensionFn2 = jest.fn(); + + codeMirror.defineExtension('defineExtensionShouldOverride', testExtensionFn1); + + (codeMirror as any).defineExtensionShouldOverride(); + expect(testExtensionFn1).toHaveBeenCalledTimes(1); + expect(testExtensionFn2).toHaveBeenCalledTimes(0); + + codeMirror.defineExtension('defineExtensionShouldOverride', testExtensionFn2); + + (codeMirror as any).defineExtensionShouldOverride(); + expect(testExtensionFn1).toHaveBeenCalledTimes(1); + expect(testExtensionFn2).toHaveBeenCalledTimes(1); + }); }); diff --git a/packages/editor/CodeMirror/CodeMirror5Emulation/CodeMirror5Emulation.ts b/packages/editor/CodeMirror/CodeMirror5Emulation/CodeMirror5Emulation.ts index 2293c142b..beda4f8ba 100644 --- a/packages/editor/CodeMirror/CodeMirror5Emulation/CodeMirror5Emulation.ts +++ b/packages/editor/CodeMirror/CodeMirror5Emulation/CodeMirror5Emulation.ts @@ -272,7 +272,7 @@ export default class CodeMirror5Emulation extends BaseCodeMirror5Emulation { } public defineExtension(name: string, value: any) { - (CodeMirror5Emulation.prototype as any)[name] ??= value; + (CodeMirror5Emulation.prototype as any)[name] = value; } public defineOption(name: string, defaultValue: any, onUpdate: OptionUpdateCallback) {