-
-
Notifications
You must be signed in to change notification settings - Fork 277
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
Remove RSpec/Capybara/FeatureMethods #1876
Conversation
1a63a27
to
71734b5
Compare
ca1b356
to
6ff8584
Compare
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.
I am curious to hear what @pirj thinks of this PR.
12a81f9
to
0b31e59
Compare
config/default.yml
Outdated
@@ -298,8 +298,15 @@ RSpec/DescribedClassModuleWrapping: | |||
RSpec/Dialect: | |||
Description: Enforces custom RSpec dialects. | |||
Enabled: false | |||
PreferredMethods: {} | |||
PreferredMethods: |
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.
It doesn’t feel right to change the config by default.
We can’t imply that those methods are always for capybara specs.
I can’t quickly find it, but I recall someone mentioned that ‘describe’ isn’t a safe correction for ‘feature’ that has a certain metadata attached to it by default.
I suggest instead adding what needs to be done to this message below:
in .rubocop.yml file, enable `RSpec/Dialect`.
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.
I agree. One thing we could do it to link from the obsoletion.yml message to https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecdialect, and add to the documentation in
rubocop-rspec/lib/rubocop/cop/rspec/dialect.rb
Lines 42 to 47 in 6f34025
# # ... | |
# end | |
# | |
class Dialect < Base | |
extend AutoCorrector | |
include MethodPreference |
diff --git a/lib/rubocop/cop/rspec/dialect.rb b/lib/rubocop/cop/rspec/dialect.rb
index 7140541c..95d75161 100644
--- a/lib/rubocop/cop/rspec/dialect.rb
+++ b/lib/rubocop/cop/rspec/dialect.rb
@@ -42,6 +42,19 @@ module RuboCop
# # ...
# end
#
+ # If you were previously using the `RSpec/Capybara/FeatureMethods` cop and
+ # want to keep disabling all Capybara-specific methods that have the same
+ # native RSpec method (e.g. are just aliases), use the following config:
+ #
+ # RSpec/Dialect:
+ # PreferredMethods:
+ # background: :before
+ # scenario: :it
+ # xscenario: :xit
+ # given: :let
+ # given!: :let!
+ # feature: :describe
+ #
class Dialect < Base
extend AutoCorrector
include MethodPreference
Nice! A small note on config, otherwise looks good. Thank you! I’m sorry if I’ve missed that in some other ticket/pr/discussion, is there anything that’s stopping us from releasing 3.0 with those breaking changes as our next release? I’ve seen that we have two branches now. |
No, I don’t think there’s a whole lot more to be done before releasing a v3.0 ✨ I started a discussion at #1880. |
18e76cd
to
7e64055
Compare
@ydah Could you please rebase once again? Related: Should I enable the “Always suggest updating pull request branches” feature for the repo?
That would mean other maintainers could easily rebase a PR (or merge origin/master in), but perhaps at the cost of (many) more commits, and a more confusing workflow for the contributor whose local branch no longer matches the remote. |
7e64055
to
141c7d4
Compare
@bquorning I did it!
I think it's a very good point of view. IMO, but we don't want to rush the merge. And confuse PR authors. So I think it's fine the way it is. |
be84bef
to
1fa9ce3
Compare
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.
Perfect ❤️
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.
Incredible! Thank you!
One last smoke check - does rubocop-capybara’s spec suite still pass with this?
I tried it locally, and the specs and most of the |
I ran rubocop with this branch of rubocop-rspec on a rather large project at work, and the only unexpected issue I encountered was the problem with rubocop-rspec_rails described in #1884 (which is easily fixed after our next release). This PR is ready to merge! |
Fix: #1852
Before submitting the PR make sure the following are checked:
master
(if not - rebase it).CHANGELOG.md
if the new code introduces user-observable changes.bundle exec rake
) passes (be sure to run this locally, since it may produce updated documentation that you will need to commit).If you have modified an existing cop's configuration options:
VersionChanged: "<<next>>"
inconfig/default.yml
.