-
Notifications
You must be signed in to change notification settings - Fork 0
/
.rubocop.yml
96 lines (79 loc) · 2.2 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
require:
- rubocop-rspec
- rubocop-rails
Rails:
Enabled: true
Style/Documentation:
Enabled: true
AllCops:
NewCops: enable
SuggestExtensions: false
DisplayCopNames: true
TargetRubyVersion: 2.7
TargetRailsVersion: 5.2
Exclude:
- bin/**/*
- vendor/**/*
- build/**/*
- gemfiles/**/*
Metrics/BlockLength:
Exclude:
- Rakefile
- '*.gemspec'
- spec/**/*.rb
- '**/*.rake'
- doc/**/*.rb
# Concerns and middlewares contain by nature long blocks
- lib/price*hubble/entity/concern/**/*.rb
- lib/price*hubble/client/request/**/*.rb
- lib/price*hubble/client/response/**/*.rb
# Our examples use +pp+ a lot
Lint/Debugger:
Exclude:
- doc/examples/**/*.rb
# MFA is not yet enabled for our gems yet.
Gemspec/RequireMFA:
Enabled: false
# Document all the things.
Style/DocumentationMethod:
Enabled: true
RequireForNonPublicMethods: true
# It's a deliberate idiom in RSpec.
# See: https://github.com/bbatsov/rubocop/issues/4222
Lint/AmbiguousBlockAssociation:
Exclude:
- "spec/**/*"
# Because +expect_any_instance_of().to have_received()+ is not
# supported with the +with(hash_including)+ matchers
RSpec/MessageSpies:
EnforcedStyle: receive
# Because nesting makes sense here to group the feature tests
# more effective. This increases maintainability.
RSpec/NestedGroups:
Max: 4
# Disable regular Rails spec paths.
RSpec/FilePath:
Enabled: false
# Because we just implemented the ActiveRecord API.
Rails/SkipsModelValidations:
Enabled: false
# Because of the clean wording on the examples.
Lint/ShadowingOuterLocalVariable:
Exclude:
- "doc/**/*"
# We stay at 80 characters per line.
# See: https://rubystyle.guide/#max-line-length
Layout/LineLength:
Max: 80
# We use memoized helpers all over the place to construct inputs and output
# which can be customized at nested contexts easily.
RSpec/MultipleMemoizedHelpers:
Enabled: false
# That are false-positives because we implement similar working
# helpers for associations like +.has_one+.
Rails/ReflectionClassName:
Enabled: false
# A very nice feature, but it does not work for non-method code parts atow.
# So just disabling it for now.
Style/DocumentDynamicEvalDefinition:
Enabled: false