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

Pluginfy RuboCop Airbnb #212

Merged
merged 1 commit into from
Mar 21, 2025
Merged

Pluginfy RuboCop Airbnb #212

merged 1 commit into from
Mar 21, 2025

Conversation

koic
Copy link
Contributor

@koic koic commented Mar 12, 2025

This PR adds support for RuboCop's Plugin feature.

It replaces the ad-hoc Inject hack with the RuboCop plugin system introduced in RuboCop 1.72.

Accordingly, rubocop-airbnb has been updated to require specific versions of the following RuboCop extension plugins it depends on

  • rubocop-performance (~> 1.24)
  • rubocop-rails (~> 2.30)
  • rubocop-rspec (~> 3.5)

The most significant change is that rubocop-rspec has been updated from version 2 to version 3. As a result, RSpec/Capybara and RSpec/FactoryBot have been extracted into the following extension gems:

  • rubocop-capybara
  • rubocop-factory_bot

This PR adds dependencies on both rubocop-capybara and rubocop-rspec extensions to maintain the previous rubocop-rspec configuration.

RSpec/FilePath has been split into RSpec/SpecFilePathFormat and RSpec/SpecFilePathSuffix, so the original disabling has been retained in the configuration. Similarly, RSpec/Capybara/FeatureMethods remains disabled as RSpec/Dialect.
https://github.com/rubocop/rubocop-rspec/blob/v3.5.0/config/obsoletion.yml

Resolves rubocop/rubocop-factory_bot#147.

This PR adds support for RuboCop's Plugin feature.

It replaces the ad-hoc `Inject` hack with the RuboCop plugin system introduced in RuboCop 1.72.

- rubocop/rubocop#13792
- https://docs.rubocop.org/rubocop/plugin_migration_guide.html

Accordingly, rubocop-airbnb has been updated to require specific versions of the following
RuboCop extension plugins it depends on

- rubocop-performance (`~> 1.24`)
- rubocop-rails (`~> 2.30`)
- rubocop-rspec (`~> 3.5`)

The most significant change is that rubocop-rspec has been updated from version 2 to version 3.
As a result, `RSpec/Capybara` and `RSpec/FactoryBot` have been extracted into the following extension gems:

- rubocop-capybara
- rubocop-factory_bot

This PR adds dependencies on both rubocop-capybara and rubocop-rspec extensions to maintain
the previous rubocop-rspec configuration.

`RSpec/FilePath` has been split into `RSpec/SpecFilePathFormat` and `RSpec/SpecFilePathSuffix`,
so the original disabling has been retained in the configuration.
Similarly, `RSpec/Capybara/FeatureMethods` remains disabled as `RSpec/Dialect`.
https://github.com/rubocop/rubocop-rspec/blob/v3.5.0/config/obsoletion.yml

Resolves rubocop/rubocop-factory_bot#147.
@koic koic force-pushed the plugin_lint_roller branch from e2f3819 to fcdaa27 Compare March 12, 2025 03:50
Copy link
Contributor

@pariser pariser left a comment

Choose a reason for hiding this comment

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

Thanks for these changes!

@pariser pariser merged commit c0e77f4 into airbnb:main Mar 21, 2025
4 checks passed
@pariser pariser mentioned this pull request Mar 21, 2025
@pariser
Copy link
Contributor

pariser commented Mar 21, 2025

Released as part of https://rubygems.org/gems/rubocop-airbnb/versions/8.0.0

@koic koic deleted the plugin_lint_roller branch March 22, 2025 00:28
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

FactoryBot/CreateList is crashing out with "undefined method 'to_sym' for nil"
2 participants