Pepr is committed to providing a stable and reliable experience for developers while allowing room for innovation and improvement. This document outlines Pepr's backward compatibility policies, including guidelines, guarantees, and examples of how we handle breaking changes.
Backward compatibility in Pepr applies to the following components:
- Public API:
- Actions Publicly exposed APIs, including function signatures, parameters, and return types. The API includes:
- Configuration:
- YAML or JSON configuration structures for Pepr Modules. Configuration includes:
- Pepr SDK:
- Helper functions to frequently used tasks defined in SDK.
- CLI Commands:
- Commands, flags, and outputs provided by the Pepr CLI.
Pepr adheres to the following guarantees to ensure a seamless user experience:
- Major Versions (X.0.0):
- Not currently in use until we get to 1.0.
- Minor Versions (X.Y.0):
- Add new features in a backward-compatible manner.
- Introduce breaking changes after deprecation.
- Patch Versions (X.Y.Z):
- Introduce deprecations changes with announcements and migration paths.
- Include bug fixes, security updates, and performance improvements without changing functionality or APIs.
- Deprecation Announcement:
- Any feature slated for removal will be marked as deprecated and announced in release notes.
- Deprecated features will include clear warnings in logs and CLI outputs.
- Deprecation notices will be included Pepr Slack.
- Grace Period:
- Deprecated features will remain functional for at least one release before removal.
- Maintain backward compatibility by validating changes against existing test suites for previously supported versions.
- Include regression tests to ensure deprecated features continue to function as expected until their removal.
- Breaking changes will only be introduced in minor releases.
- Users will be notified via:
- Release Notes: Detailed explanation of changes, migration paths, and alternative solutions.
- Documentation Updates: Guides and examples to help users adapt to the changes.
- Pepr Slack: Announcements will be left in the Pepr Slack channel with a link to the release notes.
- Pepr will provide logic to automatically migrate configurations and data to the new format where possible.
- When possible, introduce breaking changes behind feature flags to allow users to opt-in before full adoption.
- Scenario: Adding a new optional parameter to a public API.
- Action: Ensure the default behavior remains unchanged if the parameter is not provided.
- Scenario: Renaming a CLI flag.
- Action: Keep the old flag functional while logging a deprecation warning.
- Scenario: Changing a configuration schema.
- Action: Provide an automatic migration tool or fallback to interpret the old schema.
- Monitor GitHub Issues and Discussions for reports of backward compatibility issues.
- Solicit feedback from the community on proposed breaking changes before implementation.
Pepr's backward compatibility strategy ensures developers can rely on consistent behavior while adapting to new features and improvements. By clearly communicating changes and providing robust migration tools, we aim to minimize disruptions and foster trust within our user community.
For questions, concerns, or suggestions regarding backward compatibility, please reach out via: