@ -1,21 +1,33 @@
import { flushSync } from 'svelte' ;
import { flushSync } from 'svelte' ;
import { test } from '../../test' ;
import { ok, test } from '../../test' ;
export default test ( {
export default test ( {
compileOptions : {
compileOptions : {
dev : true
dev : true
} ,
} ,
html : ` <button>items: null</button> <div>x</div> ` ,
html : ` <button>items: null</button> <div>x</div> <input type="checkbox" value="1"><input type="checkbox" value="2"> ` ,
test ( { assert , target , warnings } ) {
test ( { assert , target , warnings } ) {
const btn = target . querySelector ( 'button' ) ;
const btn = target . querySelector ( 'button' ) ;
ok ( btn ) ;
flushSync ( ( ) => btn ? . click ( ) ) ;
flushSync ( ( ) => btn . click ( ) ) ;
assert . htmlEqual ( target . innerHTML , ` <button>items: []</button> <div>x</div> ` ) ;
assert . htmlEqual (
target . innerHTML ,
` <button>items: []</button> <div>x</div> <input type="checkbox" value="1"><input type="checkbox" value="2"> `
) ;
flushSync ( ( ) => btn ? . click ( ) ) ;
flushSync ( ( ) => btn . click ( ) ) ;
assert . htmlEqual ( target . innerHTML , ` <button>items: [0]</button> <div>x</div> ` ) ;
assert . htmlEqual (
target . innerHTML ,
` <button>items: [0]</button> <div>x</div> <input type="checkbox" value="1"><input type="checkbox" value="2"> `
) ;
const input = target . querySelector ( 'input' ) ;
ok ( input ) ;
input . checked = true ;
flushSync ( ( ) => input . dispatchEvent ( new Event ( 'change' , { bubbles : true } ) ) ) ;
assert . deepEqual ( warnings , [
assert . deepEqual ( warnings , [
'Assignment to `items` property (main.svelte:8:24) will evaluate to the right-hand side, not the value of `items` following the assignment. This may result in unexpected behaviour.'
'Assignment to `items` property (main.svelte:8:24) will evaluate to the right-hand side, not the value of `items` following the assignment. This may result in unexpected behaviour.'