-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.rubocop.yml
274 lines (221 loc) · 5.41 KB
/
.rubocop.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
plugins:
- rubocop-performance
- rubocop-rails
- rubocop-rspec
require:
- rubocop-factory_bot
- rubocop-rspec_rails
AllCops:
TargetRailsVersion: 7.2
TargetRubyVersion: 3.4
NewCops: enable
Exclude:
- 'bin/**'
- 'db/schema.rb'
- 'vendor/**'
# -----------------------------------------------------------------------------
# RAILS
Rails:
Enabled: true
#
# It's often easier to understand what explicit methods like "#append" and
# "#concat" actually do compared to operators like "<<" and "+" for arrays.
#
Rails/ActiveSupportAliases:
Enabled: false
#
# False positives:
# * On embedded models in migrations.
#
Rails/ApplicationRecord:
Exclude:
- 'db/**/*'
#
# To broken for other methods in non-Rails contexts
#
Rails/Delegate:
Enabled: false
#
# Often when triggered it just wants to pass joined paths as separate
# arguments but that can hurt readability.
#
Rails/FilePath:
Enabled: false
#
# False positives:
# * Specs and migrations often need to update things without validations.
#
Rails/SkipsModelValidations:
Exclude:
- 'db/migrations/**.rb'
- 'spec/**/*_spec.rb'
#
# We cannot change existing migrations.
#
Rails/ThreeStateBooleanColumn:
Exclude:
- db/migrate/20160501000003_create_quality_control.rb
- db/migrate/20160501000007_change_rule_col_type_to_bool.rb
- db/migrate/20160607123036_add_is_global_field.rb
- db/migrate/20160805112014_add_course_statistics.rb
# -----------------------------------------------------------------------------
# RSPEC
RSpec:
Include:
- 'spec/**/*_spec.rb'
- 'spec/spec_helper.rb'
- 'spec/rails_helper.rb'
RSpec/ContextWording:
Enabled: false
RSpec/DescribeClass:
Exclude:
- spec/features/**/*_spec.rb
- spec/requests/**/*_spec.rb
RSpec/ExampleLength:
Enabled: false
RSpec/ExpectInHook:
Enabled: false
RSpec/SpecFilePathFormat:
Exclude:
- 'spec/client/**/*_spec.rb'
CustomTransform:
OpenHPI: openhpi
RSpec/MessageSpies:
Enabled: false
RSpec/MissingExampleGroupArgument:
Enabled: false
RSpec/MultipleExpectations:
Enabled: false
RSpec/NestedGroups:
Max: 5
#
# TODO: We have too many specs with too many lets!
#
RSpec/MultipleMemoizedHelpers:
Max: 52
# -----------------------------------------------------------------------------
# Layout
Layout/ArgumentAlignment:
EnforcedStyle: with_fixed_indentation
Layout/CaseIndentation:
EnforcedStyle: end
SupportedStyles:
- case
- end
IndentOneStep: true
Layout/FirstArrayElementIndentation:
EnforcedStyle: consistent
Layout/FirstHashElementIndentation:
EnforcedStyle: consistent
Layout/LineLength:
Exclude:
- 'db/**/*'
- 'spec/**/*'
- 'config/**/*'
Max: 120
Layout/MultilineMethodCallIndentation:
EnforcedStyle: indented
Layout/SpaceInsideBlockBraces:
EnforcedStyle: space
EnforcedStyleForEmptyBraces: no_space
SpaceBeforeBlockParameters: false
Layout/SpaceInsideHashLiteralBraces:
EnforcedStyle: no_space
# -----------------------------------------------------------------------------
# Lint
#
# False positives:
# * expect { something }.to change { something } often triggers this
#
Lint/AmbiguousBlockAssociation:
Exclude:
- 'spec/**/*_spec.rb'
# -----------------------------------------------------------------------------
# Metrics
Metrics/BlockLength:
Exclude:
- 'db/**/*'
- 'spec/**/*'
- 'config/**/*'
- 'lib/lanalytics/metric/*.rb'
- 'app/models/reports/**/*.rb'
- 'Rakefile'
- '**/*.rake'
Metrics/ClassLength:
Max: 200
Exclude:
- 'lib/lanalytics/metric/*.rb'
- 'app/models/reports/**/*.rb'
#
# Often used as a proxy for complexity in a method, but causes many false
# positives, e.g. when generating large, but simple, hashes.
# We want to rely on CyclomaticComplexity instead.
#
Metrics/MethodLength:
Enabled: false
#
# Method calls add to this metric, but they are everywhere in Ruby, so this
# metric caused lots of what we would consider false positives.
#
Metrics/AbcSize:
Enabled: false
Metrics/CyclomaticComplexity:
Enabled: false
Metrics/PerceivedComplexity:
Enabled: false
# -----------------------------------------------------------------------------
# Style
#
# Both styles or mixtures are reasonable
#
Style/ClassAndModuleChildren:
EnforcedStyle: compact
Enabled: false
#
# Would be better but unlikely...
#
Style/Documentation:
Enabled: false
#
# Okay for conditions, but false positive in return statements (e.g. APIs)
#
Style/DoubleNegation:
Enabled: false
#
# Scripts might include on top-level
#
Style/MixinUsage:
Exclude:
- 'scripts/**/*'
Style/NumericPredicate:
Enabled: false
Style/RaiseArgs:
EnforcedStyle: compact
#
# Quick single line rescues in specs
#
Style/RescueModifier:
Exclude:
- 'spec/**/*_spec.rb'
#
# Quick single line rescues in specs
#
Style/RescueStandardError:
# xikolo/lint#2
Enabled: false
Exclude:
- 'spec/**/*_spec.rb'
#
# Often used pattern in chaining subjects in specs
#
Style/Semicolon:
Exclude:
- 'spec/**/*_spec.rb'
Style/SignalException:
EnforcedStyle: only_raise
Style/TrailingCommaInArguments:
EnforcedStyleForMultiline: comma
Style/TrailingCommaInArrayLiteral:
EnforcedStyleForMultiline: comma
Style/TrailingCommaInHashLiteral:
EnforcedStyleForMultiline: comma