.rubocop.yml 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  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. - db/*migrate/**/*
  65. # Reason: Currently disabled in .rubocop_todo.yml
  66. # https://docs.rubocop.org/rubocop/cops_metrics.html#metricscyclomaticcomplexity
  67. Metrics/CyclomaticComplexity:
  68. Exclude:
  69. - lib/mastodon/cli/*.rb
  70. - db/*migrate/**/*
  71. # Reason:
  72. # https://docs.rubocop.org/rubocop/cops_metrics.html#metricsparameterlists
  73. Metrics/ParameterLists:
  74. CountKeywordArgs: false
  75. # Reason: Prevailing style is argument file paths
  76. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsfilepath
  77. Rails/FilePath:
  78. EnforcedStyle: arguments
  79. # Reason: Prevailing style uses numeric status codes, matches RSpec/Rails/HttpStatus
  80. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railshttpstatus
  81. Rails/HttpStatus:
  82. EnforcedStyle: numeric
  83. # Reason: Allowed in `tootctl` CLI code and in boot ENV checker
  84. # https://docs.rubocop.org/rubocop-rails/cops_rails.html#railsexit
  85. Rails/Exit:
  86. Exclude:
  87. - 'config/boot.rb'
  88. - 'lib/mastodon/cli/*.rb'
  89. # Reason: Some single letter camel case files shouldn't be split
  90. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecfilepath
  91. RSpec/FilePath:
  92. CustomTransform:
  93. ActivityPub: activitypub
  94. DeepL: deepl
  95. FetchOEmbedService: fetch_oembed_service
  96. OEmbedController: oembed_controller
  97. OStatus: ostatus
  98. # Reason:
  99. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecnamedsubject
  100. RSpec/NamedSubject:
  101. EnforcedStyle: named_only
  102. # Reason: Prevailing style choice
  103. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecnottonot
  104. RSpec/NotToNot:
  105. EnforcedStyle: to_not
  106. # Reason: Prevailing style uses numeric status codes, matches Rails/HttpStatus
  107. # https://docs.rubocop.org/rubocop-rspec/cops_rspec_rails.html#rspecrailshttpstatus
  108. RSpec/Rails/HttpStatus:
  109. EnforcedStyle: numeric
  110. # Reason: Match overrides from Rspec/FilePath rule above
  111. # https://docs.rubocop.org/rubocop-rspec/cops_rspec.html#rspecspecfilepathformat
  112. RSpec/SpecFilePathFormat:
  113. CustomTransform:
  114. ActivityPub: activitypub
  115. DeepL: deepl
  116. FetchOEmbedService: fetch_oembed_service
  117. OEmbedController: oembed_controller
  118. OStatus: ostatus
  119. # Reason:
  120. # https://docs.rubocop.org/rubocop/cops_style.html#styleclassandmodulechildren
  121. Style/ClassAndModuleChildren:
  122. Enabled: false
  123. # Reason: Classes mostly self-document with their names
  124. # https://docs.rubocop.org/rubocop/cops_style.html#styledocumentation
  125. Style/Documentation:
  126. Enabled: false
  127. # Reason: Enforce modern Ruby style
  128. # https://docs.rubocop.org/rubocop/cops_style.html#stylehashsyntax
  129. Style/HashSyntax:
  130. EnforcedStyle: ruby19_no_mixed_keys
  131. # Reason:
  132. # https://docs.rubocop.org/rubocop/cops_style.html#stylenumericliterals
  133. Style/NumericLiterals:
  134. AllowedPatterns:
  135. - \d{4}_\d{2}_\d{2}_\d{6} # For DB migration date version number readability
  136. # Reason:
  137. # https://docs.rubocop.org/rubocop/cops_style.html#stylepercentliteraldelimiters
  138. Style/PercentLiteralDelimiters:
  139. PreferredDelimiters:
  140. '%i': '()'
  141. '%w': '()'
  142. # Reason: Prefer less indentation in conditional assignments
  143. # https://docs.rubocop.org/rubocop/cops_style.html#styleredundantbegin
  144. Style/RedundantBegin:
  145. Enabled: false
  146. # Reason: Overridden to reduce implicit StandardError rescues
  147. # https://docs.rubocop.org/rubocop/cops_style.html#stylerescuestandarderror
  148. Style/RescueStandardError:
  149. EnforcedStyle: implicit
  150. # Reason: Simplify some spec layouts
  151. # https://docs.rubocop.org/rubocop/cops_style.html#stylesemicolon
  152. Style/Semicolon:
  153. AllowAsExpressionSeparator: true
  154. # Reason: Originally disabled for CodeClimate, and no config consensus has been found
  155. # https://docs.rubocop.org/rubocop/cops_style.html#stylesymbolarray
  156. Style/SymbolArray:
  157. Enabled: false
  158. # Reason:
  159. # https://docs.rubocop.org/rubocop/cops_style.html#styletrailingcommainarrayliteral
  160. Style/TrailingCommaInArrayLiteral:
  161. EnforcedStyleForMultiline: 'comma'
  162. # Reason:
  163. # https://docs.rubocop.org/rubocop/cops_style.html#styletrailingcommainhashliteral
  164. Style/TrailingCommaInHashLiteral:
  165. EnforcedStyleForMultiline: 'comma'
  166. Style/MiddleDot:
  167. Enabled: true