adding test coverage for boolean and enum HTML attributes (#2544)
This commit is contained in:
parent
73bf4d8bb8
commit
41b659b12e
2 changed files with 31 additions and 11 deletions
|
@ -15,18 +15,25 @@ describe('Attributes', async () => {
|
||||||
const $ = cheerio.load(html);
|
const $ = cheerio.load(html);
|
||||||
|
|
||||||
const attrs = {
|
const attrs = {
|
||||||
'false-str': 'false',
|
'false-str': { attribute: 'attr', value: 'false' },
|
||||||
'true-str': 'true',
|
'true-str': { attribute: 'attr', value: 'true' },
|
||||||
false: undefined,
|
false: { attribute: 'attr', value: undefined },
|
||||||
true: 'true',
|
true: { attribute: 'attr', value: 'true' },
|
||||||
empty: '',
|
empty: { attribute: 'attr', value: '' },
|
||||||
null: undefined,
|
null: { attribute: 'attr', value: undefined },
|
||||||
undefined: undefined,
|
undefined: { attribute: 'attr', value: undefined },
|
||||||
|
'html-boolean': { attribute: 'async', value: 'async' },
|
||||||
|
'html-boolean-true': { attribute: 'async', value: 'async' },
|
||||||
|
'html-boolean-false': { attribute: 'async', value: undefined },
|
||||||
|
'html-enum': { attribute: 'draggable', value: 'true' },
|
||||||
|
'html-enum-true': { attribute: 'draggable', value: 'true' },
|
||||||
|
'html-enum-false': { attribute: 'draggable', value: 'false' },
|
||||||
};
|
};
|
||||||
|
|
||||||
for (const [k, v] of Object.entries(attrs)) {
|
for (const id of Object.keys(attrs)) {
|
||||||
const attr = $(`#${k}`).attr('attr');
|
const { attribute, value } = attrs[id]
|
||||||
expect(attr).to.equal(v);
|
const attr = $(`#${id}`).attr(attribute);
|
||||||
|
expect(attr).to.equal(value);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -5,4 +5,17 @@
|
||||||
<span id="empty" attr="" />
|
<span id="empty" attr="" />
|
||||||
<span id="null" attr={null} />
|
<span id="null" attr={null} />
|
||||||
<span id="undefined" attr={undefined} />
|
<span id="undefined" attr={undefined} />
|
||||||
|
<!--
|
||||||
|
Per HTML spec, some attributes should be treated as booleans
|
||||||
|
These should always render <span async /> or <span /> (without a string value)
|
||||||
|
-->
|
||||||
|
<span id='html-boolean' async />
|
||||||
|
<span id='html-boolean-true' async={true} />
|
||||||
|
<span id='html-boolean-false' async={false} />
|
||||||
|
<!--
|
||||||
|
Other attributes should be treated as string enums
|
||||||
|
These should always render <span draggable="true" /> or <span draggable="false" />
|
||||||
|
-->
|
||||||
|
<span id='html-enum' draggable='true' />
|
||||||
|
<span id='html-enum-true' draggable={true} />
|
||||||
|
<span id='html-enum-false' draggable={false} />
|
Loading…
Reference in a new issue