CPO Overrides Configuration Guide
Overview
The CPO (Control Plane Operator) overrides mechanism allows you to specify custom Control Plane Operator images for specific OpenShift versions and platforms. This is particularly useful for applying hotfixes and patches before they're officially released.
Configuration File Structure
The CPO overrides are configured using a YAML file with the following structure:
platforms:
aws:
overrides:
- version: "4.17.9"
cpoImage: "quay.io/hypershift/control-plane-operator:4.17.9"
- version: "4.17.8"
cpoImage: "quay.io/hypershift/control-plane-operator:4.17.8"
testing:
latest: "quay.io/openshift-release-dev/ocp-release:4.17.9-x86_64"
previous: "quay.io/openshift-release-dev/ocp-release:4.17.8-x86_64"
azure:
overrides:
- version: "4.16.17"
cpoImage: "quay.io/openshift-release-dev/ocp-v4.0-art-dev@sha256:1a50894aafa6b750bf890ef147a20699ff5b807e586d15506426a8a615580797"
- version: "4.16.18"
cpoImage: "quay.io/hypershift/hypershift-cpo:patch"
Configuration Elements
Platforms Section
The top-level platforms
section contains platform-specific configurations. Currently supported platforms:
aws
: Amazon Web Servicesazure
: Microsoft Azure
Each platform section is optional. If a platform is not configured, the default CPO image from the OpenShift release will be used.
Platform Configuration
Each platform can contain:
overrides
(Array)
A list of version-specific CPO image overrides:
version
(string): The exact OpenShift version (e.g., "4.17.9", "4.16.17")cpoImage
(string): The full container image reference to use for this version
testing
(Object, Optional)
Configuration for automated testing:
latest
(string): The latest OpenShift release image for testingprevious
(string): The previous OpenShift release image for testing
Configuration Examples
Basic Platform-Specific Override
platforms:
aws:
overrides:
- version: "4.17.9"
cpoImage: "quay.io/myorg/custom-cpo-aws:4.17.9"
Multiple Versions and Platforms
platforms:
aws:
overrides:
- version: "4.17.9"
cpoImage: "quay.io/hypershift/control-plane-operator-aws:4.17.9"
- version: "4.17.8"
cpoImage: "quay.io/hypershift/control-plane-operator-aws:4.17.8"
- version: "4.16.15"
cpoImage: "quay.io/hotfix/cpo-aws:4.16.15-hotfix"
testing:
latest: "quay.io/openshift-release-dev/ocp-release:4.17.9-x86_64"
previous: "quay.io/openshift-release-dev/ocp-release:4.17.8-x86_64"
azure:
overrides:
- version: "4.17.9"
cpoImage: "quay.io/hypershift/control-plane-operator-azure:4.17.9"
- version: "4.16.20"
cpoImage: "quay.io/security-fix/cpo-azure:4.16.20-security"
How It Works
Image Resolution Process
- Override Check: When a HostedCluster is created or updated, the system checks if CPO overrides are enabled
- Platform Lookup: The system looks up overrides for the specific platform (case-insensitive)
- Version Match: If the platform exists, it searches for an exact version match
- Fallback: If no override is found, the default CPO image from the OpenShift release is used
Platform Handling
- Platform names are case-insensitive (
AWS
,aws
,Aws
all work) - Unknown platforms return empty string (graceful degradation)
- Missing platforms in configuration are handled safely (no panics)
Enabling CPO Overrides
CPO overrides are controlled by an environment variable on the HyperShift operator:
export ENABLE_CPO_OVERRIDES=1
When this environment variable is set to 1
, the override system is activated. Without this variable, all overrides are ignored and default images are used.
File Locations
The override configuration files are embedded in the binary at build time:
hypershift-operator/controlplaneoperator-overrides/assets/overrides.yaml
Best Practices
Version Management
- Use exact version strings (e.g., "4.17.9", not "4.17.x")
- Keep override lists sorted by version for maintainability
Image References
- Use full image references including registry and tag/digest
- Prefer digest references for production overrides for immutability
Platform Configuration
- Only configure platforms that need overrides
- Keep platform-specific testing configurations separate
- Document the purpose of each override in comments
Testing
- The test section allows specifying a pair of release images to use for a single hypershift e2e test run. Currently only a single pair can be specified per platform. If multiple releases need to be tested, create a clone of your override PR and specify a different pair of images to test in the clone. The clone shouldn't be merged, it should only be used for testing.
Troubleshooting
Common Issues
- Override Not Applied
- Check if
ENABLE_CPO_OVERRIDES=1
is set - Verify platform name matches exactly (case-insensitive)
-
Confirm version string is exact match
-
Image Pull Failures
- Verify image exists and is accessible
- Check image registry authentication
-
Validate image digest/tag is correct
-
Platform Not Found
- Returns empty string (safe fallback)
- Check platform configuration in YAML
- Verify platform name spelling
Security/Production Considerations
- Only use trusted image registries for CPO overrides
- Validate override images are signed and verified
- If multiple architectures are supported in the data plane, ensure that override image references point to multi-arch repositories that have all architectures supported in the data plane.