From 858dc357a1d2062a935f235863a62f15c6193eea Mon Sep 17 00:00:00 2001 From: Rich Harris Date: Fri, 6 Jun 2025 16:37:23 -0400 Subject: [PATCH] add test --- .../samples/async-error-skipped/_config.js | 56 +++++++++++++++++++ .../samples/async-error-skipped/main.svelte | 43 ++++++++++++++ 2 files changed, 99 insertions(+) create mode 100644 packages/svelte/tests/runtime-runes/samples/async-error-skipped/_config.js create mode 100644 packages/svelte/tests/runtime-runes/samples/async-error-skipped/main.svelte diff --git a/packages/svelte/tests/runtime-runes/samples/async-error-skipped/_config.js b/packages/svelte/tests/runtime-runes/samples/async-error-skipped/_config.js new file mode 100644 index 0000000000..c73fdbf268 --- /dev/null +++ b/packages/svelte/tests/runtime-runes/samples/async-error-skipped/_config.js @@ -0,0 +1,56 @@ +import { flushSync, tick } from 'svelte'; +import { test } from '../../test'; + +export default test({ + async test({ assert, target }) { + await Promise.resolve(); + + assert.htmlEqual( + target.innerHTML, + ` +

a

+ + + + +

a

+ ` + ); + + const [a, b, c, ok] = target.querySelectorAll('button'); + + flushSync(() => b.click()); + await Promise.resolve(); + await Promise.resolve(); + + assert.htmlEqual( + target.innerHTML, + ` +

c

+ + + + +

c

+ ` + ); + + flushSync(() => ok.click()); + + flushSync(() => b.click()); + await Promise.resolve(); + await Promise.resolve(); + + assert.htmlEqual( + target.innerHTML, + ` +

b

+ + + + +

b

+ ` + ); + } +}); diff --git a/packages/svelte/tests/runtime-runes/samples/async-error-skipped/main.svelte b/packages/svelte/tests/runtime-runes/samples/async-error-skipped/main.svelte new file mode 100644 index 0000000000..bf5fdf9ed3 --- /dev/null +++ b/packages/svelte/tests/runtime-runes/samples/async-error-skipped/main.svelte @@ -0,0 +1,43 @@ + + +

{route}

+ + + + + + + {#if route === 'a'} +

a

+ {/if} + + {#if route === 'b'} + {#if ok} +

b

+ {:else} + {await goto('c')} + {/if} + {/if} + + {#if route === 'c'} +

c

+ {/if} + + {#snippet pending()} +

pending...

+ {/snippet} + + {#snippet failed(error, reset)} + + {/snippet} +