diff --git a/packages/svelte/tests/runtime-runes/samples/async-time-travelling-derived/_config.js b/packages/svelte/tests/runtime-runes/samples/async-time-travelling-derived/_config.js
new file mode 100644
index 0000000000..06437d2e31
--- /dev/null
+++ b/packages/svelte/tests/runtime-runes/samples/async-time-travelling-derived/_config.js
@@ -0,0 +1,56 @@
+import { tick } from 'svelte';
+import { test } from '../../test';
+
+export default test({
+ async test({ assert, target }) {
+ await tick();
+
+ const [a, b, update] = target.querySelectorAll('button');
+
+ assert.htmlEqual(
+ target.innerHTML,
+ `
+
+
+
+
a
+ `
+ );
+
+ b.click();
+ await tick();
+ assert.htmlEqual(
+ target.innerHTML,
+ `
+
+
+
+ b
+ `
+ );
+
+ update.click();
+ await tick();
+ assert.htmlEqual(
+ target.innerHTML,
+ `
+
+
+
+ b
+ `
+ );
+
+ a.click();
+ await tick();
+ assert.htmlEqual(
+ target.innerHTML,
+ `
+
+
+
+ a
+ `
+ );
+ }
+});
diff --git a/packages/svelte/tests/runtime-runes/samples/async-time-travelling-derived/main.svelte b/packages/svelte/tests/runtime-runes/samples/async-time-travelling-derived/main.svelte
new file mode 100644
index 0000000000..5fca286a78
--- /dev/null
+++ b/packages/svelte/tests/runtime-runes/samples/async-time-travelling-derived/main.svelte
@@ -0,0 +1,26 @@
+
+
+
+
+
+
+
+
+ {#if condition}
+ a
+ {:else}
+ b
+ {/if}
+
+ {#snippet pending()}{/snippet}
+
+