2017-11-01 11:56:40 -04:00
---
comments: false
2018-05-09 07:07:11 -04:00
description: 'Learn how to contribute to GitLab.'
2017-11-01 11:56:40 -04:00
---
2017-10-11 01:59:34 -04:00
# GitLab development guides
2014-04-24 13:53:18 -04:00
2017-10-11 01:59:34 -04:00
## Get started!
2016-08-04 06:45:59 -04:00
2018-09-19 12:03:00 -04:00
- Set up GitLab's development environment with [GitLab Development Kit (GDK) ](https://gitlab.com/gitlab-org/gitlab-development-kit/blob/master/doc/howto/README.md )
2018-10-11 07:57:49 -04:00
- [GitLab contributing guide ](contributing/index.md )
2017-10-11 01:59:34 -04:00
- [Architecture ](architecture.md ) of GitLab
- [Rake tasks ](rake_tasks.md ) for development
2016-08-04 06:45:59 -04:00
2017-10-11 01:59:34 -04:00
## Processes
- [GitLab core team & GitLab Inc. contribution process ](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/PROCESS.md )
- [Generate a changelog entry with `bin/changelog` ](changelog.md )
- [Code review guidelines ](code_review.md ) for reviewing code and having code reviewed.
2017-12-05 11:49:49 -05:00
- [Automatic CE->EE merge ](automatic_ce_ee_merge.md )
2017-12-06 11:23:53 -05:00
- [Guidelines for implementing Enterprise Edition features ](ee_features.md )
2018-05-08 06:55:02 -04:00
- [Security process for developers ](https://gitlab.com/gitlab-org/release/docs/blob/master/general/security/developer.md#security-releases-critical-non-critical-as-a-developer )
2017-10-11 01:59:34 -04:00
## UX and frontend guides
2016-08-04 06:45:59 -04:00
2018-11-21 10:25:15 -05:00
- [GitLab Design System ](https://design.gitlab.com/ ) for building GitLab with existing CSS styles and elements
2017-03-22 15:30:54 -04:00
- [Frontend guidelines ](fe_guide/index.md )
2017-11-14 17:29:33 -05:00
- [Emoji guide ](fe_guide/emojis.md )
2017-10-11 01:59:34 -04:00
## Backend guides
2017-12-29 01:29:53 -05:00
- [GitLab utilities ](utilities.md )
2018-11-13 17:43:16 -05:00
- [Logging ](logging.md )
2017-10-11 01:59:34 -04:00
- [API styleguide ](api_styleguide.md ) Use this styleguide if you are
contributing to the API.
2018-06-11 23:28:29 -04:00
- [GraphQL API styleguide ](api_graphql_styleguide.md ) Use this
2018-05-21 03:52:24 -04:00
styleguide if you are contribution to the [GraphQL API ](../api/graphql/index.md )
2016-10-21 12:13:41 -04:00
- [Sidekiq guidelines ](sidekiq_style_guide.md ) for working with Sidekiq workers
2017-10-11 01:59:34 -04:00
- [Working with Gitaly ](gitaly.md )
- [Manage feature flags ](feature_flags.md )
- [View sent emails or preview mailers ](emails.md )
- [Shell commands ](shell_commands.md ) in the GitLab codebase
2017-01-27 06:17:21 -05:00
- [`Gemfile` guidelines ](gemfile.md )
2018-07-20 01:31:51 -04:00
- [Pry debugging ](pry_debugging.md )
2017-10-11 01:59:34 -04:00
- [Sidekiq debugging ](sidekiq_debugging.md )
- [Gotchas ](gotchas.md ) to avoid
2017-11-21 10:15:24 -05:00
- [Avoid modules with instance variables ](module_with_instance_variables.md ) if possible
2017-10-11 01:59:34 -04:00
- [How to dump production data to staging ](db_dump.md )
2017-10-13 12:50:36 -04:00
- [Working with the GitHub importer ](github_importer.md )
2018-04-09 17:24:26 -04:00
- [Working with Merge Request diffs ](diffs.md )
2018-09-10 06:54:52 -04:00
- [Permissions ](permissions.md )
2018-09-04 09:01:34 -04:00
- [Prometheus metrics ](prometheus_metrics.md )
2018-08-16 11:14:14 -04:00
- [Guidelines for reusing abstractions ](reusing_abstractions.md )
2018-10-14 18:58:29 -04:00
- [DeclarativePolicy framework ](policies.md )
2016-08-04 06:45:59 -04:00
2017-10-11 01:59:34 -04:00
## Performance guides
2016-08-04 06:45:59 -04:00
2018-09-18 08:25:22 -04:00
- [Instrumentation ](instrumentation.md ) for Ruby code running in production
environments
- [Performance guidelines ](performance.md ) for writing code, benchmarks, and
certain patterns to avoid
2016-08-19 11:21:00 -04:00
- [Merge request performance guidelines ](merge_request_performance_guidelines.md )
for ensuring merge requests do not negatively impact GitLab performance
2018-09-18 16:17:07 -04:00
- [Profiling ](profiling.md ) a URL, measuring performance using Sherlock, or
tracking down N+1 queries using Bullet
2016-08-04 06:45:59 -04:00
2018-08-14 12:07:15 -04:00
## Database guides
### Tooling
- [Understanding EXPLAIN plans ](understanding_explain_plans.md )
- [explain.depesz.com ](https://explain.depesz.com/ ) for visualising the output
of `EXPLAIN`
2016-08-11 08:22:21 -04:00
2017-10-11 01:59:34 -04:00
### Migrations
2016-08-11 08:22:21 -04:00
2016-08-04 11:17:31 -04:00
- [What requires downtime? ](what_requires_downtime.md )
2017-10-11 01:59:34 -04:00
- [SQL guidelines ](sql.md ) for working with SQL queries
- [Migrations style guide ](migration_style_guide.md ) for creating safe SQL migrations
- [Post deployment migrations ](post_deployment_migrations.md )
- [Background migrations ](background_migrations.md )
- [Swapping tables ](swapping_tables.md )
### Best practices
- [Merge Request checklist ](database_merge_request_checklist.md )
2016-08-11 08:22:21 -04:00
- [Adding database indexes ](adding_database_indexes.md )
2017-10-11 01:59:34 -04:00
- [Foreign keys & associations ](foreign_keys.md )
- [Single table inheritance ](single_table_inheritance.md )
- [Polymorphic associations ](polymorphic_associations.md )
- [Serializing data ](serializing_data.md )
- [Hash indexes ](hash_indexes.md )
- [Storing SHA1 hashes as binary ](sha1_as_binary.md )
- [Iterating tables in batches ](iterating_tables_in_batches.md )
- [Ordering table columns ](ordering_table_columns.md )
- [Verifying database capabilities ](verifying_database_capabilities.md )
2017-11-15 22:19:14 -05:00
- [Database Debugging and Troubleshooting ](database_debugging.md )
2018-01-15 10:21:04 -05:00
- [Query Count Limits ](query_count_limits.md )
2018-09-18 11:32:21 -04:00
- [Database helper modules ](database_helpers.md )
2017-10-11 01:59:34 -04:00
2017-10-11 10:33:57 -04:00
## Testing guides
- [Testing standards and style guidelines ](testing_guide/index.md )
- [Frontend testing standards and style guidelines ](testing_guide/frontend_testing.md )
2017-10-11 01:59:34 -04:00
## Documentation guides
2018-06-06 07:32:38 -04:00
- [Writing documentation ](documentation/index.md )
- [Documentation styleguide ](documentation/styleguide.md )
2017-12-15 05:56:21 -05:00
- [Markdown ](../user/markdown.md )
2017-10-11 01:59:34 -04:00
## Internationalization (i18n) guides
2017-05-16 14:26:12 -04:00
2017-10-09 05:28:01 -04:00
- [Introduction ](i18n/index.md )
2017-09-26 17:15:19 -04:00
- [Externalization ](i18n/externalization.md )
- [Translation ](i18n/translation.md )
2017-05-16 14:26:12 -04:00
2017-10-11 01:59:34 -04:00
## Build guides
- [Building a package for testing purposes ](build_test_package.md )
2016-08-04 06:45:59 -04:00
## Compliance
- [Licensing ](licensing.md ) for ensuring license compliance