Release Policy¶
The UiPath Python ecosystem is composed of different component packages:
uipath
: The core SDK package (version >= 2.0.0)uipath-langchain
: The LangChain integration package (version >= 0.0.0)
Both packages are under rapid development, following semantic versioning in the format of X.Y.Z:
- X (major version):
uipath
: X = 2uipath-langchain
: X = 0
- Y (minor version) increases indicate breaking changes for public interfaces not marked as beta
- Z (patch version) increases indicate:
- Bug fixes
- New features
- Changes to private interfaces
- Changes to beta features
Version Number Format¶
The version format is X.Y.Z
where:
- For
uipath
: X = 2 (e.g., 2.0.0, 2.1.0) - For
uipath-langchain
: X = 0 (e.g., 0.0.0, 0.1.0) - Y represents the minor version
- Z represents the patch version
Release Candidates¶
From time to time, we will version packages as release candidates. These are versions that are intended to be released as stable versions, but we want to get feedback from the community before doing so.
Release candidates are versioned as X.Y.ZrcN
. For example:
uipath
:2.2.0rc1
uipath-langchain
:0.1.0rc1
If no issues are found, the release candidate will be released as a stable version with the same version number. If issues are found, we will release a new release candidate with an incremented N value (e.g., 2.2.0rc2
or 0.1.0rc2
).
When upgrading between minor versions, users should review the list of breaking changes and deprecations.
Release Cadence¶
Minor Releases (X.Y.0)¶
- Released as needed based on feature development and breaking changes
- Include breaking changes for public interfaces not marked as beta
- Require a migration guide for users
- Preceded by a release candidate (RC) phase
Patch Releases (X.Y.Z)¶
- Released as needed based on bug fixes and improvements
- Include bug fixes, new features, and changes to private interfaces
- Always maintain backward compatibility for public interfaces
API Stability¶
Public API¶
The following components are considered part of the public API:
- All classes and methods in the
src/uipath
directory - CLI commands and their interfaces
Internal API¶
Components marked as internal include:
- Methods and classes prefixed with
_
- Test utilities and fixtures
- Build and development tools
Breaking Changes¶
Breaking changes are introduced in minor releases (X.Y.0) and follow these guidelines:
- Deprecation Period: Features marked for removal will be deprecated for at least one minor release cycle
- Migration Path: Breaking changes must provide a clear migration path
- Documentation: All breaking changes must be documented in the release notes and migration guide
- Beta Features: Breaking changes to beta features can occur in patch releases
Deprecation Policy¶
- Announcement: Features to be deprecated will be announced in release notes
- Warning Period: Deprecated features will trigger warnings when used
- Removal: Deprecated features will be removed in the next major release
Release Process¶
-
Development:
- Features and fixes are developed in feature branches
- All changes require tests and documentation
- Code must pass all CI checks
-
Release Candidate:
- Minor releases include an RC phase
- RCs are versioned as
X.Y.ZrcN
- Community feedback is collected during RC phase
-
Release:
- Version number is updated in
pyproject.toml
- Release notes are prepared
- Package is published to PyPI
- Documentation is updated
- Version number is updated in
Support Policy¶
- Current major version: Full support
- Previous major version: Security fixes only
- Older versions: No official support
Dependencies¶
The SDK maintains compatibility with:
- Python 3.10+
- Key dependencies as specified in
pyproject.toml
- Regular updates to dependencies are performed in minor releases
Documentation¶
- All public APIs must be documented
- Documentation follows Google-style docstrings
- Examples and usage guides are provided for new features
- Breaking changes are clearly documented in migration guides