diff --git a/.changeset/ninety-ravens-join.md b/.changeset/ninety-ravens-join.md
new file mode 100644
index 0000000000..f7bc6f8def
--- /dev/null
+++ b/.changeset/ninety-ravens-join.md
@@ -0,0 +1,5 @@
+---
+'svelte': patch
+---
+
+fix: ensure batch exists when resetting a failed boundary
diff --git a/packages/svelte/src/internal/client/dom/blocks/boundary.js b/packages/svelte/src/internal/client/dom/blocks/boundary.js
index 60fe2b7d3c..12ca547608 100644
--- a/packages/svelte/src/internal/client/dom/blocks/boundary.js
+++ b/packages/svelte/src/internal/client/dom/blocks/boundary.js
@@ -297,6 +297,9 @@ export class Boundary {
e.svelte_boundary_reset_onerror();
}
+ // If the failure happened while flushing effects, current_batch can be null
+ Batch.ensure();
+
this.#pending_count = 0;
if (this.#failed_effect !== null) {
diff --git a/packages/svelte/tests/runtime-runes/samples/async-boundary-reset/Test.svelte b/packages/svelte/tests/runtime-runes/samples/async-boundary-reset/Test.svelte
new file mode 100644
index 0000000000..2232a094cb
--- /dev/null
+++ b/packages/svelte/tests/runtime-runes/samples/async-boundary-reset/Test.svelte
@@ -0,0 +1,15 @@
+
+
+
diff --git a/packages/svelte/tests/runtime-runes/samples/async-boundary-reset/_config.js b/packages/svelte/tests/runtime-runes/samples/async-boundary-reset/_config.js
new file mode 100644
index 0000000000..19b273175b
--- /dev/null
+++ b/packages/svelte/tests/runtime-runes/samples/async-boundary-reset/_config.js
@@ -0,0 +1,19 @@
+import { tick } from 'svelte';
+import { test } from '../../test';
+
+export default test({
+ async test({ assert, target }) {
+ await tick();
+ let [btn] = target.querySelectorAll('button');
+ btn.click();
+ await tick();
+
+ assert.htmlEqual(target.innerHTML, '');
+
+ [btn] = target.querySelectorAll('button');
+ btn.click();
+ await tick();
+
+ assert.htmlEqual(target.innerHTML, '');
+ }
+});
diff --git a/packages/svelte/tests/runtime-runes/samples/async-boundary-reset/main.svelte b/packages/svelte/tests/runtime-runes/samples/async-boundary-reset/main.svelte
new file mode 100644
index 0000000000..42242f26d6
--- /dev/null
+++ b/packages/svelte/tests/runtime-runes/samples/async-boundary-reset/main.svelte
@@ -0,0 +1,12 @@
+
+
+
+
+
+ {#snippet pending()}pending{/snippet}
+ {#snippet failed(_, reset)}
+
+ {/snippet}
+