44 lines
896 B

export default {
data: {
count: 42
},
html: `
<input type='number'>
<p>number 42</p>
`,
test ( assert, component, target, window ) {
const input = target.querySelector( 'input' );
assert.equal( input.value, '42' );
const event = new window.Event( 'input' );
input.value = '43';
input.dispatchEvent( event );
assert.equal( component.get().count, 43 );
assert.htmlEqual( target.innerHTML, `
<input type='number'>
<p>number 43</p>
` );
component.set({ count: 44 });
assert.equal( input.value, '44' );
assert.htmlEqual( target.innerHTML, `
<input type='number'>
<p>number 44</p>
` );
// empty string should be treated as undefined
input.value = '';
input.dispatchEvent( event );
assert.equal( component.get().count, undefined );
assert.htmlEqual( target.innerHTML, `
<input type='number'>
<p>undefined undefined</p>
` );
}
};