Skip to content

Commit 47a073e

Browse files
fix: destroy effect on error (#12376)
fixes #12360 --------- Co-authored-by: Simon Holthausen <[email protected]>
1 parent 145d67a commit 47a073e

File tree

9 files changed

+67
-1
lines changed

9 files changed

+67
-1
lines changed

.changeset/small-chefs-sing.md

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
---
2+
'svelte': patch
3+
---
4+
5+
fix: destroy effects that error on creation

packages/svelte/src/internal/client/reactivity/effects.js

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -109,6 +109,9 @@ function create_effect(type, fn, sync, push = true) {
109109
set_is_flushing_effect(true);
110110
update_effect(effect);
111111
effect.f |= EFFECT_RAN;
112+
} catch (e) {
113+
destroy_effect(effect);
114+
throw e;
112115
} finally {
113116
set_is_flushing_effect(previously_flushing_effect);
114117
}

packages/svelte/tests/runtime-legacy/shared.ts

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -104,7 +104,10 @@ export function runtime_suite(runes: boolean) {
104104
if (config.skip_mode?.includes('hydrate')) return true;
105105
}
106106

107-
if (variant === 'dom' && config.skip_mode?.includes('client')) {
107+
if (
108+
variant === 'dom' &&
109+
(config.skip_mode?.includes('client') || (config.mode && !config.mode.includes('client')))
110+
) {
108111
return 'no-test';
109112
}
110113

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
import { flushSync } from 'svelte';
2+
import { test } from '../../test';
3+
4+
export default test({
5+
html: '<p><p>invalid</p></p>',
6+
mode: ['hydrate'],
7+
recover: true,
8+
test({ assert, target, logs }) {
9+
target.click();
10+
flushSync();
11+
assert.deepEqual(logs, ['body', 'document', 'window']);
12+
}
13+
});
Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
<svelte:window onclick={() => console.log('window')} />
2+
<svelte:document onclick={() => console.log('document')} />
3+
<svelte:body onclick={() => console.log('body')} />
4+
5+
<p>{@html '<p>invalid</p>'}</p>
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
<script>
2+
throw new Error('boom');
3+
</script>
Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
<script>
2+
import Inner from './Inner.svelte';
3+
</script>
4+
5+
<svelte:window onclick={() => console.log('window')} />
6+
<svelte:document onclick={() => console.log('document')} />
7+
<svelte:body onclick={() => console.log('body')} />
8+
9+
<Inner />
Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
import { flushSync } from 'svelte';
2+
import { test } from '../../test';
3+
4+
export default test({
5+
mode: ['client'],
6+
test({ assert, target, logs }) {
7+
target.click();
8+
flushSync();
9+
assert.deepEqual(logs, []);
10+
}
11+
});
Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
<script>
2+
import { mount, onMount } from 'svelte';
3+
import Outer from './Outer.svelte';
4+
5+
let el;
6+
7+
onMount(() => {
8+
try {
9+
mount(Outer, { target: el });
10+
} catch {}
11+
});
12+
</script>
13+
14+
<div bind:this={el}></div>

0 commit comments

Comments
 (0)