From 75a3f389934d1c2c4af5a4c9e2dde6a2bfb1cd74 Mon Sep 17 00:00:00 2001 From: Michael Cousins Date: Thu, 25 Jul 2024 19:05:04 -0400 Subject: [PATCH] fix(svelte5): synchronously flush changes after mount and unmount (#396) --- src/__tests__/mount.test.js | 5 +---- src/core/modern.svelte.js | 3 ++- 2 files changed, 3 insertions(+), 5 deletions(-) diff --git a/src/__tests__/mount.test.js b/src/__tests__/mount.test.js index e25c429..df6351d 100644 --- a/src/__tests__/mount.test.js +++ b/src/__tests__/mount.test.js @@ -1,4 +1,4 @@ -import { act, render, screen } from '@testing-library/svelte' +import { render, screen } from '@testing-library/svelte' import { describe, expect, test, vi } from 'vitest' import Mounter from './fixtures/Mounter.svelte' @@ -14,20 +14,17 @@ describe('mount and destroy', () => { const content = screen.getByRole('button') expect(content).toBeInTheDocument() - await act() expect(onMounted).toHaveBeenCalledTimes(1) }) test('component is destroyed', async () => { const { unmount } = renderSubject() - await act() unmount() const content = screen.queryByRole('button') expect(content).not.toBeInTheDocument() - await act() expect(onDestroyed).toHaveBeenCalledTimes(1) }) }) diff --git a/src/core/modern.svelte.js b/src/core/modern.svelte.js index 3da78b4..34893f5 100644 --- a/src/core/modern.svelte.js +++ b/src/core/modern.svelte.js @@ -26,6 +26,7 @@ const mount = (Component, options) => { const props = $state(options.props ?? {}) const component = Svelte.mount(Component, { ...options, props }) + Svelte.flushSync() propsByComponent.set(component, props) return component @@ -34,7 +35,7 @@ const mount = (Component, options) => { /** Remove the component from the DOM. */ const unmount = (component) => { propsByComponent.delete(component) - Svelte.unmount(component) + Svelte.flushSync(() => Svelte.unmount(component)) } /**