README.md 5.0 KB
Newer Older
1 2
---
comments: false
3
description: 'Learn how to contribute to GitLab.'
4 5
---

6
# GitLab development guides
7

8
## Get started!
9

10
- 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)
11
- [GitLab contributing guide](contributing/index.md)
12 13
- [Architecture](architecture.md) of GitLab
- [Rake tasks](rake_tasks.md) for development
14

15 16 17 18 19
## 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.
20
- [Automatic CE->EE merge](automatic_ce_ee_merge.md)
21
- [Guidelines for implementing Enterprise Edition features](ee_features.md)
22
- [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)
23 24

## UX and frontend guides
25

26
- [GitLab Design System](https://design.gitlab.com/) for building GitLab with existing CSS styles and elements
F
Filipa Lacerda 已提交
27
- [Frontend guidelines](fe_guide/index.md)
E
Eric Eastwood 已提交
28
- [Emoji guide](fe_guide/emojis.md)
29 30 31

## Backend guides

32
- [GitLab utilities](utilities.md)
33
- [Logging](logging.md)
34 35
- [API styleguide](api_styleguide.md) Use this styleguide if you are
  contributing to the API.
36
- [GraphQL API styleguide](api_graphql_styleguide.md) Use this
B
Bob Van Landuyt 已提交
37
  styleguide if you are contribution to the [GraphQL API](../api/graphql/index.md)
38
- [Sidekiq guidelines](sidekiq_style_guide.md) for working with Sidekiq workers
39 40 41 42
- [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
43
- [`Gemfile` guidelines](gemfile.md)
T
Toon Claes 已提交
44
- [Pry debugging](pry_debugging.md)
45 46
- [Sidekiq debugging](sidekiq_debugging.md)
- [Gotchas](gotchas.md) to avoid
L
Lin Jen-Shin 已提交
47
- [Avoid modules with instance variables](module_with_instance_variables.md) if possible
48
- [How to dump production data to staging](db_dump.md)
49
- [Working with the GitHub importer](github_importer.md)
J
James Lopez 已提交
50
- [Import/Export development documentation](import_export.md)
51
- [Working with Merge Request diffs](diffs.md)
T
Thong Kuah 已提交
52
- [Kubernetes integration guidelines](kubernetes.md)
53
- [Permissions](permissions.md)
K
Kamil Trzciński 已提交
54
- [Prometheus metrics](prometheus_metrics.md)
55
- [Guidelines for reusing abstractions](reusing_abstractions.md)
56
- [DeclarativePolicy framework](policies.md)
57
- [How Git object deduplication works in GitLab](git_object_deduplication.md)
58

59
## Performance guides
60

61 62 63 64
- [Instrumentation](instrumentation.md) for Ruby code running in production
  environments
- [Performance guidelines](performance.md) for writing code, benchmarks, and
  certain patterns to avoid
65 66
- [Merge request performance guidelines](merge_request_performance_guidelines.md)
  for ensuring merge requests do not negatively impact GitLab performance
67 68
- [Profiling](profiling.md) a URL, measuring performance using Sherlock, or
  tracking down N+1 queries using Bullet
69

70 71 72 73 74 75 76
## Database guides

### Tooling

- [Understanding EXPLAIN plans](understanding_explain_plans.md)
- [explain.depesz.com](https://explain.depesz.com/) for visualising the output
  of `EXPLAIN`
77

78
### Migrations
79

80
- [What requires downtime?](what_requires_downtime.md)
81 82 83 84 85 86 87 88 89
- [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)
90
- [Adding database indexes](adding_database_indexes.md)
91 92 93 94 95 96 97 98 99
- [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)
100
- [Database Debugging and Troubleshooting](database_debugging.md)
101
- [Query Count Limits](query_count_limits.md)
102
- [Database helper modules](database_helpers.md)
103

104 105 106 107 108
## Testing guides

- [Testing standards and style guidelines](testing_guide/index.md)
- [Frontend testing standards and style guidelines](testing_guide/frontend_testing.md)

109 110
## Documentation guides

111 112
- [Writing documentation](documentation/index.md)
- [Documentation styleguide](documentation/styleguide.md)
113
- [Markdown](../user/markdown.md)
114 115

## Internationalization (i18n) guides
116

117
- [Introduction](i18n/index.md)
118 119
- [Externalization](i18n/externalization.md)
- [Translation](i18n/translation.md)
120

121 122 123 124
## Build guides

- [Building a package for testing purposes](build_test_package.md)

125 126 127
## Compliance

- [Licensing](licensing.md) for ensuring license compliance
128 129 130 131

## Go guides

- [Go Guidelines](go_guide/index.md)