Skip to content
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

feat: add no-container rule #177

Merged
merged 21 commits into from
Jun 21, 2020
Merged

Conversation

thebinaryfelix
Copy link
Contributor

@thebinaryfelix thebinaryfelix commented Jun 19, 2020

Closes #171

This PR adds a new no-container rule for disallowing the use of container methods like querySelector, following best practices.

A refactor of the no-debug rule was made in order to extract two helper functions to node-utils.ts so they could be used by no-container.

Preview of how the message will appear (in VS Code):

screenshot-no-container-rule

@Belco90 Belco90 added this to the v4 milestone Jun 19, 2020
@Belco90 Belco90 changed the base branch from master to v4 June 19, 2020 16:49
@Belco90 Belco90 changed the title no-container rule feat: add no-container rule Jun 19, 2020
@Belco90 Belco90 added the new rule New rule to be included in the plugin label Jun 19, 2020
@gndelia
Copy link
Collaborator

gndelia commented Jun 19, 2020

Thanks for your PR! There are some conflicts with the files. Could you rebase/update your PR ? Thanks!

Copy link
Collaborator

@gndelia gndelia left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I added some comments. I Will continue reviewing it later. Thank you very much for this PR 🚀

docs/rules/no-container.md Show resolved Hide resolved
lib/rules/no-container.ts Outdated Show resolved Hide resolved
tests/lib/rules/no-container.test.ts Show resolved Hide resolved
@thebinaryfelix
Copy link
Contributor Author

I added some comments. I Will continue reviewing it later. Thank you very much for this PR 🚀

I'll take a look and work on them later, thanks for the review!

Copy link
Member

@Belco90 Belco90 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi Mateus! Thank you very much for this PR, specially about the custom render function refactor.

I added some comments, basically for adding more test cases (it could imply updating the rule implementation tho) and removing the rule from recommended config.

Let me know if you need help to address the feedback here or want to discuss something!

README.md Outdated Show resolved Hide resolved
docs/rules/no-container.md Show resolved Hide resolved
docs/rules/no-container.md Show resolved Hide resolved
docs/rules/no-container.md Outdated Show resolved Hide resolved
lib/index.ts Outdated Show resolved Hide resolved
lib/rules/no-container.ts Outdated Show resolved Hide resolved
tests/lib/rules/no-container.test.ts Outdated Show resolved Hide resolved
tests/lib/rules/no-container.test.ts Show resolved Hide resolved
Mateus Felix added 4 commits June 19, 2020 16:23
| add description about testing library frameworks
| add link to container docs
| remove recommended badge
docs/rules/no-container.md Show resolved Hide resolved
tests/lib/rules/no-container.test.ts Outdated Show resolved Hide resolved
@gndelia
Copy link
Collaborator

gndelia commented Jun 20, 2020

I think that by using destructuring, it'd be also possible to bypass this rule

const { container: { querySelector } } = render(<Example />);
querySelector('foo');

I don't generally use that double-nested destructuring because I find it really hard to read 😆 but it's valid js code. The rule should probably cover it. Can we add it to the docs as invalid, and in the tests? I followed the code and I think it does not cover this scenario (but I might be wrong)

lib/rules/no-container.ts Outdated Show resolved Hide resolved
@nickserv nickserv linked an issue Jun 20, 2020 that may be closed by this pull request
@nickserv nickserv removed this from the v4 milestone Jun 20, 2020
@thebinaryfelix
Copy link
Contributor Author

I think that by using destructuring, it'd be also possible to bypass this rule

const { container: { querySelector } } = render(<Example />);
querySelector('foo');

I don't generally use that double-nested destructuring because I find it really hard to read laughing but it's valid js code. The rule should probably cover it. Can we add it to the docs as invalid, and in the tests? I followed the code and I think it does not cover this scenario (but I might be wrong)

You're right! It didn't cover this scenario, I've adjusted the code now. If you think of any other case, please let me know.

@thebinaryfelix
Copy link
Contributor Author

thebinaryfelix commented Jun 20, 2020

I think that by using destructuring, it'd be also possible to bypass this rule

const { container: { querySelector } } = render(<Example />);
querySelector('foo');

I don't generally use that double-nested destructuring because I find it really hard to read laughing but it's valid js code. The rule should probably cover it. Can we add it to the docs as invalid, and in the tests? I followed the code and I think it does not cover this scenario (but I might be wrong)

You're right! It didn't cover this scenario, I've adjusted the code now. If you think of any other case, please let me know.

Actually there's another case where the user could rename the method by doing something like:

const { container: { querySelector: alias } } = render(<Example />);
alias("foo");

And we could verify that recursively, but do we really wanna go that far to validate it? Also, if anyone has another approach for how to check that, feel free to share it.

@Belco90
Copy link
Member

Belco90 commented Jun 20, 2020

Actually there's another case where the user could rename the method by doing something like:

const { container: { querySelector: alias } } = render(<Example />);
alias("foo");

And we could verify that recursively, but do we really wanna go that far to validate it? Also, if anyone has another approach for how to check that, feel free to share it.

I'm against going that far in general. We need to cover different cases which are pretty common, but this is a really weird edge case I would say. So I'd go ahead with a basic coverage of different usages of this method (which is actually really nice) and leave that complex destructuring case as a future improvement.

lib/rules/no-container.ts Outdated Show resolved Hide resolved
Copy link
Member

@Belco90 Belco90 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looking good now. Amazing job here mate, thank you very much for your work and patience 😅

@Belco90 Belco90 requested a review from gndelia June 21, 2020 10:33
Copy link
Collaborator

@gndelia gndelia left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM 🚀

@gndelia gndelia merged commit 86f9c84 into testing-library:v4 Jun 21, 2020
@gndelia
Copy link
Collaborator

gndelia commented Jun 21, 2020

@all-contributors please add @thebinaryfelix for code, tests and doc

@allcontributors
Copy link
Contributor

@gndelia

I've put up a pull request to add @thebinaryfelix! 🎉

@Belco90
Copy link
Member

Belco90 commented Jun 22, 2020

I need to update contributing guidelines with a section for maintainers. Meanwhile, please let's try to squash merge PRs to make the commit messages fit with the semantic release changelogs (except when merging v4 to master for example, so we don't ruin the original commits as I did when merging v3 😓 ).

@Belco90 Belco90 mentioned this pull request Jun 22, 2020
19 tasks
@gndelia
Copy link
Collaborator

gndelia commented Jun 22, 2020

Hey @Belco90 I don't have access, but I think there should be a way in the settings to only allow squash merges in PR

image

(this is from another project I work for)

Perhaps that could help to avoid missing squashes. (but yeah, we'd need to be careful when merging v4 to master - we'd need to disable it there)

I reviewed the commit message so it fit the semantic release, but I missed the squash. Sorry for that 😓

@Belco90
Copy link
Member

Belco90 commented Jun 22, 2020

No problem, not a big deal as I can update the release notes after the release itself. I don't want to force always squash merging tho, as it's useful to allow merge commits too (for example when merging v4 to master).

@github-actions
Copy link

🎉 This PR is included in version 4.0.0-beta.1 🎉

The release is available on:

Your semantic-release bot 📦🚀

@github-actions
Copy link

🎉 This PR is included in version 4.0.0 🎉

The release is available on:

Your semantic-release bot 📦🚀

@MichaelDeBoey MichaelDeBoey added this to the v4 milestone Apr 15, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
new rule New rule to be included in the plugin released on @beta released
Projects
None yet
Development

Successfully merging this pull request may close these issues.

new rule: no-container
5 participants