This repository contains Konflux configuration to build Red Hat build OpenShift distributed tracing platform (Jaeger).
docker login brew.registry.redhat.io -u
docker login registry.redhat.io -u
git submodule update --init --recursive
podman build -t docker.io/user/jaeger-operator:$(date +%s) -f Dockerfile.operator
Update all base images (merge renovatebot PRs).
Create a PR Release - update upstream sources x.y
:
- Update git submodules with upstream versions
Note: If you use a forked repository instead of upstream, you must sync the git tags.
The version information is set dynamically using
git describe --tags
in the Dockerfile, and is crucial for e.g. the upgrade process of the operator.
Wait for renovatebot to create PRs to update the hash in the bundle-patch/update_bundle.sh
file, and merge all of them.
Create a PR Release - update bundle version x.y
and update patch_csv.yaml by submitting a PR with follow-up changes:
metadata.name
with the current version e.g.jaeger-operator.v1.58.0-1
metadata.extra_annotations.olm.skipRange
with the version being productized e.g.'>=0.33.0 <1.58.0-1'
spec.version
with the current version e.g.jaeger-operator.v1.58.0-1
spec.replaces
with the previous shipped version of CSV e.g.jaeger-operator.v1.57.0-1
- Update
release
,version
andcom.redhat.openshift.versions
(minimum OCP version) labels in bundle dockerfile - Verify diff of upstream and downstream ClusterServiceVersion
podman build -t jaeger-bundle -f Dockerfile.bundle . && podman cp $(podman create jaeger-bundle):/manifests/jaeger-operator.clusterserviceversion.yaml . git diff --no-index jaeger-operator/bundle/manifests/jaeger-operator.clusterserviceversion.yaml jaeger-operator.clusterserviceversion.yaml rm jaeger-operator.clusterserviceversion.yaml
Once the PR is merged and bundle is built, create another PR Release - update catalog x.y
with:
- Updated catalog template with the new bundle (get the bundle pullspec from
kubectl get component jaeger-bundle -o yaml
):opm alpha render-template basic --output yaml catalog/catalog-template.yaml > catalog/jaeger-product/catalog.yaml && \ opm alpha render-template basic --output yaml --migrate-level bundle-object-to-csv-metadata catalog/catalog-template.yaml > catalog/jaeger-product-4.17/catalog.yaml && \ sed -i 's#quay.io/redhat-user-workloads/rhosdt-tenant/jaeger/jaeger-bundle#registry.redhat.io/rhosdt/jaeger-operator-bundle#g' catalog/jaeger-product/catalog.yaml && \ sed -i 's#quay.io/redhat-user-workloads/rhosdt-tenant/jaeger/jaeger-bundle#registry.redhat.io/rhosdt/jaeger-operator-bundle#g' catalog/jaeger-product-4.17/catalog.yaml && \ opm validate catalog/jaeger-product && \ opm validate catalog/jaeger-product-4.17
Images can be found at https://quay.io/organization/redhat-user-workloads (search for rhosdt-tenant/jaeger
).
get latest pullspec from kubectl get component jaeger-bundle-quay -o yaml
, then run:
kubectl create namespace openshift-distributed-tracing
operator-sdk run bundle -n openshift-distributed-tracing quay.io/redhat-user-workloads/rhosdt-tenant/jaeger/jaeger-bundle-quay@sha256:509300864348265febf30328f9f380d1a5340bb5a5d466c51bf9951e6767c3ea
operator-sdk cleanup -n openshift-distributed-tracing jaeger-product
podman cp $(podman create --name tc registry.redhat.io/redhat/redhat-operator-index:v4.17):/configs/jaeger-product jaeger-product-4.17 && podman rm tc
opm migrate jaeger-product-4.17 jaeger-product-4.17-migrated
opm alpha convert-template basic --output yaml ./jaeger-product-4.17-migrated/jaeger-product/catalog.json > catalog/catalog-template.yaml