.rubocop.yml 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  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: Allowed in `tootctl` CLI code and in boot ENV checker
  82. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsexit
  83. Rails/Exit:
  84. Exclude:
  85. - 'config/boot.rb'
  86. - 'lib/mastodon/cli/*.rb'
  87. Rails/SkipsModelValidations:
  88. Exclude:
  89. - 'db/*migrate/**/*'
  90. # Reason: We want to preserve the ability to migrate from arbitrary old versions,
  91. # and cannot guarantee that every installation has run every migration as they upgrade.
  92. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsunusedignoredcolumns
  93. Rails/UnusedIgnoredColumns:
  94. Enabled: false
  95. # Reason: Prevailing style choice
  96. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsnegateinclude
  97. Rails/NegateInclude:
  98. Enabled: false
  99. # Reason: Deprecated cop, will be removed in 3.0, replaced by SpecFilePathFormat
  100. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecfilepath
  101. RSpec/FilePath:
  102. Enabled: false
  103. # Reason:
  104. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecnamedsubject
  105. RSpec/NamedSubject:
  106. EnforcedStyle: named_only
  107. # Reason: Prevailing style choice
  108. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecnottonot
  109. RSpec/NotToNot:
  110. EnforcedStyle: to_not
  111. # Reason: Prevailing style uses numeric status codes, matches Rails/HttpStatus
  112. # https://docs.rubocop.org/rubocop-rspec/cops_rspec_rails.html#rspecrailshttpstatus
  113. RSpec/Rails/HttpStatus:
  114. EnforcedStyle: numeric
  115. # Reason: Match overrides from Rspec/FilePath rule above
  116. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecspecfilepathformat
  117. RSpec/SpecFilePathFormat:
  118. CustomTransform:
  119. ActivityPub: activitypub
  120. DeepL: deepl
  121. FetchOEmbedService: fetch_oembed_service
  122. OEmbedController: oembed_controller
  123. OStatus: ostatus
  124. # Reason:
  125. # https://docs.rubocop.org/rubocop/cops_style.html#styleclassandmodulechildren
  126. Style/ClassAndModuleChildren:
  127. Enabled: false
  128. # Reason: Classes mostly self-document with their names
  129. # https://docs.rubocop.org/rubocop/cops_style.html#styledocumentation
  130. Style/Documentation:
  131. Enabled: false
  132. # Reason: Enforce modern Ruby style
  133. # https://docs.rubocop.org/rubocop/cops_style.html#stylehashsyntax
  134. Style/HashSyntax:
  135. EnforcedStyle: ruby19_no_mixed_keys
  136. # Reason:
  137. # https://docs.rubocop.org/rubocop/cops_style.html#stylenumericliterals
  138. Style/NumericLiterals:
  139. AllowedPatterns:
  140. - \d{4}_\d{2}_\d{2}_\d{6} # For DB migration date version number readability
  141. # Reason:
  142. # https://docs.rubocop.org/rubocop/cops_style.html#stylepercentliteraldelimiters
  143. Style/PercentLiteralDelimiters:
  144. PreferredDelimiters:
  145. '%i': '()'
  146. '%w': '()'
  147. # Reason: Prefer less indentation in conditional assignments
  148. # https://docs.rubocop.org/rubocop/cops_style.html#styleredundantbegin
  149. Style/RedundantBegin:
  150. Enabled: false
  151. # Reason: Overridden to reduce implicit StandardError rescues
  152. # https://docs.rubocop.org/rubocop/cops_style.html#stylerescuestandarderror
  153. Style/RescueStandardError:
  154. EnforcedStyle: implicit
  155. # Reason: Simplify some spec layouts
  156. # https://docs.rubocop.org/rubocop/cops_style.html#stylesemicolon
  157. Style/Semicolon:
  158. AllowAsExpressionSeparator: true
  159. # Reason: Originally disabled for CodeClimate, and no config consensus has been found
  160. # https://docs.rubocop.org/rubocop/cops_style.html#stylesymbolarray
  161. Style/SymbolArray:
  162. Enabled: false
  163. # Reason:
  164. # https://docs.rubocop.org/rubocop/cops_style.html#styletrailingcommainarrayliteral
  165. Style/TrailingCommaInArrayLiteral:
  166. EnforcedStyleForMultiline: 'comma'
  167. # Reason:
  168. # https://docs.rubocop.org/rubocop/cops_style.html#styletrailingcommainhashliteral
  169. Style/TrailingCommaInHashLiteral:
  170. EnforcedStyleForMultiline: 'comma'
  171. Style/MiddleDot:
  172. Enabled: true