2021-01-29 00:20:46 +05:30
---
stage: none
group: unassigned
2022-11-25 23:54:43 +05:30
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/product/ux/technical-writing/#assignments
2021-01-29 00:20:46 +05:30
---
2022-08-27 11:52:29 +05:30
# Deprecating GitLab features
2020-10-24 23:57:45 +05:30
2022-08-27 11:52:29 +05:30
This page includes information about how and when to remove or make breaking changes
to GitLab features.
2020-10-24 23:57:45 +05:30
## Terminology
2022-10-11 01:57:18 +05:30
<!--
If updating these definitions, be sure to update them in the handbook as well:
https://about.gitlab.com/handbook/product/gitlab-the-product/#definitions
-->
2022-07-23 23:45:48 +05:30
**Deprecation**:
2020-10-24 23:57:45 +05:30
2022-10-11 01:57:18 +05:30
- Required before ending support for a feature or removing a feature.
2022-07-23 23:45:48 +05:30
- Feature not recommended for use.
- Development restricted to Priority 1 / Severity 1 bug fixes.
- Will be removed in a future major release.
2022-10-11 01:57:18 +05:30
- Begins after a deprecation announcement outlining an end-of-support or removal date.
2022-07-23 23:45:48 +05:30
- Ends after the end-of-support date or removal date has passed.
2020-10-24 23:57:45 +05:30
2022-07-23 23:45:48 +05:30
**End of Support**:
2022-10-11 01:57:18 +05:30
- Optional step before removal.
2022-07-23 23:45:48 +05:30
- 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.
2022-10-11 01:57:18 +05:30
[Announcing an End of Support period ](https://about.gitlab.com/handbook/marketing/blog/release-posts/#announcing-an-end-of-support-period )
should only be used in special circumstances and is not recommended for general use.
Most features should be deprecated and then removed.
2022-07-23 23:45:48 +05:30
**Removal**:
- Feature usage impossible.
2023-03-17 16:20:25 +05:30
- Feature no longer supported (if End of Support period hasn't already been announced).
2022-07-23 23:45:48 +05:30
- Happens in a major release in line with our
[semantic versioning policy ](../../policy/maintenance.md ).
- Begins after removal date has passed.
2022-08-27 11:52:29 +05:30
**Breaking change**:
A "breaking change" is any change that requires users to make a corresponding change to their code, settings, or workflow. "Users" might be humans, API clients, or even code classes that "use" another class. Examples of breaking changes include:
- Removing a user-facing feature without a replacement/workaround.
- Changing the definition of an existing API (by doing things like re-naming query parameters or changing routes).
- Removing a public method from a code class.
A breaking change can be considered major if it affects many users, or represents a significant change in behavior.
2023-03-17 16:20:25 +05:30
![Deprecation, End of Support, Removal process ](img/deprecation_removal_process.png )
2020-10-24 23:57:45 +05:30
## When can a feature be deprecated?
2022-01-26 12:08:38 +05:30
Deprecations should be announced on the [Deprecated feature removal schedule ](../../update/deprecations.md ).
2023-05-27 22:25:52 +05:30
Deprecations should be announced [no later than the third milestone preceding intended removal ](https://about.gitlab.com/handbook/product/gitlab-the-product/#process-for-deprecating-and-removing-a-feature ).
2022-08-13 15:12:31 +05:30
Do not include the deprecation announcement in the merge request that introduces a code change for the deprecation.
Use a separate MR to create a deprecation entry. For steps to create a deprecation entry, see
[Deprecations ](https://about.gitlab.com/handbook/marketing/blog/release-posts/#deprecations ).
2021-09-04 01:27:46 +05:30
2022-08-27 11:52:29 +05:30
## How are Community Contributions to a deprecated feature handled?
Development on deprecated features is restricted to Priority 1 / Severity 1 bug fixes. Any community contributions to deprecated features are unlikely to be prioritized during milestone planning.
However, at GitLab, we [give agency ](https://about.gitlab.com/handbook/values/#give-agency ) to our team members. So, a member of the team associated with the contribution may decide to review and merge it at their discretion.
2020-10-24 23:57:45 +05:30
## When can a feature be removed/changed?
2021-09-04 01:27:46 +05:30
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 ).
2023-05-27 22:25:52 +05:30
For API removals, see the [GraphQL ](../../api/graphql/index.md#deprecation-and-removal-process ) and [GitLab API ](../documentation/restful_api_styleguide.md#deprecations ) guidelines.
2021-04-29 21:17:54 +05:30
2021-11-11 11:23:49 +05:30
For configuration removals, see the [Omnibus deprecation policy ](../../administration/package_information/deprecation_policy.md ).
2021-04-29 21:17:54 +05:30
For versioning and upgrade details, see our [Release and Maintenance policy ](../../policy/maintenance.md ).
2022-07-16 23:28:13 +05:30
2023-01-13 00:05:48 +05:30
## Update the deprecations and removals documentation pages
2022-07-16 23:28:13 +05:30
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 >
2023-01-13 00:05:48 +05:30
## Update the related documentation
When features are deprecated and removed, [update the related documentation ](../documentation/versions.md#deprecations-and-removals ).