- .NET Clients: other versions:
- Introduction
- Getting started
- Installation
- Connecting
- Configuration
- Client concepts
- Using the .NET Client
- Troubleshooting
- Release notes
- Breaking changes policy
- Release notes v8.1.3
- Release notes v8.1.2
- Release notes v8.1.1
- Release notes v8.1.0
- Release notes v8.0.10
- Release notes v8.0.9
- Release notes v8.0.8
- Release notes v8.0.7
- Release notes v8.0.6
- Release notes v8.0.5
- Release notes v8.0.4
- Release notes v8.0.3
- Release notes v8.0.2
- Release notes v8.0.1
- Release notes v8.0.0
Breaking changes policy
editBreaking changes policy
editThe Elasticsearch .NET Client source code is generated from a formal specification of the Elasticsearch API. This API specification is large, and although it is tested against hundreds of Elasticsearch test files, it may have discrepancies with the actual API that result in issues in the Elasticsearch .NET Client.
Fixing these discrepancies in the API specification results in code changes in the Elasticsearch .NET Client, and some of these changes can require code updates in your applications.
This section explains how these breaking changes are considered for inclusion in Elasticsearch .NET Client releases.
Breaking changes in patch releases
editSome issues in the API specification are properties that have an incorrect type, such as a long
that should be a string
, or a required property that is actually optional. These issues can cause the Elasticsearch .NET Client to not work properly or even throw exceptions.
When a specification issue is discovered and resolved, it may require code updates in applications using the Elasticsearch .NET Client. Such breaking changes are considered acceptable, even in patch releases (e.g. 8.0.0 → 8.0.1), as they introduce stability to APIs that may otherwise be unusable.
We may also make breaking changes in patch releases to correct design flaws and code-generation issues that we deem beneficial to resolve at the earliest oppotunity. We will detail these in the relevant release notes and limit these as the client matures.
Breaking changes in minor releases
editAlong with these bug fixes, the API specification is constantly refined, more precise type definitions are introduced to improve developer comfort and remove ambiguities. The specification of often-used APIs is fairly mature, so these changes happen generally on less often used APIs. These changes can also cause breaking changes requiring code updates which are considered acceptable in minor releases (e.g. 8.0 → 8.1).
Breaking changes in major releases
editMajor releases (e.g. 7.x → 8.x) can include larger refactorings of the API specification and the framework underlying the Elasticsearch .NET Client. These refactorings are considered carefully and done only when they unlock new important features or new developments.
Elasticsearch API stability guarantees
editAll Elasticsearch APIs have stability indicators, which imply potential changes. If an API is stable
only additional non-breaking changes are added. In case of experimental
APIs, breaking changes can be introduced any time, which means that these changes, will also be reflected in the Elasticsearch .NET Client.
On this page
ElasticON events are back!
Learn about the Elastic Search AI Platform from the experts at our live events.
Register now