Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/datarockets/ruby-style
Shared rubocop configs and custom linters for datarockets projects
https://github.com/datarockets/ruby-style
hacktoberfest linter rubocop ruby
Last synced: 23 days ago
JSON representation
Shared rubocop configs and custom linters for datarockets projects
- Host: GitHub
- URL: https://github.com/datarockets/ruby-style
- Owner: datarockets
- License: mit
- Created: 2019-03-24T17:40:06.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-08-27T13:23:16.000Z (4 months ago)
- Last Synced: 2024-12-09T18:02:16.235Z (24 days ago)
- Topics: hacktoberfest, linter, rubocop, ruby
- Language: Ruby
- Homepage:
- Size: 225 KB
- Stars: 10
- Watchers: 18
- Forks: 2
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Datarockets::Style [![Gem Version](https://badge.fury.io/rb/datarockets-style.svg)](https://badge.fury.io/rb/datarockets-style)
Datarockets shared style configs and notes of code-style conventions. Based on the [Rubocop](https://github.com/rubocop-hq/rubocop) util.
This config enforces many of the guidelines outlined in the datarockets [Ruby Style Guide](doc/STYLE_GUIDE.md).
## Installation
Add this line to your application's Gemfile:
```ruby
group :test, :development do
gem 'datarockets-style', '~> 1.6.0'
end
```Or, for a Ruby library, add this to your gemspec:
```ruby
spec.add_development_dependency 'datarockets-style', '~> 1.6.0'
```And then execute:
```bash
$ bundle install
```## Usage
Create a `.rubocop.yml` with the following directives:
### Ruby application
This config includes specific rules for Ruby application. It works for Ruby gems and no-Rails applications.
```yaml
inherit_gem:
datarockets-style:
- config/ruby.yml
```### Rails application
For Rails applications, you can use a specific Rails instead of Ruby config
```yaml
inherit_gem:
datarockets-style:
- config/rails.yml
```By default, it doesn't include rules for I18n. For enabling them, add the next styles
```yaml
inherit_gem:
datarockets-style:
- config/rails.yml
- config/rails-locales.yml
```### GraphQL config
To include specific rules for GraphQL, you can add the following config
```yaml
inherit_gem:
datarockets-style:
- config/graphql.yml
```### Rspec config
For Rspec tests, you can add a special rubocop config
```yaml
inherit_gem:
datarockets-style:
- config/ruby.yml
- config/rspec.yml
```Now, run:
```bash
$ bundle exec rubocop
```You do not need to include rubocop directly in your application's dependencies. Datarockets-style will include a specific version of `rubocop` and `rubocop-rspec` that is shared across all projects.
### Configurable cops
There are some areas in which there is no clear consensus in datarockets team regarding a particular style (like string literal quoting).
In such scenarios, all popular styles are acknowledged and it’s up to you to pick one and apply it consistently.
For that just set up these cops before starting of usage.#### RSpec/LetSetup
[This cop](https://rubocop-rspec.readthedocs.io/en/latest/cops_rspec/#rspecletsetup) is enabled by default and we suggest not to use unreferenced `let` variables in your test cases.
However, if it feels like the cop should be enabled and tests can't be written w/o them, please create an issue with your cases so that we can re-thinking our solution about enabling this cop.#### Style/StringLiterals
There are two popular styles in the Ruby community, both of which are considered good - single quotes by default and double quotes by default.
There is no clear consensus about this style in the Ruby community and in the datarockets team.
So we suggest just to set up a [preferable style](https://rubocop.readthedocs.io/en/latest/cops_style/#stylestringliterals) before running this gem.P.S. The string literals in this gem are using double quotes by default.
##### Tips
For an existing project, we suggest running rubocop with both styles and choose which has fewer offenses (which is more popular in the current project).
### Custom cops
We have custom cops. You can find specification for them [here](manual).
## Formatters
### ToDo list formatter
This formatter allows us to get list of files for some offense and with number of offenses in each file. This file can be useful if you need to fix a large some cop step by step.
Result of the formatter is compatible with rubocop config or rubocop todo file.
For running that cop, just print in your command like
```bash
$ bundle exec rubocop -f TodoListFormatter -r datarockets_style
Inspecting 10 files
...CC.CC..
10 files inspected, 7 offenses detectedLayout/IndentationConsistency:
Exclude:
- 'spec/datarockets_style/formatter/todo_list_formatter_spec.rb' # 1Naming/MemoizedInstanceVariableName:
Exclude:
- 'lib/datarockets_style/formatter/todo_list_formatter/report_summary.rb' # 1RSpec/ExampleLength:
Exclude:
- 'spec/datarockets_style/formatter/todo_list_formatter/report_summary_spec.rb' # 1
- 'spec/datarockets_style/formatter/todo_list_formatter_spec.rb' # 2Style/Documentation:
Exclude:
- 'lib/datarockets_style/formatter/todo_list_formatter/report_summary.rb' # 1
- 'lib/datarockets_style/formatter/todo_list_formatter.rb' # 1
```#### Autocorrection
If you run the formatter with autocorrection options, the formatter skip corrected cop and does not include it to the result.
```bash
$ bundle exec rubocop -f TodoListFormatter -r datarockets_style -a
Inspecting 10 files
...CC.CC..
10 files inspected, 7 offenses detected, 1 offenses correctedNaming/MemoizedInstanceVariableName:
Exclude:
- 'lib/datarockets_style/formatter/todo_list_formatter/report_summary.rb' # 1RSpec/ExampleLength:
Exclude:
- 'spec/datarockets_style/formatter/todo_list_formatter/report_summary_spec.rb' # 1
- 'spec/datarockets_style/formatter/todo_list_formatter_spec.rb' # 2Style/Documentation:
Exclude:
- 'lib/datarockets_style/formatter/todo_list_formatter/report_summary.rb' # 1
- 'lib/datarockets_style/formatter/todo_list_formatter.rb' # 1
```## Non-goals of RuboCop
### Rspec configuration
RSpec-core library provides some configuration rules which provides some linting rules itself. Read more about it in [RuboCop Rspec non-goals topic](https://github.com/rubocop-hq/rubocop-rspec#non-goals-of-rubocop-rspec).
## Changelog
Datarockets Style's changelog is available [here](CHANGELOG.md).
## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/datarockets/datarockets-style. If you'd like to contribute to our RuboCop config and code-style rules, please take the time to go through our short [contribution guidelines](CONTRIBUTING.md).
## License
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
## Code of Conduct
Everyone interacting in the DatarocketsStyle project’s codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](CODE_OF_CONDUCT.md).