diff --git a/src/__tests__/to-have-style.js b/src/__tests__/to-have-style.js index 5991a7e9..5d223af4 100644 --- a/src/__tests__/to-have-style.js +++ b/src/__tests__/to-have-style.js @@ -215,6 +215,15 @@ describe('.toHaveStyle', () => { }) }) + test('correctly matches invalid properties', () => { + const {queryByTestId} = render(` +
+ `) + expect(queryByTestId('element')).not.toHaveStyle({ + fontSize: 1, + }) + }) + test('Fails with an invalid unit', () => { const {queryByTestId} = render(` Hello World diff --git a/src/to-have-style.js b/src/to-have-style.js index 010e2a5d..f39a25cd 100644 --- a/src/to-have-style.js +++ b/src/to-have-style.js @@ -14,6 +14,15 @@ function getStyleDeclaration(document, css) { return styles } +function isInvalidStyleDeclaration(name, value, computedStyle) { + return ( + name && + !value && + !computedStyle[name] && + !computedStyle.getPropertyValue(name) + ) +} + function isSubset(styles, computedStyle) { return ( !!Object.keys(styles).length && @@ -22,11 +31,16 @@ function isSubset(styles, computedStyle) { const spellingVariants = [prop] if (!isCustomProperty) spellingVariants.push(prop.toLowerCase()) - return spellingVariants.some( - name => + return spellingVariants.some(name => { + if (isInvalidStyleDeclaration(name, value, computedStyle)) { + return false + } + + return ( computedStyle[name] === value || - computedStyle.getPropertyValue(name) === value, - ) + computedStyle.getPropertyValue(name) === value + ) + }) }) ) }