-
Notifications
You must be signed in to change notification settings - Fork 52
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(RELEASE-1347): add resources to update manager yaml files
This commit adds a tenant task to fetch the image ref containing a git sha tag from the Release artifacts as well as a tenant task to update a file in git with the value of the image ref. It also adds a tenant pipeline that calls these two tasks. The point of this pipeline is to use it as a final pipeline. It will enable us to have the internal-services manager files updated once the internal-services managed pipelineRun succeeds. Today, this is a manual step. Signed-off-by: Johnny Bieren <[email protected]>
- Loading branch information
1 parent
b057dff
commit b91c5c6
Showing
6 changed files
with
153 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
# get-git-sha-image-ref-from-release | ||
|
||
Tekton task to get the image reference containing the git sha tag from the Release artifacts. | ||
|
||
It finds the git sha by checking for the `pac.test.appstudio.openshift.io/sha` label on the Release CR. | ||
If it is not found, the task will fail with error. | ||
|
||
This task is only meant to work with Releases for one component. If the task finds there are more than one image | ||
in its artifacts, it will fail with error. | ||
|
||
Once it has the git sha, the task simply returns the image url from the artifacts that ends with it. This is | ||
done via the `imageRef` task result. | ||
|
||
## Parameters | ||
|
||
| Name | Description | Optional | Default value | | ||
|----------------------|----------------------------------------------------|----------|---------------| | ||
| release | Namespaced name of the Release | No | - | |
48 changes: 48 additions & 0 deletions
48
tasks/tenant/get-git-sha-image-ref-from-release/get-git-sha-image-ref-from-release.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
--- | ||
apiVersion: tekton.dev/v1 | ||
kind: Task | ||
metadata: | ||
name: get-git-sha-image-ref-from-release | ||
labels: | ||
app.kubernetes.io/version: "0.1.0" | ||
annotations: | ||
tekton.dev/pipelines.minVersion: "0.12.1" | ||
tekton.dev/tags: "release, tenant" | ||
spec: | ||
description: >- | ||
Tekton task to output the imageRef stored in the Release artifacts that corresponds to the git sha tag. | ||
params: | ||
- name: release | ||
type: string | ||
description: The namespaced name of the Release | ||
results: | ||
- name: imageRef | ||
type: string | ||
description: The imageRef from the Release.Status.Artifacts that uses the git sha tag | ||
steps: | ||
- name: get-git-sha-image-ref-from-release | ||
image: quay.io/konflux-ci/release-service-utils:e633d51cd41d73e4b3310face21bb980af7a662f | ||
script: | | ||
#!/usr/bin/env bash | ||
set -exo pipefail | ||
IFS='/' read -r RELEASE_NAMESPACE RELEASE_NAME <<< "$(params.release)" | ||
GIT_SHA=$(kubectl get release "$RELEASE_NAME" -n "$RELEASE_NAMESPACE" \ | ||
-o jsonpath='{.metadata.labels.pac\.test\.appstudio\.openshift\.io/sha}') | ||
if [ -z "$GIT_SHA" ] ; then | ||
echo "Error: git sha label from PaC not found in Release labels" | ||
exit 1 | ||
fi | ||
IMAGES=$(kubectl get release "$RELEASE_NAME" -n "$RELEASE_NAMESPACE" \ | ||
-o jsonpath='{.status.artifacts.images}') | ||
if [ "$(jq 'length' <<< "$IMAGES")" -gt 1 ] ; then | ||
echo "Error: this task only supports Release CRs with one image in its artifacts." | ||
echo "Found images: $IMAGES" | ||
exit 1 | ||
fi | ||
jq -jr --arg sha "$GIT_SHA" '.[0].urls[] | select(test(".*" + $sha))' <<< "$IMAGES" \ | ||
> "$(results.imageRef.path)" |
7 changes: 7 additions & 0 deletions
7
tasks/tenant/get-git-sha-image-ref-from-release/tests/pre-apply-task-hook.sh
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
#!/usr/bin/env bash | ||
|
||
# Install the CRDs so we can create/get them | ||
.github/scripts/install_crds.sh | ||
|
||
# Add RBAC so that the SA executing the tests can retrieve CRs | ||
kubectl apply -f .github/resources/crd_rbac.yaml |
77 changes: 77 additions & 0 deletions
77
tasks/tenant/get-git-sha-image-ref-from-release/tests/test-get-git-sha-image-ref.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
--- | ||
apiVersion: tekton.dev/v1 | ||
kind: Pipeline | ||
metadata: | ||
name: test-get-git-sha-image-ref | ||
spec: | ||
description: | | ||
Run the collect-data task and verify that all resources are stored in the workspace. | ||
workspaces: | ||
- name: tests-workspace | ||
tasks: | ||
- name: setup | ||
taskSpec: | ||
steps: | ||
- name: create-cr | ||
image: quay.io/konflux-ci/release-service-utils:e633d51cd41d73e4b3310face21bb980af7a662f | ||
script: | | ||
#!/usr/bin/env bash | ||
set -eux | ||
cat > release << EOF | ||
apiVersion: appstudio.redhat.com/v1alpha1 | ||
kind: Release | ||
metadata: | ||
name: release-sample | ||
namespace: default | ||
labels: | ||
pac.test.appstudio.openshift.io/sha: abcdefg12345 | ||
spec: | ||
snapshot: foo | ||
releasePlan: foo | ||
EOF | ||
kubectl apply -f release | ||
# Status needs to be patched in, can't be added at apply time | ||
kubectl --warnings-as-errors=true patch release -n default release-sample --type=merge \ | ||
--subresource status --patch \ | ||
"status: {'artifacts':{'images':[{'urls':['quay.io/konflux-ci/myimage:abcdefg12345', | ||
'quay.io/konflux-ci/myimage:abcde']}]}}" | ||
- name: run-task | ||
taskRef: | ||
name: get-git-sha-image-ref-from-release | ||
params: | ||
- name: release | ||
value: default/release-sample | ||
runAfter: | ||
- setup | ||
- name: check-result | ||
params: | ||
- name: imageRef | ||
value: $(tasks.run-task.results.imageRef) | ||
runAfter: | ||
- run-task | ||
taskSpec: | ||
params: | ||
- name: imageRef | ||
type: string | ||
steps: | ||
- name: check-result | ||
image: quay.io/konflux-ci/release-service-utils:e633d51cd41d73e4b3310face21bb980af7a662f | ||
script: | | ||
#!/usr/bin/env bash | ||
set -eux | ||
echo Test the imageRef result was properly set | ||
test "$(params.imageRef)" == "quay.io/konflux-ci/myimage:abcdefg12345" | ||
finally: | ||
- name: cleanup | ||
taskSpec: | ||
steps: | ||
- name: delete-crs | ||
image: quay.io/konflux-ci/release-service-utils:e633d51cd41d73e4b3310face21bb980af7a662f | ||
script: | | ||
#!/usr/bin/env sh | ||
set -eux | ||
kubectl delete release release-sample |