-
Notifications
You must be signed in to change notification settings - Fork 73
/
.rubocop.yml
147 lines (111 loc) · 3.65 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
####################################################################################################
# AllCops Configurations
####################################################################################################
AllCops:
TargetRubyVersion: 3.0
SuggestExtensions: false
NewCops: enable
Exclude:
- .bundle/**/*
- bin/**/*
- vendor/**/*
- tmp/**/*
- log/**/*
- spec/support/**/*
- spec/factories/**/*
- spec/fixtures/**/*
- spec/pb/**/*
- spec/demo_server
require:
- rubocop-performance
- rubocop-rspec
- rubocop-thread_safety
####################################################################################################
# Layout Configurations
####################################################################################################
Layout/EndAlignment:
Enabled: false
Layout/LineLength:
Max: 120
####################################################################################################
# Lint Configurations
####################################################################################################
# Rubocop is opinionated here, which makes compositional base classes/interfaces with keyword arguments problematic.
# Disabling this allows base class stub methods to have keyword args.
Lint/UnusedMethodArgument:
AllowUnusedKeywordArguments: true
####################################################################################################
# Metrics Configurations
####################################################################################################
Metrics/AbcSize:
Max: 147
Metrics/BlockLength:
Enabled: false
Metrics/ClassLength:
Max: 406
Metrics/CyclomaticComplexity:
Max: 12
Metrics/MethodLength:
Max: 88
Metrics/ModuleLength:
Max: 1000
Metrics/ParameterLists:
Max: 9
MaxOptionalParameters: 5
Metrics/PerceivedComplexity:
Max: 12
Style/ArgumentsForwarding:
Enabled: false
####################################################################################################
# Naming Configurations
####################################################################################################
Naming/PredicateName:
Enabled: false
####################################################################################################
# RSpec Configurations
####################################################################################################
RSpec/AnyInstance:
Enabled: false
RSpec/ContextWording:
inherit_mode:
merge:
- Prefixes
Prefixes:
- and
RSpec/DescribeClass:
Exclude:
- spec/gruf/functional/**/*
RSpec/ExampleLength:
Max: 50
RSpec/IndexedLet:
Enabled: false
RSpec/IteratedExpectation:
Exclude:
- spec/gruf/functional/**/*
RSpec/MessageSpies:
EnforcedStyle: receive
RSpec/MultipleExpectations:
Max: 30
RSpec/MultipleMemoizedHelpers:
Enabled: false
RSpec/NamedSubject:
Enabled: false
RSpec/NestedGroups:
Enabled: false
RSpec/StubbedMock:
Enabled: false
# This does not work with RPC messages
RSpec/VerifiedDoubles:
Enabled: false
####################################################################################################
# Style Configurations
####################################################################################################
# We prefer the leading constant declaration for easier refactoring
Style/RedundantConstantBase:
Enabled: false
####################################################################################################
# ThreadSafety Configurations
####################################################################################################
# We're fine with this
ThreadSafety/NewThread:
Enabled: false