You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
svelte/test/runtime/samples/transition-js-each-block-ke.../_config.js

44 lines
976 B

export default {
get props() {
return {
things: [{ name: 'a' }, { name: 'b' }, { name: 'c' }]
};
},
intro: true,
test({ assert, component, target, raf }) {
let divs = target.querySelectorAll('div');
assert.equal(divs[0].foo, 0);
assert.equal(divs[1].foo, 0);
assert.equal(divs[2].foo, 0);
raf.tick(50);
assert.equal(divs[0].foo, 0.5);
assert.equal(divs[1].foo, 0.5);
assert.equal(divs[2].foo, 0.5);
component.things = [{ name: 'a' }, { name: 'woo!' }, { name: 'b' }, { name: 'c' }];
assert.htmlEqual(
target.innerHTML,
`
<div>a</div>
<div>woo!</div>
<div>b</div>
<div>c</div>
`
);
divs = target.querySelectorAll('div');
assert.equal(divs[0].foo, 0.5);
assert.equal(divs[1].foo, 0);
assert.equal(divs[2].foo, 0.5);
assert.equal(divs[3].foo, 0.5);
raf.tick(75);
assert.equal(divs[0].foo, 0.75);
assert.equal(divs[1].foo, 0.25);
assert.equal(divs[2].foo, 0.75);
assert.equal(divs[3].foo, 0.75);
}
};