-
Notifications
You must be signed in to change notification settings - Fork 318
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
chore(ui-react): lint test files #3306
Conversation
|
let updateControlledValue; | ||
const ControlledSwitch = () => { | ||
const [isChecked, setIsChecked] = React.useState(true); | ||
const changeFunction = (e) => { | ||
setIsChecked(e.target.checked); | ||
}; | ||
updateControlledValue = setIsChecked; | ||
|
||
return ( | ||
<SwitchField | ||
label={label} | ||
isChecked={isChecked} | ||
onChange={changeFunction} | ||
/> | ||
); | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This test component was extraneous, the desired behavior can be achieved using the rerender
function returned from calling render
); | ||
|
||
const field = container.getElementsByTagName('input')[0]; | ||
expect(field).toBeChecked(); | ||
}); | ||
|
||
it('should fire the onChange function with a checkbox change event', async () => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Removed this test as it was really only testing the behavior of the SwitchFieldControlledExample
contained inside, not the functionality of the SwitchField
. To note, doublechecked that it had no impact on test coverage
); | ||
|
||
if (breakpoint === 'base') { | ||
// eslint-disable-next-line jest/no-conditional-expect |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Disabled jest/no-conditional-expect
here (and below on lines 70, 92, and 95) to avoid refactoring further, which most likely require moving away from the current approach of using the iterative it.each
let matchMedia: MatchMediaMock; | ||
let mediaQueries = getMediaQueries({ breakpoints }); | ||
|
||
const testBreakpoints = (m) => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Curious why linting didn't like sharing this function. I thought it was pretty clever ;)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Eslint does not care abt cleverness 😭
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All jokes aside, maybe it kind of breaks jest idioms. Could see an argument for requiring the tests to be inside an it
for readability?
mediaQueries.reverse().forEach(testBreakpoints); | ||
it.each(mediaQueries)( | ||
`should return the $breakpoint breakpoint as expected`, | ||
({ query, breakpoint }) => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Couldn't this be the shared function here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tried that but it gives a linting error in the it
blocks because eslint thinks there are no tests inside. We could just disable that lint rule but thought it was probably okay to be more verbose since it's a test file
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Had a question on useMediaQueries test, but not a blocker
Description of changes
Begin the process of linting all the test files in
@aws-amplify/ui-react
:yarn react lint --fix
to autofix issuesjest
idiomaticit.each
Before (with linting turned on for test files):
data:image/s3,"s3://crabby-images/3347a/3347a7d499aa1a6d19fe04b2e194b111b0d3ed63" alt="Screen Shot 2023-01-13 at 2 40 09 PM"
After (with linting turned on for test files):
data:image/s3,"s3://crabby-images/09fde/09fde819d2dbcf018197e08800b282e2a895e08b" alt="Screen Shot 2023-01-13 at 2 41 17 PM"
Issue #, if available
NA
Description of how you validated changes
yarn react lint && yarn react test
Checklist
yarn test
passessideEffects
field updatedBy submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.