import { RenderingTest, moduleFor } from '../utils/test-case';
import { set } from '@ember/-internals/metal';
import { strip } from '../utils/abstract-test-case';
moduleFor(
'SVG element tests',
class extends RenderingTest {
['@test unquoted viewBox property is output'](assert) {
let viewBoxString = '0 0 100 100';
this.render('
', {
model: {
viewBoxString,
},
});
this.assertInnerHTML(strip`
`);
this.runTask(() => this.rerender());
this.assertInnerHTML(strip`
`);
this.runTask(() => set(this.context, 'model.viewBoxString', null));
assert.equal(this.firstChild.getAttribute('svg'), null);
this.runTask(() => set(this.context, 'model', { viewBoxString }));
this.assertInnerHTML(strip`
`);
}
['@test quoted viewBox property is output'](assert) {
let viewBoxString = '0 0 100 100';
this.render('', {
model: {
viewBoxString,
},
});
this.assertInnerHTML(strip`
`);
this.runTask(() => this.rerender());
this.assertInnerHTML(strip`
`);
this.runTask(() => set(this.context, 'model.viewBoxString', null));
assert.equal(this.firstChild.getAttribute('svg'), null);
this.runTask(() => set(this.context, 'model', { viewBoxString }));
this.assertInnerHTML(strip`
`);
}
['@test quoted viewBox property is concat']() {
let viewBoxString = '100 100';
this.render('', {
model: {
viewBoxString,
},
});
this.assertInnerHTML(strip`
`);
this.runTask(() => this.rerender());
this.assertInnerHTML(strip`
`);
this.runTask(() => set(this.context, 'model.viewBoxString', '200 200'));
this.assertInnerHTML(strip`
`);
this.runTask(() => set(this.context, 'model', { viewBoxString }));
this.assertInnerHTML(strip`
`);
}
['@test class is output']() {
this.render("", {
model: {
color: 'blue',
},
});
this.assertInnerHTML(strip`
`);
this.runTask(() => this.rerender());
this.assertInnerHTML(strip`
`);
this.runTask(() => set(this.context, 'model.color', 'yellow'));
this.assertInnerHTML(strip`
`);
this.runTask(() => set(this.context, 'model', { color: 'blue' }));
this.assertInnerHTML(strip`
`);
}
}
);