2020-10-30 14:08:56 -04:00
---
stage: none
group: unassigned
2020-11-26 01:09:20 -05:00
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
2020-10-30 14:08:56 -04:00
---
2020-07-27 05:09:42 -04:00
# Deprecation guidelines
2022-02-11 10:14:00 -05:00
This page includes information about how and when to remove or make [breaking
changes](../contributing/index.md#breaking-changes) to GitLab features.
2020-07-27 05:09:42 -04:00
## Terminology
2022-06-08 20:08:57 -04:00
**Deprecation**:
2020-07-27 05:09:42 -04:00
2022-06-08 20:08:57 -04:00
- Feature not recommended for use.
- Development restricted to Priority 1 / Severity 1 bug fixes.
- Will be removed in a future major release.
- Begins after a deprecation announcement outlining an end-of-support date.
- Ends after the end-of-support date or removal date has passed.
2020-07-27 05:09:42 -04:00
2022-06-08 20:08:57 -04:00
**End of Support**:
- Feature usage strongly discouraged.
- No support or fixes provided.
- No longer tested internally.
- Will be removed in a future major release.
- Begins after an end-of-support date has passed.
- Ends after all relevant code has been removed.
**Removal**:
- Feature usage impossible.
- Happens in a major release in line with our
[semantic versioning policy ](../../policy/maintenance.md ).
- Begins after removal date has passed.
![Deprecation, End of Support, Removal process ](img/deprecation_removal_process.png )
2020-07-27 05:09:42 -04:00
## When can a feature be deprecated?
2021-12-06 10:14:39 -05:00
Deprecations should be announced on the [Deprecated feature removal schedule ](../../update/deprecations.md ).
For steps to create a deprecation entry, see [Deprecations ](https://about.gitlab.com/handbook/marketing/blog/release-posts/#deprecations ).
2021-06-02 17:10:00 -04:00
2020-07-27 05:09:42 -04:00
## When can a feature be removed/changed?
2021-06-02 17:10:00 -04:00
Generally, feature or configuration can be removed/changed only on major release.
It also should be [deprecated in advance ](https://about.gitlab.com/handbook/marketing/blog/release-posts/#deprecations ).
2021-06-28 11:08:03 -04:00
For API removals, see the [GraphQL ](../../api/graphql/index.md#deprecation-and-removal-process ) and [GitLab API ](../../api/index.md#compatibility-guidelines ) guidelines.
2021-04-15 14:09:01 -04:00
2021-09-17 05:09:24 -04:00
For configuration removals, see the [Omnibus deprecation policy ](../../administration/package_information/deprecation_policy.md ).
2021-04-15 14:09:01 -04:00
For versioning and upgrade details, see our [Release and Maintenance policy ](../../policy/maintenance.md ).
2022-05-05 02:08:22 -04:00
## Update the deprecations and removals documentation
The [deprecations ](../../update/deprecations.md ) and [removals ](../../update/removals.md )
documentation is generated from the YAML files located in
[`gitlab/data/` ](https://gitlab.com/gitlab-org/gitlab/-/tree/master/data ).
To update the deprecations and removals pages when an entry is added,
edited, or removed:
1. From the command line, navigate to your local clone of the [`gitlab-org/gitlab` ](https://gitlab.com/gitlab-org/gitlab ) project.
1. Create, edit, or remove the YAML file under [deprecations ](https://gitlab.com/gitlab-org/gitlab/-/tree/master/data/deprecations )
or [removals ](https://gitlab.com/gitlab-org/gitlab/-/tree/master/data/removals ).
1. Compile the deprecation or removals documentation with the appropriate command:
- For deprecations:
```shell
bin/rake gitlab:docs:compile_deprecations
```
- For removals:
```shell
bin/rake gitlab:docs:compile_removals
```
1. If needed, you can verify the docs are up to date with:
- For deprecations:
```shell
bin/rake gitlab:docs:check_deprecations
```
- For removals:
```shell
bin/rake gitlab:docs:check_removals
```
1. Commit the updated documentation and push the changes.
1. Create a merge request using the [Deprecations ](https://gitlab.com/gitlab-org/gitlab/-/blob/master/.gitlab/merge_request_templates/Deprecations.md )
or [Removals ](https://gitlab.com/gitlab-org/gitlab/-/blob/master/.gitlab/merge_request_templates/Removals.md ) templates.
Related Handbook pages:
- < https: // about . gitlab . com / handbook / marketing / blog / release-posts /# deprecations-removals-and-breaking-changes >
- < https: // about . gitlab . com / handbook / marketing / blog / release-posts /# update-the-deprecations-and-removals-docs >