From 0dac01ce4b98e64620a9d2334fd8e2a3fdc5d206 Mon Sep 17 00:00:00 2001 From: Rich-Harris Date: Tue, 18 Apr 2017 22:07:43 -0400 Subject: [PATCH] failing test for #498 --- .../_config.js | 78 +++++++++++++++++++ .../main.html | 13 ++++ 2 files changed, 91 insertions(+) create mode 100644 test/runtime/samples/binding-input-checkbox-group-outside-each/_config.js create mode 100644 test/runtime/samples/binding-input-checkbox-group-outside-each/main.html diff --git a/test/runtime/samples/binding-input-checkbox-group-outside-each/_config.js b/test/runtime/samples/binding-input-checkbox-group-outside-each/_config.js new file mode 100644 index 0000000000..bff66c903b --- /dev/null +++ b/test/runtime/samples/binding-input-checkbox-group-outside-each/_config.js @@ -0,0 +1,78 @@ +const values = [ + { name: 'Alpha' }, + { name: 'Beta' }, + { name: 'Gamma' } +]; + +export default { + data: { + values, + selected: [ values[1] ] + }, + + 'skip-ssr': true, // values are rendered as [object Object] + + html: ` + + + + + + +

Beta

`, + + test ( assert, component, target, window ) { + const inputs = target.querySelectorAll( 'input' ); + assert.equal( inputs[0].checked, false ); + assert.equal( inputs[1].checked, true ); + assert.equal( inputs[2].checked, false ); + + const event = new window.Event( 'change' ); + + inputs[0].checked = true; + inputs[0].dispatchEvent( event ); + + assert.htmlEqual( target.innerHTML, ` + + + + + + +

Alpha, Beta

+ ` ); + + component.set({ selected: [ values[1], values[2] ] }); + assert.equal( inputs[0].checked, false ); + assert.equal( inputs[1].checked, true ); + assert.equal( inputs[2].checked, true ); + + assert.htmlEqual( target.innerHTML, ` + + + + + + +

Beta, Gamma

+ ` ); + } +}; diff --git a/test/runtime/samples/binding-input-checkbox-group-outside-each/main.html b/test/runtime/samples/binding-input-checkbox-group-outside-each/main.html new file mode 100644 index 0000000000..126f7b79c1 --- /dev/null +++ b/test/runtime/samples/binding-input-checkbox-group-outside-each/main.html @@ -0,0 +1,13 @@ + + + + + + +

{{selected.map( function ( value ) { return value.name; }).join( ', ' ) }}

\ No newline at end of file