.rubocop.yml 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. # Can be removed once all rules are addressed or moved to this file as documented overrides
  2. inherit_from: .rubocop_todo.yml
  3. # Used for merging with exclude lists with .rubocop_todo.yml
  4. inherit_mode:
  5. merge:
  6. - Exclude
  7. require:
  8. - rubocop-rails
  9. - rubocop-rspec
  10. - rubocop-performance
  11. - rubocop-capybara
  12. - ./lib/linter/rubocop_middle_dot
  13. AllCops:
  14. TargetRubyVersion: 3.0 # Set to minimum supported version of CI
  15. DisplayCopNames: true
  16. DisplayStyleGuide: true
  17. ExtraDetails: true
  18. UseCache: true
  19. CacheRootDirectory: tmp
  20. NewCops: enable # Opt-in to newly added rules
  21. Exclude:
  22. - db/schema.rb
  23. - 'bin/*'
  24. - 'node_modules/**/*'
  25. - 'Vagrantfile'
  26. - 'vendor/**/*'
  27. - 'config/initializers/json_ld*' # Generated files
  28. - 'lib/mastodon/migration_helpers.rb' # Vendored from GitLab
  29. - 'lib/templates/**/*'
  30. # Reason: Prefer Hashes without extreme indentation
  31. # https://docs.rubocop.org/rubocop/cops_layout.html#layoutfirsthashelementindentation
  32. Layout/FirstHashElementIndentation:
  33. EnforcedStyle: consistent
  34. # Reason: Currently disabled in .rubocop_todo.yml
  35. # https://docs.rubocop.org/rubocop/cops_layout.html#layoutlinelength
  36. Layout/LineLength:
  37. Max: 320 # Default of 120 causes a duplicate entry in generated todo file
  38. # Reason:
  39. # https://docs.rubocop.org/rubocop/cops_lint.html#lintuselessaccessmodifier
  40. Lint/UselessAccessModifier:
  41. ContextCreatingMethods:
  42. - class_methods
  43. ## Disable most Metrics/*Length cops
  44. # Reason: those are often triggered and force significant refactors when this happend
  45. # but the team feel they are not really improving the code quality.
  46. # https://docs.rubocop.org/rubocop/cops_metrics.html#metricsblocklength
  47. Metrics/BlockLength:
  48. Enabled: false
  49. # https://docs.rubocop.org/rubocop/cops_metrics.html#metricsclasslength
  50. Metrics/ClassLength:
  51. Enabled: false
  52. # https://docs.rubocop.org/rubocop/cops_metrics.html#metricsmethodlength
  53. Metrics/MethodLength:
  54. Enabled: false
  55. # https://docs.rubocop.org/rubocop/cops_metrics.html#metricsmodulelength
  56. Metrics/ModuleLength:
  57. Enabled: false
  58. ## End Disable Metrics/*Length cops
  59. # Reason: Currently disabled in .rubocop_todo.yml
  60. # https://docs.rubocop.org/rubocop/cops_metrics.html#metricsabcsize
  61. Metrics/AbcSize:
  62. Exclude:
  63. - 'lib/mastodon/cli/*.rb'
  64. # Reason: Currently disabled in .rubocop_todo.yml
  65. # https://docs.rubocop.org/rubocop/cops_metrics.html#metricscyclomaticcomplexity
  66. Metrics/CyclomaticComplexity:
  67. Exclude:
  68. - lib/mastodon/cli/*.rb
  69. # Reason:
  70. # https://docs.rubocop.org/rubocop/cops_metrics.html#metricsparameterlists
  71. Metrics/ParameterLists:
  72. CountKeywordArgs: false
  73. # Reason: Prevailing style is argument file paths
  74. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsfilepath
  75. Rails/FilePath:
  76. EnforcedStyle: arguments
  77. # Reason: Prevailing style uses numeric status codes, matches RSpec/Rails/HttpStatus
  78. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railshttpstatus
  79. Rails/HttpStatus:
  80. EnforcedStyle: numeric
  81. # Reason: Conflicts with `Lint/UselessMethodDefinition` for inherited controller actions
  82. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railslexicallyscopedactionfilter
  83. Rails/LexicallyScopedActionFilter:
  84. Exclude:
  85. - 'app/controllers/auth/*'
  86. # Reason: These tasks are doing local work which do not need full env loaded
  87. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsrakeenvironment
  88. Rails/RakeEnvironment:
  89. Exclude:
  90. - 'lib/tasks/auto_annotate_models.rake'
  91. - 'lib/tasks/emojis.rake'
  92. - 'lib/tasks/mastodon.rake'
  93. - 'lib/tasks/repo.rake'
  94. - 'lib/tasks/statistics.rake'
  95. # Reason: There are appropriate times to use these features
  96. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsskipsmodelvalidations
  97. Rails/SkipsModelValidations:
  98. Enabled: false
  99. # Reason: We want to preserve the ability to migrate from arbitrary old versions,
  100. # and cannot guarantee that every installation has run every migration as they upgrade.
  101. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsunusedignoredcolumns
  102. Rails/UnusedIgnoredColumns:
  103. Enabled: false
  104. # Reason: Prevailing style choice
  105. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsnegateinclude
  106. Rails/NegateInclude:
  107. Enabled: false
  108. # Reason: Enforce default limit, but allow some elements to span lines
  109. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecexamplelength
  110. RSpec/ExampleLength:
  111. CountAsOne: ['array', 'heredoc', 'method_call']
  112. # Reason: Deprecated cop, will be removed in 3.0, replaced by SpecFilePathFormat
  113. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecfilepath
  114. RSpec/FilePath:
  115. Enabled: false
  116. # Reason:
  117. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecnamedsubject
  118. RSpec/NamedSubject:
  119. EnforcedStyle: named_only
  120. # Reason: Prevailing style choice
  121. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecnottonot
  122. RSpec/NotToNot:
  123. EnforcedStyle: to_not
  124. # Reason: Prevailing style uses numeric status codes, matches Rails/HttpStatus
  125. # https://docs.rubocop.org/rubocop-rspec/cops_rspec_rails.html#rspecrailshttpstatus
  126. RSpec/Rails/HttpStatus:
  127. EnforcedStyle: numeric
  128. # Reason: Match overrides from Rspec/FilePath rule above
  129. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecspecfilepathformat
  130. RSpec/SpecFilePathFormat:
  131. CustomTransform:
  132. ActivityPub: activitypub
  133. DeepL: deepl
  134. FetchOEmbedService: fetch_oembed_service
  135. OEmbedController: oembed_controller
  136. OStatus: ostatus
  137. # Reason:
  138. # https://docs.rubocop.org/rubocop/cops_style.html#styleclassandmodulechildren
  139. Style/ClassAndModuleChildren:
  140. Enabled: false
  141. # Reason: Classes mostly self-document with their names
  142. # https://docs.rubocop.org/rubocop/cops_style.html#styledocumentation
  143. Style/Documentation:
  144. Enabled: false
  145. # Reason: Route redirects are not token-formatted and must be skipped
  146. # https://docs.rubocop.org/rubocop/cops_style.html#styleformatstringtoken
  147. Style/FormatStringToken:
  148. inherit_mode:
  149. merge:
  150. - AllowedMethods # The rubocop-rails config adds `redirect`
  151. AllowedMethods:
  152. - redirect_with_vary
  153. # Reason: Enforce modern Ruby style
  154. # https://docs.rubocop.org/rubocop/cops_style.html#stylehashsyntax
  155. Style/HashSyntax:
  156. EnforcedStyle: ruby19_no_mixed_keys
  157. # Reason:
  158. # https://docs.rubocop.org/rubocop/cops_style.html#stylenumericliterals
  159. Style/NumericLiterals:
  160. AllowedPatterns:
  161. - \d{4}_\d{2}_\d{2}_\d{6} # For DB migration date version number readability
  162. # Reason:
  163. # https://docs.rubocop.org/rubocop/cops_style.html#stylepercentliteraldelimiters
  164. Style/PercentLiteralDelimiters:
  165. PreferredDelimiters:
  166. '%i': '()'
  167. '%w': '()'
  168. # Reason: Prefer less indentation in conditional assignments
  169. # https://docs.rubocop.org/rubocop/cops_style.html#styleredundantbegin
  170. Style/RedundantBegin:
  171. Enabled: false
  172. # Reason: Overridden to reduce implicit StandardError rescues
  173. # https://docs.rubocop.org/rubocop/cops_style.html#stylerescuestandarderror
  174. Style/RescueStandardError:
  175. EnforcedStyle: implicit
  176. # Reason: Simplify some spec layouts
  177. # https://docs.rubocop.org/rubocop/cops_style.html#stylesemicolon
  178. Style/Semicolon:
  179. AllowAsExpressionSeparator: true
  180. # Reason: Originally disabled for CodeClimate, and no config consensus has been found
  181. # https://docs.rubocop.org/rubocop/cops_style.html#stylesymbolarray
  182. Style/SymbolArray:
  183. Enabled: false
  184. # Reason:
  185. # https://docs.rubocop.org/rubocop/cops_style.html#styletrailingcommainarrayliteral
  186. Style/TrailingCommaInArrayLiteral:
  187. EnforcedStyleForMultiline: 'comma'
  188. # Reason:
  189. # https://docs.rubocop.org/rubocop/cops_style.html#styletrailingcommainhashliteral
  190. Style/TrailingCommaInHashLiteral:
  191. EnforcedStyleForMultiline: 'comma'
  192. Style/MiddleDot:
  193. Enabled: true