mirror of https://github.com/sveltejs/svelte
update await-block to use on_outro and check_outros - fixes #1995
parent
3ec5ff77eb
commit
33a2b54881
@ -0,0 +1,5 @@
|
||||
{value}
|
||||
|
||||
<script>
|
||||
export let value = 'Loading...';
|
||||
</script>
|
@ -0,0 +1,29 @@
|
||||
export default {
|
||||
async test({ assert, component, target }) {
|
||||
let resolve, reject;
|
||||
let promise = new Promise(ok => resolve = ok);
|
||||
|
||||
component.promise = promise;
|
||||
assert.htmlEqual(target.innerHTML, 'Loading...');
|
||||
|
||||
resolve(42);
|
||||
await promise;
|
||||
assert.htmlEqual(target.innerHTML, '42');
|
||||
|
||||
promise = new Promise((ok, fail) => reject = fail);
|
||||
component.promise = promise;
|
||||
assert.htmlEqual(target.innerHTML, 'Loading...');
|
||||
|
||||
reject(99);
|
||||
await promise.then(null, () => {});
|
||||
assert.htmlEqual(target.innerHTML, '99');
|
||||
|
||||
promise = new Promise(ok => resolve = ok);
|
||||
component.promise = promise;
|
||||
assert.htmlEqual(target.innerHTML, 'Loading...');
|
||||
|
||||
resolve(1);
|
||||
await promise;
|
||||
assert.htmlEqual(target.innerHTML, '1');
|
||||
}
|
||||
};
|
@ -0,0 +1,12 @@
|
||||
{#await promise}
|
||||
<Widget />
|
||||
{:then result}
|
||||
<Widget value="{result}" />
|
||||
{:catch err}
|
||||
<Widget value="{err}" />
|
||||
{/await}
|
||||
|
||||
<script>
|
||||
import Widget from './Widget.html';
|
||||
export let promise = Promise.resolve();
|
||||
</script>
|
Loading…
Reference in new issue