558 lines
12 KiB
YAML
558 lines
12 KiB
YAML
inherit_gem:
|
|
gitlab-styles:
|
|
- rubocop-default.yml
|
|
|
|
require:
|
|
- ./rubocop/rubocop
|
|
- rubocop-rspec
|
|
|
|
inherit_from:
|
|
- .rubocop_todo.yml
|
|
- ./rubocop/rubocop-migrations.yml
|
|
- ./rubocop/rubocop-usage-data.yml
|
|
|
|
inherit_mode:
|
|
merge:
|
|
- Include
|
|
|
|
AllCops:
|
|
TargetRubyVersion: 2.6
|
|
TargetRailsVersion: 6.0
|
|
Exclude:
|
|
- 'vendor/**/*'
|
|
- 'node_modules/**/*'
|
|
- 'db/fixtures/**/*'
|
|
- 'db/schema.rb'
|
|
- 'ee/db/geo/schema.rb'
|
|
- 'tmp/**/*'
|
|
- 'bin/**/*'
|
|
- 'generator_templates/**/*'
|
|
- 'builds/**/*'
|
|
- 'plugins/**/*'
|
|
- 'file_hooks/**/*'
|
|
CacheRootDirectory: tmp
|
|
MaxFilesInCache: 18000
|
|
|
|
Cop/AvoidKeywordArgumentsInSidekiqWorkers:
|
|
Enabled: true
|
|
Include:
|
|
- 'app/workers/**/*'
|
|
- 'ee/app/workers/**/*'
|
|
|
|
Cop/StaticTranslationDefinition:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/**/*'
|
|
- 'ee/spec/**/*'
|
|
|
|
# This cop checks whether some constant value isn't a
|
|
# mutable literal (e.g. array or hash).
|
|
Style/MutableConstant:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'db/migrate/**/*'
|
|
- 'db/post_migrate/**/*'
|
|
- 'ee/db/migrate/**/*'
|
|
- 'ee/db/post_migrate/**/*'
|
|
- 'ee/db/geo/migrate/**/*'
|
|
|
|
# TODO: Move this to gitlab-styles
|
|
Style/SafeNavigation:
|
|
Enabled: false
|
|
|
|
Style/AccessModifierDeclarations:
|
|
AllowModifiersOnSymbols: true
|
|
|
|
# Frozen String Literal
|
|
Style/FrozenStringLiteralComment:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'config.ru'
|
|
- 'Dangerfile'
|
|
- 'Gemfile'
|
|
- 'Rakefile'
|
|
- 'app/views/**/*'
|
|
- 'config/**/*'
|
|
- 'danger/**/*'
|
|
- 'db/**/*'
|
|
- 'ee/db/**/*'
|
|
- 'ee/lib/tasks/**/*'
|
|
- 'lib/tasks/**/*'
|
|
- 'qa/**/*'
|
|
- 'rubocop/**/*'
|
|
- 'scripts/**/*'
|
|
|
|
RSpec/FilePath:
|
|
Exclude:
|
|
- 'qa/**/*'
|
|
- 'spec/frontend/fixtures/*'
|
|
- 'ee/spec/frontend/fixtures/*'
|
|
- 'spec/requests/api/v3/*'
|
|
|
|
Naming/FileName:
|
|
ExpectMatchingDefinition: true
|
|
Exclude:
|
|
- 'db/**/*'
|
|
- 'ee/db/**/*'
|
|
- 'spec/**/*'
|
|
- 'features/**/*'
|
|
- 'ee/spec/**/*'
|
|
- 'qa/spec/**/*'
|
|
- 'qa/qa/specs/**/*'
|
|
- 'qa/bin/*'
|
|
- 'ee/bin/*'
|
|
- 'config/**/*'
|
|
- 'ee/config/**/*'
|
|
- 'lib/generators/**/*'
|
|
- 'locale/unfound_translations.rb'
|
|
- 'ee/locale/unfound_translations.rb'
|
|
- 'ee/lib/generators/**/*'
|
|
- 'qa/qa/scenario/test/integration/ldap_no_tls.rb'
|
|
- 'qa/qa/scenario/test/integration/ldap_tls.rb'
|
|
|
|
IgnoreExecutableScripts: true
|
|
AllowedAcronyms:
|
|
- EE
|
|
- JSON
|
|
- LDAP
|
|
- SAML
|
|
- SSO
|
|
- IO
|
|
- HMAC
|
|
- QA
|
|
- ENV
|
|
- STL
|
|
- PDF
|
|
- SVG
|
|
- CTE
|
|
- DN
|
|
- RSA
|
|
- CI
|
|
- CD
|
|
- OAuth
|
|
# default ones:
|
|
- CLI
|
|
- DSL
|
|
- ACL
|
|
- API
|
|
- ASCII
|
|
- CPU
|
|
- CSS
|
|
- DNS
|
|
- EOF
|
|
- GUID
|
|
- HTML
|
|
- HTTP
|
|
- HTTPS
|
|
- ID
|
|
- IP
|
|
- JSON
|
|
- LHS
|
|
- QPS
|
|
- RAM
|
|
- RHS
|
|
- RPC
|
|
- SLA
|
|
- SMTP
|
|
- SQL
|
|
- SSH
|
|
- TCP
|
|
- TLS
|
|
- TTL
|
|
- UDP
|
|
- UI
|
|
- UID
|
|
- UUID
|
|
- URI
|
|
- URL
|
|
- UTF8
|
|
- VM
|
|
- XML
|
|
- XMPP
|
|
- XSRF
|
|
- XSS
|
|
- GRPC
|
|
|
|
Rails/ApplicationRecord:
|
|
Enabled: true
|
|
Exclude:
|
|
# Models in database migrations should not subclass from ApplicationRecord
|
|
# as they need to be as decoupled from application code as possible
|
|
- db/**/*.rb
|
|
- lib/gitlab/background_migration/**/*.rb
|
|
- ee/lib/ee/gitlab/background_migration/**/*.rb
|
|
- lib/gitlab/database/**/*.rb
|
|
- spec/**/*.rb
|
|
- ee/db/**/*.rb
|
|
- ee/spec/**/*.rb
|
|
|
|
Cop/DefaultScope:
|
|
Enabled: true
|
|
|
|
Rails/FindBy:
|
|
Enabled: true
|
|
Include:
|
|
- 'ee/app/**/*.rb'
|
|
- 'ee/lib/**/*.rb'
|
|
- 'spec/**/*.rb'
|
|
- 'ee/spec/**/*.rb'
|
|
|
|
# This is currently exiting with a rubocop exception error and should be
|
|
# resolved hopefully a future update
|
|
# An error occurred while Rails/UniqueValidationWithoutIndex cop was inspecting
|
|
# app/models/abuse_report.rb:15:2.
|
|
# To see the complete backtrace run rubocop -d.
|
|
Rails/UniqueValidationWithoutIndex:
|
|
Enabled: false
|
|
|
|
# GitLab ###################################################################
|
|
|
|
Gitlab/ModuleWithInstanceVariables:
|
|
Enable: true
|
|
Exclude:
|
|
# We ignore Rails helpers right now because it's hard to workaround it
|
|
- app/helpers/**/*_helper.rb
|
|
- ee/app/helpers/**/*_helper.rb
|
|
# We ignore Rails mailers right now because it's hard to workaround it
|
|
- app/mailers/emails/**/*.rb
|
|
- ee/**/emails/**/*.rb
|
|
# We ignore spec helpers because it usually doesn't matter
|
|
- spec/support/**/*.rb
|
|
- features/steps/**/*.rb
|
|
|
|
Gitlab/ConstGetInheritFalse:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'qa/bin/*'
|
|
|
|
Gitlab/ChangeTimezone:
|
|
Enabled: true
|
|
Exclude:
|
|
- config/initializers/time_zone.rb
|
|
|
|
Gitlab/HTTParty:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/**/*'
|
|
- 'ee/spec/**/*'
|
|
|
|
Gitlab/Json:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'db/**/*'
|
|
- 'qa/**/*'
|
|
- 'scripts/**/*'
|
|
- 'lib/rspec_flaky/**/*'
|
|
- 'lib/quality/**/*'
|
|
- 'lib/gitlab/danger/**/*'
|
|
|
|
Gitlab/AvoidUploadedFileFromParams:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'lib/gitlab/middleware/multipart.rb'
|
|
- 'spec/**/*'
|
|
- 'ee/spec/**/*'
|
|
|
|
GitlabSecurity/PublicSend:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'config/**/*'
|
|
- 'db/**/*'
|
|
- 'features/**/*'
|
|
- 'lib/**/*.rake'
|
|
- 'qa/**/*'
|
|
- 'spec/**/*'
|
|
- 'ee/db/**/*'
|
|
- 'ee/lib/**/*.rake'
|
|
- 'ee/spec/**/*'
|
|
|
|
Gitlab/DuplicateSpecLocation:
|
|
Enabled: true
|
|
|
|
Cop/InjectEnterpriseEditionModule:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/**/*'
|
|
- 'ee/spec/**/*'
|
|
|
|
Style/ReturnNil:
|
|
Enabled: true
|
|
|
|
# It isn't always safe to replace `=~` with `.match?`, especially when there are
|
|
# nil values on the left hand side
|
|
Performance/RegexpMatch:
|
|
Enabled: false
|
|
|
|
Cop/ActiveRecordAssociationReload:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/**/*'
|
|
- 'ee/spec/**/*'
|
|
|
|
Gitlab/AvoidFeatureGet:
|
|
Enabled: true
|
|
|
|
RSpec/TimecopFreeze:
|
|
Enabled: true
|
|
AutoCorrect: true
|
|
Include:
|
|
- 'spec/**/*.rb'
|
|
- 'ee/spec/**/*.rb'
|
|
- 'qa/spec/**/*.rb'
|
|
|
|
RSpec/TimecopTravel:
|
|
Enabled: false
|
|
AutoCorrect: true
|
|
Include:
|
|
- 'spec/**/*.rb'
|
|
- 'ee/spec/**/*.rb'
|
|
- 'qa/spec/**/*.rb'
|
|
|
|
Naming/PredicateName:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/**/*'
|
|
- 'ee/spec/**/*'
|
|
|
|
RSpec/FactoriesInMigrationSpecs:
|
|
Enabled: true
|
|
Include:
|
|
- 'spec/migrations/**/*.rb'
|
|
- 'ee/spec/migrations/**/*.rb'
|
|
- 'spec/lib/gitlab/background_migration/**/*.rb'
|
|
- 'spec/lib/ee/gitlab/background_migration/**/*.rb'
|
|
- 'ee/spec/lib/ee/gitlab/background_migration/**/*.rb'
|
|
|
|
Cop/IncludeSidekiqWorker:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/**/*'
|
|
- 'ee/spec/**/*'
|
|
|
|
Gitlab/Union:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/**/*'
|
|
- 'ee/spec/**/*'
|
|
|
|
API/GrapeAPIInstance:
|
|
Enabled: true
|
|
Include:
|
|
- 'lib/**/api/**/*.rb'
|
|
- 'ee/**/api/**/*.rb'
|
|
|
|
API/GrapeArrayMissingCoerce:
|
|
Enabled: true
|
|
Include:
|
|
- 'lib/**/api/**/*.rb'
|
|
- 'ee/**/api/**/*.rb'
|
|
|
|
Cop/SidekiqOptionsQueue:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/**/*.rb'
|
|
- 'ee/spec/**/*.rb'
|
|
|
|
Graphql/AuthorizeTypes:
|
|
Enabled: true
|
|
Include:
|
|
- 'app/graphql/types/**/*'
|
|
- 'ee/app/graphql/types/**/*'
|
|
Exclude:
|
|
- 'spec/**/*.rb'
|
|
- 'ee/spec/**/*.rb'
|
|
|
|
Graphql/JSONType:
|
|
Enabled: true
|
|
Include:
|
|
- 'app/graphql/**/*'
|
|
- 'ee/app/graphql/**/*'
|
|
Exclude:
|
|
- 'spec/**/*.rb'
|
|
- 'ee/spec/**/*.rb'
|
|
|
|
RSpec/EnvAssignment:
|
|
Enable: true
|
|
Include:
|
|
- 'spec/**/*.rb'
|
|
- 'ee/spec/**/*.rb'
|
|
Exclude:
|
|
- 'spec/**/fast_spec_helper.rb'
|
|
- 'ee/spec/**/fast_spec_helper.rb'
|
|
- 'spec/**/spec_helper.rb'
|
|
- 'ee/spec/**/spec_helper.rb'
|
|
RSpec/BeSuccessMatcher:
|
|
Enabled: true
|
|
Include:
|
|
- 'spec/controllers/**/*'
|
|
- 'ee/spec/controllers/**/*'
|
|
- 'spec/support/shared_examples/controllers/**/*'
|
|
- 'ee/spec/support/shared_examples/controllers/**/*'
|
|
- 'spec/support/controllers/**/*'
|
|
- 'ee/spec/support/controllers/**/*'
|
|
|
|
Scalability/FileUploads:
|
|
Enabled: true
|
|
Include:
|
|
- 'lib/api/**/*.rb'
|
|
- 'ee/lib/api/**/*.rb'
|
|
|
|
Graphql/Descriptions:
|
|
Enabled: true
|
|
Include:
|
|
- 'app/graphql/**/*'
|
|
- 'ee/app/graphql/**/*'
|
|
|
|
RSpec/AnyInstanceOf:
|
|
Enabled: false
|
|
|
|
# Cops for upgrade to gitlab-styles 3.1.0
|
|
RSpec/ImplicitSubject:
|
|
Enabled: false
|
|
|
|
# WIP See https://gitlab.com/gitlab-org/gitlab/-/issues/211580
|
|
RSpec/LeakyConstantDeclaration:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/db/schema_spec.rb'
|
|
- 'spec/lib/feature_spec.rb'
|
|
- 'spec/lib/gitlab/config/entry/simplifiable_spec.rb'
|
|
- 'spec/lib/gitlab/quick_actions/dsl_spec.rb'
|
|
- 'spec/lib/marginalia_spec.rb'
|
|
- 'spec/mailers/notify_spec.rb'
|
|
- 'spec/models/concerns/batch_destroy_dependent_associations_spec.rb'
|
|
- 'spec/models/concerns/bulk_insert_safe_spec.rb'
|
|
- 'spec/models/concerns/bulk_insertable_associations_spec.rb'
|
|
- 'spec/models/concerns/triggerable_hooks_spec.rb'
|
|
- 'spec/models/repository_spec.rb'
|
|
- 'spec/services/clusters/applications/check_installation_progress_service_spec.rb'
|
|
- 'spec/support/shared_examples/quick_actions/issuable/issuable_quick_actions_shared_examples.rb'
|
|
|
|
RSpec/EmptyLineAfterHook:
|
|
Enabled: false
|
|
|
|
RSpec/HooksBeforeExamples:
|
|
Enabled: false
|
|
|
|
RSpec/EmptyLineAfterExample:
|
|
Enabled: false
|
|
|
|
RSpec/Be:
|
|
Enabled: false
|
|
|
|
RSpec/DescribedClass:
|
|
Enabled: false
|
|
|
|
RSpec/SharedExamples:
|
|
Enabled: false
|
|
|
|
RSpec/EmptyLineAfterExampleGroup:
|
|
Enabled: false
|
|
|
|
RSpec/ReceiveNever:
|
|
Enabled: false
|
|
|
|
RSpec/MissingExampleGroupArgument:
|
|
Enabled: false
|
|
|
|
RSpec/UnspecifiedException:
|
|
Enabled: false
|
|
|
|
RSpec/HaveGitlabHttpStatus:
|
|
Enabled: true
|
|
Exclude:
|
|
- 'spec/support/matchers/have_gitlab_http_status.rb'
|
|
Include:
|
|
- 'spec/**/*'
|
|
- 'ee/spec/**/*'
|
|
|
|
Style/MultilineWhenThen:
|
|
Enabled: false
|
|
|
|
# We use EnforcedStyle of comparison here due to it being better
|
|
# performing code as seen in https://gitlab.com/gitlab-org/gitlab/-/merge_requests/36221#note_375659681
|
|
Style/NumericPredicate:
|
|
EnforcedStyle: comparison
|
|
|
|
Style/FloatDivision:
|
|
Enabled: false
|
|
|
|
Cop/BanCatchThrow:
|
|
Enabled: true
|
|
|
|
Performance/ReadlinesEach:
|
|
Enabled: true
|
|
|
|
Performance/ChainArrayAllocation:
|
|
Enabled: true
|
|
Include:
|
|
- 'lib/gitlab/import_export/**/*'
|
|
- 'ee/lib/gitlab/import_export/**/*'
|
|
- 'ee/lib/ee/gitlab/import_export/**/*'
|
|
|
|
Rails/TimeZone:
|
|
Enabled: true
|
|
EnforcedStyle: 'flexible'
|
|
Include:
|
|
- 'app/controllers/**/*'
|
|
- 'app/services/**/*'
|
|
- 'lib/**/*'
|
|
- 'spec/controllers/**/*'
|
|
- 'spec/services/**/*'
|
|
- 'spec/lib/**/*'
|
|
- 'ee/app/controllers/**/*'
|
|
- 'ee/app/services/**/*'
|
|
- 'ee/spec/controllers/**/*'
|
|
- 'ee/spec/services/**/*'
|
|
- 'app/models/**/*'
|
|
- 'spec/models/**/*'
|
|
- 'ee/app/models/**/*'
|
|
- 'ee/spec/models/**/*'
|
|
- 'app/workers/**/*'
|
|
- 'spec/workers/**/*'
|
|
- 'ee/app/workers/**/*'
|
|
- 'ee/spec/workers/**/*'
|
|
- 'ee/lib/**/*'
|
|
- 'ee/spec/lib/**/*'
|
|
|
|
# WIP: See https://gitlab.com/gitlab-org/gitlab/-/issues/220040
|
|
Rails/SaveBang:
|
|
Enabled: true
|
|
AllowImplicitReturn: false
|
|
AllowedReceivers: ['ActionDispatch::TestRequest']
|
|
Include:
|
|
- 'spec/**/*.rb'
|
|
- 'ee/spec/**/*.rb'
|
|
- 'qa/spec/**/*.rb'
|
|
- 'qa/qa/specs/**/*.rb'
|
|
|
|
Cop/PutProjectRoutesUnderScope:
|
|
Include:
|
|
- 'config/routes/project.rb'
|
|
- 'ee/config/routes/project.rb'
|
|
|
|
Cop/PutGroupRoutesUnderScope:
|
|
Include:
|
|
- 'config/routes/group.rb'
|
|
- 'ee/config/routes/group.rb'
|
|
|
|
Migration/ComplexIndexesRequireName:
|
|
Exclude:
|
|
- !ruby/regexp /\Adb\/(post_)?migrate\/201.*\.rb\z/
|
|
- !ruby/regexp /\Adb\/(post_)?migrate\/20200[1-7].*\.rb\z/
|
|
|
|
Migration/ReferToIndexByName:
|
|
Exclude:
|
|
- !ruby/regexp /\Adb\/(post_)?migrate\/201.*\.rb\z/
|
|
- !ruby/regexp /\Adb\/(post_)?migrate\/20200[1-7].*\.rb\z/
|
|
- !ruby/regexp /\Aee\/db\/geo\/(post_)?migrate\/201.*\.rb\z/
|
|
|
|
Migration/CreateTableWithForeignKeys:
|
|
# Disable this cop for all the existing migrations
|
|
Exclude:
|
|
- !ruby/regexp /\Adb\/(?:post_)?migrate\/(?:201[0-9]\d+|20200[0-8][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9])_.+\.rb\z/
|
|
|
|
Gitlab/RailsLogger:
|
|
Exclude:
|
|
- 'spec/**/*.rb'
|
|
- 'ee/spec/**/*.rb'
|