From bf07199e8890a8c185f7c6f2544a76ca58d8a43e Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 16:10:27 +0000 Subject: [PATCH 01/13] Add migration tests --- .github/workflows/pull-request.yaml | 38 ++++ LICENSE | 201 ++++++++++++++++++ Makefile | 3 + e2e/s3-to-rqlite.sh | 40 ++++ e2e/shared/wait-for-app.sh | 18 ++ ...ces-hook.yaml => keep-resources-hook.yaml} | 8 +- 6 files changed, 306 insertions(+), 2 deletions(-) create mode 100644 .github/workflows/pull-request.yaml create mode 100644 LICENSE create mode 100644 Makefile create mode 100755 e2e/s3-to-rqlite.sh create mode 100755 e2e/shared/wait-for-app.sh rename templates/{abandon-resources-hook.yaml => keep-resources-hook.yaml} (86%) diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml new file mode 100644 index 0000000..33fa08e --- /dev/null +++ b/.github/workflows/pull-request.yaml @@ -0,0 +1,38 @@ +name: Pull request +on: +- pull_request +concurrency: + group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} + cancel-in-progress: true +jobs: + build: + name: Build + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v4 + - name: ttl.sh + env: + GITHUB_USER: automated-${{ github.run_id }} + run: make build-ttl.sh + + e2e: + runs-on: ubuntu-latest + needs: + - build + strategy: + fail-fast: false + matrix: + test: + - { name: s3-to-rqlite, licenseb64: ${{ secrets.S3_TO_RQLITE_LICENSE }} } + # - { name: pvc-to-rqlite, licenseb64: ${{ secrets.PVC_TO_RQLITE_LICENSE }} } + steps: + - name: Checkout + uses: actions/checkout@v4 + - name: Run test + working-directory: e2e + env: + CHART_URL: oci://ttl.sh/automated-${{ github.run_id }}/admin-console + CHART_VERSION: 0.0.0-main + LICENSE_BASE64: ${{ matrix.test.licenseb64 }} + run: ${{ matrix.test.name }}.sh diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..261eeb9 --- /dev/null +++ b/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..c49e41d --- /dev/null +++ b/Makefile @@ -0,0 +1,3 @@ +.PHONY: build-ttl.sh +build-ttl.sh: + ./scripts/build-ttl.sh \ No newline at end of file diff --git a/e2e/s3-to-rqlite.sh b/e2e/s3-to-rqlite.sh new file mode 100755 index 0000000..1b2ea9a --- /dev/null +++ b/e2e/s3-to-rqlite.sh @@ -0,0 +1,40 @@ +#!/bin/bash + +set -e + +# 1.107.8 is the latest version of the chart that uses s3 +helm install s3-to-rqlite oci://registry.replicated.com/library/admin-console \ + --version 1.107.8 \ + --namespace s3-to-rqlite \ + --create-namespace \ + --set password=password \ + --set isHelmManaged=false \ + --wait + +# download KOTS CLI +curl -LO "https://github.com/replicatedhq/kots/releases/latest/download/kots_linux_amd64.tar.gz" \ + && tar zxvf kots_linux_amd64.tar.gz \ + && mv kots /usr/local/bin/kubectl-kots + +# install the app +echo "$LICENSE_BASE64" | base64 -d > license.yaml +kubectl kots install s3-to-rqlite \ + --namespace s3-to-rqlite \ + --shared-password=password \ + --license-file=license.yaml + +# wait for the app to be ready +./shared/wait-for-app.sh s3-to-rqlite + +# upgrade the chart +helm upgrade -i s3-to-rqlite "$CHART_URL" \ + --version "$CHART_VERSION" \ + --namespace s3-to-rqlite \ + --wait + +# validate migration success +if ! kubectl logs -n s3-to-rqlite job/kotsadm-migrate-s3-to-rqlite | grep -q "Migrated from S3 to rqlite successfully!"; then + echo "Migration failed" + kubectl logs -n s3-to-rqlite job/kotsadm-migrate-s3-to-rqlite + exit 1 +fi diff --git a/e2e/shared/wait-for-app.sh b/e2e/shared/wait-for-app.sh new file mode 100755 index 0000000..c14b0e5 --- /dev/null +++ b/e2e/shared/wait-for-app.sh @@ -0,0 +1,18 @@ +#!/bin/bash + +set -e + +appSlug=$1 + +COUNTER=1 +while [ "$(kubectl kots get apps --namespace "$appSlug" | awk 'NR>1{print $2}')" != "ready" ]; do + ((COUNTER += 1)) + if [ $COUNTER -gt 120 ]; then + echo "Timed out waiting for app to be ready" + kubectl kots get apps --namespace "$appSlug" + echo "kotsadm logs:" + kubectl logs -l app=kotsadm --tail=100 --namespace "$appSlug" + exit 1 + fi + sleep 1 +done diff --git a/templates/abandon-resources-hook.yaml b/templates/keep-resources-hook.yaml similarity index 86% rename from templates/abandon-resources-hook.yaml rename to templates/keep-resources-hook.yaml index 6b6390f..e2e858f 100644 --- a/templates/abandon-resources-hook.yaml +++ b/templates/keep-resources-hook.yaml @@ -2,7 +2,7 @@ apiVersion: batch/v1 kind: Job metadata: - name: kotsadm-abandon-resources + name: kotsadm-keep-resources annotations: helm.sh/hook: pre-upgrade helm.sh/hook-weight: "2" @@ -20,6 +20,10 @@ spec: - /bin/sh - -c - | + # Delete old abandon-resources job if it exists + kubectl delete job kotsadm-abandon-resources -n {{ .Release.Namespace }} || true + + # Annotate resources to keep them if kubectl get configmap kotsadm-confg -n {{ .Release.Namespace }} -o jsonpath='{.metadata.labels.app\.kubernetes\.io/managed-by}' | grep -q "Helm"; then kubectl annotate configmap kotsadm-confg -n {{ .Release.Namespace }} helm.sh/resource-policy=keep fi @@ -33,7 +37,7 @@ spec: {{- end }} image: {{ .Values.images.kotsadm }} imagePullPolicy: IfNotPresent - name: abandon-resources + name: keep-resources resources: requests: cpu: 100m From 6e8b2e49f55324569feefb4c94f7df7347128cf8 Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 16:12:12 +0000 Subject: [PATCH 02/13] fix syntax --- .github/workflows/pull-request.yaml | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index 33fa08e..611d230 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -23,9 +23,10 @@ jobs: strategy: fail-fast: false matrix: - test: - - { name: s3-to-rqlite, licenseb64: ${{ secrets.S3_TO_RQLITE_LICENSE }} } + test: [ + { name: s3-to-rqlite, licenseb64: ${{ secrets.S3_TO_RQLITE_LICENSE }} } # - { name: pvc-to-rqlite, licenseb64: ${{ secrets.PVC_TO_RQLITE_LICENSE }} } + ] steps: - name: Checkout uses: actions/checkout@v4 From 48df6a9691668bb0d850e175f3a858d974b92e53 Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 16:39:31 +0000 Subject: [PATCH 03/13] updates --- .github/workflows/pull-request.yaml | 11 ++++----- e2e/s3-to-rqlite/license.yaml | 24 ++++++++++++++++++++ e2e/{s3-to-rqlite.sh => s3-to-rqlite/run.sh} | 3 +-- 3 files changed, 29 insertions(+), 9 deletions(-) create mode 100644 e2e/s3-to-rqlite/license.yaml rename e2e/{s3-to-rqlite.sh => s3-to-rqlite/run.sh} (92%) diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index 611d230..d112966 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -23,17 +23,14 @@ jobs: strategy: fail-fast: false matrix: - test: [ - { name: s3-to-rqlite, licenseb64: ${{ secrets.S3_TO_RQLITE_LICENSE }} } - # - { name: pvc-to-rqlite, licenseb64: ${{ secrets.PVC_TO_RQLITE_LICENSE }} } - ] + test: + - s3-to-rqlite steps: - name: Checkout uses: actions/checkout@v4 - name: Run test - working-directory: e2e + working-directory: e2e/${{ matrix.test }} env: CHART_URL: oci://ttl.sh/automated-${{ github.run_id }}/admin-console CHART_VERSION: 0.0.0-main - LICENSE_BASE64: ${{ matrix.test.licenseb64 }} - run: ${{ matrix.test.name }}.sh + run: run.sh diff --git a/e2e/s3-to-rqlite/license.yaml b/e2e/s3-to-rqlite/license.yaml new file mode 100644 index 0000000..bda1a52 --- /dev/null +++ b/e2e/s3-to-rqlite/license.yaml @@ -0,0 +1,24 @@ +apiVersion: kots.io/v1beta1 +kind: License +metadata: + name: github-action +spec: + appSlug: s3-to-rqlite + channelID: 2hEq6WzDcjAGkJwZnB7VglVMF7p + channelName: Automated + customerName: github-action + endpoint: https://replicated.app + entitlements: + expires_at: + description: License Expiration + signature: {} + title: Expiration + value: "" + valueType: String + isKotsInstallEnabled: true + isNewKotsUiEnabled: true + isSnapshotSupported: true + licenseID: 2hEqBry8vZcCoW7rC8AVz24yfjc + licenseSequence: 1 + licenseType: dev + signature: eyJsaWNlbnNlRGF0YSI6ImV5SmhjR2xXWlhKemFXOXVJam9pYTI5MGN5NXBieTkyTVdKbGRHRXhJaXdpYTJsdVpDSTZJa3hwWTJWdWMyVWlMQ0p0WlhSaFpHRjBZU0k2ZXlKdVlXMWxJam9pWjJsMGFIVmlMV0ZqZEdsdmJpSjlMQ0p6Y0dWaklqcDdJbXhwWTJWdWMyVkpSQ0k2SWpKb1JYRkNjbms0ZGxwalEyOVhOM0pET0VGV2VqSTBlV1pxWXlJc0lteHBZMlZ1YzJWVWVYQmxJam9pWkdWMklpd2lZM1Z6ZEc5dFpYSk9ZVzFsSWpvaVoybDBhSFZpTFdGamRHbHZiaUlzSW1Gd2NGTnNkV2NpT2lKek15MTBieTF5Y1d4cGRHVWlMQ0pqYUdGdWJtVnNTVVFpT2lJeWFFVnhObGQ2UkdOcVFVZHJTbmRhYmtJM1ZtZHNWazFHTjNBaUxDSmphR0Z1Ym1Wc1RtRnRaU0k2SWtGMWRHOXRZWFJsWkNJc0lteHBZMlZ1YzJWVFpYRjFaVzVqWlNJNk1Td2laVzVrY0c5cGJuUWlPaUpvZEhSd2N6b3ZMM0psY0d4cFkyRjBaV1F1WVhCd0lpd2laVzUwYVhSc1pXMWxiblJ6SWpwN0ltVjRjR2x5WlhOZllYUWlPbnNpZEdsMGJHVWlPaUpGZUhCcGNtRjBhVzl1SWl3aVpHVnpZM0pwY0hScGIyNGlPaUpNYVdObGJuTmxJRVY0Y0dseVlYUnBiMjRpTENKMllXeDFaU0k2SWlJc0luWmhiSFZsVkhsd1pTSTZJbE4wY21sdVp5SXNJbk5wWjI1aGRIVnlaU0k2ZTMxOWZTd2lhWE5UYm1Gd2MyaHZkRk4xY0hCdmNuUmxaQ0k2ZEhKMVpTd2lhWE5PWlhkTGIzUnpWV2xGYm1GaWJHVmtJanAwY25WbExDSnBjMHR2ZEhOSmJuTjBZV3hzUlc1aFlteGxaQ0k2ZEhKMVpYMTkiLCJpbm5lclNpZ25hdHVyZSI6ImV5SnNhV05sYm5ObFUybG5ibUYwZFhKbElqb2lUakF6U1VwQ1lWWmFRek40UldkeVMwcEpUbVZLVG1wU1FrdDFSMDFFVG1GaFRWaERNRXR5ZUVNdlJWUnpjM2RNUW5sTllrRTBkRVIwVkRab2FVRTBkMEZPSzJsNVppdElLMUZYVmpRclRXeHZWRGxuWWtjeFdFUnFXQ3RPTVU1SGRuTlpUMWR2TlhsVGJuRk5NbXhOU1V3emNFdEhUakJsZWtsVU5TOWlNSEZCT1VOVU0wRlNNVTVNY0hoR1VXeDBiazVSUldsTmVGQmtOemQ1Y1ZkaGVqTllaMFpMYWpGblRHRkhUVlEyVVhJdmNtRm5MM0ZOUmxkUFdsUTNMMFprY1ZSblJVWnpjRmxLTkhSVWVrUjVVMnhqTkdFeFZucFVaVVJYUlU5b2JWRlhjWGRZTldkak5YZHlNekZUVVU1blUzZG9hRUZhTDIxeU1rcDVNbXQ2VFdNMWF6QlBVekJ5V1ZSSldIbE9WVzg0ZGtOek4zcFFaMUZ4U1RWRE9USkVTVVIzTVN0aE9WVllVRkpOUW5oeWJVcDRZMkYyYm5oYWJXUkdjRGcxZFd4UWNEVnNWWGRVVUVrMlVERXlkV3g0UTA5c2FsaFJQVDBpTENKd2RXSnNhV05MWlhraU9pSXRMUzB0TFVKRlIwbE9JRkJWUWt4SlF5QkxSVmt0TFMwdExWeHVUVWxKUWtscVFVNUNaMnR4YUd0cFJ6bDNNRUpCVVVWR1FVRlBRMEZST0VGTlNVbENRMmRMUTBGUlJVRnRSR04yZFZremJ6SjBSemhpV0Rjd1ZpdGFORnh1WjNaclFVUlROQ3RwUVdGc1dIcDJXUzluU0d4c2FXeHdXbVo2YzFsdVJFWnlXbkpRZVVGSGRVRmhRVTB3ZFRod09IUnpibTVFU2xZMmJXUTRjbWcwTWx4dVJGaEtRM1J2VjFwWFducEZiVWxYZGxCTWRVUkRWVEJUYVdWRUwyWlVTRzh6ZGs5NllucHhiMFF6VVRsWWNFUjRZM1I1VDJ4QlEzTkhOSEpyU0RoMVdWeHVkMnByZFRSVE1Fc3lSMWhTZFdSS2FqQkRjV2xUYlc5RlNVSnBjVE5JWW05S1JUTkJRVUoxU1ZaUk1XTlZZa3hIWVVOWllrcHpURmxXZGxsMmRIVmFTRnh1WjA5QlpYUjNTR3B0UXpCT1JYbFhjV2RpVW1oT01EUjNXRkpGUkVSQlNISmxhVGxXVmxGaVEyc3dlVlZyV0dRM05qSmtVR2RFTjBWcFRXTnJVbEpUUzF4dU5EWjNRbkkzV0hCUFpIcGxObUZhWTFSVVNFNXZWMGhVTWxkVllWVnJZV2RwTVRKd09YSlVZVGRoTWk5VVMxZFFLMng1TkM5Tk5VWTVWVU5PSzNoRFNGeHVjbEZKUkVGUlFVSmNiaTB0TFMwdFJVNUVJRkJWUWt4SlF5QkxSVmt0TFMwdExWeHVJaXdpYTJWNVUybG5ibUYwZFhKbElqb2laWGxLZW1GWFpIVlpXRkl4WTIxVmFVOXBTa05hTVVaYVZVWktSV1JZVFRKYVNFNXlWMVpDTmxac1FsRldSbEl4WkVab1QxVkVhSFppUjFFeVVsaHZkbFJWV2toT01HTjNaSHBDYlZkcE9YcGxSbXhFWkRKa1lXVnBPVkZNTTBKS1N6QTFlRlJyT1hCT2JrWm9UbTFKTWxaSFVuUldiRVp3WlZjNWFGVnRNWFJSTVdoWlpVVmtXbFZFUW5CV2VtUTJVMjFPU0ZkcWFFOVZSMUpOVFcxamNscHVWakppYTA1b1ZGWldkRTR5V1hsVWFscGFZbFZhVFdGVk9VNVVWMXBQVGxOME1WVnRXWFpYUlhBeFRsVktTRTFyY0hKWGFYUTJZVVJDVW1OclJuRldibEkxV2xoU2RtSlZaM3BUVmxKRVdrWk9kMk5FU2t0VVdHeDRZakp3ZG1Oc2NIRmpNVkY2WTFWU1QxRnNUVEpYVkVweFRrUnNVMUpWT1hSaU1HUklWVEpqTTFSVVdteFVTRkp3U3pGU1JWUnNaRkJYYTNoNVYwUmFkRk13YkdoaFdFSlRaRVpKY21SRVpIcGhSMk4yV2xaa2RHTnRkekZpYTJ4dFVWY3hObFZHYjNwTE1VWjZWRzVHYVZOR2IzWmtWVFZVWVRGS05rNXNiR3RSYTJoVFVucEJjazVWZHpSV1IzaEhWRWhPUzA5SFRuVmhlbVJOWVd4T1NscEdaSEJhVm1SWFdURldNbUZIT1ZWWFJ6VkVUVEZzYVdFd2RFdGhhMmhMWTFka1dsVnVWa1ZQVmtwUVdXcG9jRlZzWkhCWFZra3lXa1pXUlZOSVl6bFFVMGx6U1cxa2MySXlTbWhpUlhSc1pWVnNhMGxxYjJsWmJWSnNXbFJWTWs1VVdYZFpNbHBwVGtST2FrOVhTWGxQUjBwdFQxUm9iRmxYVG1oYWJVVXlUa1JaYVdaUlBUMGlmUT09In0= diff --git a/e2e/s3-to-rqlite.sh b/e2e/s3-to-rqlite/run.sh similarity index 92% rename from e2e/s3-to-rqlite.sh rename to e2e/s3-to-rqlite/run.sh index 1b2ea9a..9bb5851 100755 --- a/e2e/s3-to-rqlite.sh +++ b/e2e/s3-to-rqlite/run.sh @@ -17,14 +17,13 @@ curl -LO "https://github.com/replicatedhq/kots/releases/latest/download/kots_lin && mv kots /usr/local/bin/kubectl-kots # install the app -echo "$LICENSE_BASE64" | base64 -d > license.yaml kubectl kots install s3-to-rqlite \ --namespace s3-to-rqlite \ --shared-password=password \ --license-file=license.yaml # wait for the app to be ready -./shared/wait-for-app.sh s3-to-rqlite +../shared/wait-for-app.sh s3-to-rqlite # upgrade the chart helm upgrade -i s3-to-rqlite "$CHART_URL" \ From 65f2586f206b21ec6674e52b664d388bf3fcb6cb Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 16:42:35 +0000 Subject: [PATCH 04/13] updates --- .github/workflows/pull-request.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index d112966..d5850d3 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -33,4 +33,4 @@ jobs: env: CHART_URL: oci://ttl.sh/automated-${{ github.run_id }}/admin-console CHART_VERSION: 0.0.0-main - run: run.sh + run: ./run.sh From d13a3c17913eb5737013c404f93781e45a4e5ec7 Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 16:59:47 +0000 Subject: [PATCH 05/13] updates --- .github/actions/e2e/action.yml | 43 +++++++++++++++++++ .../generate-support-bundle/action.yml | 33 ++++++++++++++ .github/workflows/pull-request.yaml | 10 ++--- LICENSE | 2 +- 4 files changed, 81 insertions(+), 7 deletions(-) create mode 100644 .github/actions/e2e/action.yml create mode 100644 .github/actions/generate-support-bundle/action.yml diff --git a/.github/actions/e2e/action.yml b/.github/actions/e2e/action.yml new file mode 100644 index 0000000..8cad39c --- /dev/null +++ b/.github/actions/e2e/action.yml @@ -0,0 +1,43 @@ +name: 'KOTS E2E' +description: 'Composite action for running KOTS e2e test' +inputs: + test-name: + description: 'Individual test to run' + required: true +runs: + using: "composite" + steps: + - name: Create Cluster + id: create-cluster + uses: replicatedhq/replicated-actions/create-cluster@v1 + with: + api-token: ${{ secrets.C11Y_MATRIX_TOKEN }} + kubernetes-distribution: kind + kubernetes-version: v1.28.0 + cluster-name: automated-kots-helm-${{ github.run_id }}-${{ input.test-name }} + timeout-minutes: '120' + ttl: 2h + export-kubeconfig: true + + - name: Run test + working-directory: e2e/${{ input.test-name }} + env: + CHART_URL: oci://ttl.sh/automated-${{ github.run_id }}/admin-console + CHART_VERSION: 0.0.0-main + run: ./run.sh + shell: bash + + - name: Generate support bundle on failure + if: failure() + uses: ./.github/actions/generate-support-bundle + with: + artifact-name: ${{ input.test-name }}-${{ github.run_id }}-support-bundle + + - name: Remove Cluster + id: remove-cluster + uses: replicatedhq/replicated-actions/remove-cluster@v1 + if: ${{ always() && steps.create-cluster.outputs.cluster-id != '' }} + continue-on-error: true + with: + api-token: ${{ secrets.C11Y_MATRIX_TOKEN }} + cluster-id: ${{ steps.create-cluster.outputs.cluster-id }} diff --git a/.github/actions/generate-support-bundle/action.yml b/.github/actions/generate-support-bundle/action.yml new file mode 100644 index 0000000..f5e7a21 --- /dev/null +++ b/.github/actions/generate-support-bundle/action.yml @@ -0,0 +1,33 @@ +name: 'Generate Support Bundle' +description: 'Composite action for generating a support bundle' +inputs: + artifact-name: + description: 'Name of the artifact to be uploaded' + required: true +runs: + using: "composite" + steps: + - id: generate-support-bundle + run: | + RELEASE="$( + curl -sfL https://api.github.com/repos/replicatedhq/troubleshoot/releases/latest | \ + grep '"tag_name":' | \ + sed -E 's/.*"(v[^"]+)".*/\1/' + )" + curl -fsLO "https://github.com/replicatedhq/troubleshoot/releases/download/${RELEASE}/support-bundle_linux_amd64.tar.gz" + tar xzf support-bundle_linux_amd64.tar.gz + ./support-bundle https://kots.io + BUNDLE="$(ls -1 | grep 'support-bundle-.*.tar.gz')" + echo "bundle-name=$BUNDLE" >> "$GITHUB_OUTPUT" + shell: bash + + - id: upload-support-bundle + uses: actions/upload-artifact@v4 + with: + name: ${{ inputs.artifact-name }} + path: ${{ steps.generate-support-bundle.outputs.bundle-name }} + + - name: Print support bundle URL + shell: bash + run: | + echo "::notice ::support bundle can be downloaded from: ${{ steps.upload-support-bundle.outputs.artifact-url }}" diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index d5850d3..989cab5 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -28,9 +28,7 @@ jobs: steps: - name: Checkout uses: actions/checkout@v4 - - name: Run test - working-directory: e2e/${{ matrix.test }} - env: - CHART_URL: oci://ttl.sh/automated-${{ github.run_id }}/admin-console - CHART_VERSION: 0.0.0-main - run: ./run.sh + - uses: ./.github/actions/e2e + secrets: inherit + with: + test-name: ${{ matrix.test }} diff --git a/LICENSE b/LICENSE index 261eeb9..cb5c3c8 100644 --- a/LICENSE +++ b/LICENSE @@ -186,7 +186,7 @@ same "printed page" as the copyright notice for easier identification within third-party archives. - Copyright [yyyy] [name of copyright owner] + Copyright 2024 Replicated, Inc. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. From 4966c39242d34338181e3f15b0b1b468408842d4 Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 17:05:51 +0000 Subject: [PATCH 06/13] updates --- .github/actions/e2e/action.yml | 7 +++++-- .github/workflows/pull-request.yaml | 1 + 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/.github/actions/e2e/action.yml b/.github/actions/e2e/action.yml index 8cad39c..0af26a8 100644 --- a/.github/actions/e2e/action.yml +++ b/.github/actions/e2e/action.yml @@ -4,6 +4,9 @@ inputs: test-name: description: 'Individual test to run' required: true + replicated-api-token: + description: 'Replicated API token for C11y matrix' + required: false runs: using: "composite" steps: @@ -11,7 +14,7 @@ runs: id: create-cluster uses: replicatedhq/replicated-actions/create-cluster@v1 with: - api-token: ${{ secrets.C11Y_MATRIX_TOKEN }} + api-token: ${{ inputs.replicated-api-token }} kubernetes-distribution: kind kubernetes-version: v1.28.0 cluster-name: automated-kots-helm-${{ github.run_id }}-${{ input.test-name }} @@ -39,5 +42,5 @@ runs: if: ${{ always() && steps.create-cluster.outputs.cluster-id != '' }} continue-on-error: true with: - api-token: ${{ secrets.C11Y_MATRIX_TOKEN }} + api-token: ${{ inputs.replicated-api-token }} cluster-id: ${{ steps.create-cluster.outputs.cluster-id }} diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index 989cab5..d24e85e 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -32,3 +32,4 @@ jobs: secrets: inherit with: test-name: ${{ matrix.test }} + replicated-api-token: ${{ secrets.C11Y_MATRIX_TOKEN }} From 3f9d1acb26d199ee323a161a09f616454a7d4391 Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 17:07:59 +0000 Subject: [PATCH 07/13] remove secrets inherit --- .github/workflows/pull-request.yaml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index d24e85e..6a795c3 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -29,7 +29,6 @@ jobs: - name: Checkout uses: actions/checkout@v4 - uses: ./.github/actions/e2e - secrets: inherit with: test-name: ${{ matrix.test }} replicated-api-token: ${{ secrets.C11Y_MATRIX_TOKEN }} From 02a9b3df74bb02b361d4f6a5f90c3c567ba5fc14 Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 17:11:11 +0000 Subject: [PATCH 08/13] updates --- .github/actions/e2e/action.yml | 6 +++--- .github/workflows/pull-request.yaml | 15 +++++++++++++++ 2 files changed, 18 insertions(+), 3 deletions(-) diff --git a/.github/actions/e2e/action.yml b/.github/actions/e2e/action.yml index 0af26a8..ea3516f 100644 --- a/.github/actions/e2e/action.yml +++ b/.github/actions/e2e/action.yml @@ -17,13 +17,13 @@ runs: api-token: ${{ inputs.replicated-api-token }} kubernetes-distribution: kind kubernetes-version: v1.28.0 - cluster-name: automated-kots-helm-${{ github.run_id }}-${{ input.test-name }} + cluster-name: automated-kots-helm-${{ github.run_id }}-${{ inputs.test-name }} timeout-minutes: '120' ttl: 2h export-kubeconfig: true - name: Run test - working-directory: e2e/${{ input.test-name }} + working-directory: e2e/${{ inputs.test-name }} env: CHART_URL: oci://ttl.sh/automated-${{ github.run_id }}/admin-console CHART_VERSION: 0.0.0-main @@ -34,7 +34,7 @@ runs: if: failure() uses: ./.github/actions/generate-support-bundle with: - artifact-name: ${{ input.test-name }}-${{ github.run_id }}-support-bundle + artifact-name: ${{ inputs.test-name }}-${{ github.run_id }}-support-bundle - name: Remove Cluster id: remove-cluster diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index 6a795c3..9847800 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -32,3 +32,18 @@ jobs: with: test-name: ${{ matrix.test }} replicated-api-token: ${{ secrets.C11Y_MATRIX_TOKEN }} + + # this job will validate that all the tests passed + # it is used for the github branch protection rule + validate-success: + runs-on: ubuntu-20.04 + needs: + - e2e + if: always() + steps: + # https://docs.github.com/en/actions/learn-github-actions/contexts#needs-context + - name: fail if e2e job was not successful + if: needs.e2e.result != 'success' + run: exit 1 + - name: succeed if everything else passed + run: echo "Validation succeeded" From c5fca2568e2da761ac0c4cdd47bb5a77ee7246fd Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 18:03:30 +0000 Subject: [PATCH 09/13] updates --- .github/actions/e2e/action.yml | 6 ++++-- .github/workflows/pull-request.yaml | 13 +++++++++---- Makefile | 3 --- README.md | 2 +- e2e/s3-to-rqlite/run.sh | 6 +++--- scripts/build-local.sh | 17 +++++++++-------- 6 files changed, 26 insertions(+), 21 deletions(-) delete mode 100644 Makefile diff --git a/.github/actions/e2e/action.yml b/.github/actions/e2e/action.yml index ea3516f..72a0131 100644 --- a/.github/actions/e2e/action.yml +++ b/.github/actions/e2e/action.yml @@ -4,6 +4,9 @@ inputs: test-name: description: 'Individual test to run' required: true + chart-path: + description: 'Path to the chart to test' + required: true replicated-api-token: description: 'Replicated API token for C11y matrix' required: false @@ -25,8 +28,7 @@ runs: - name: Run test working-directory: e2e/${{ inputs.test-name }} env: - CHART_URL: oci://ttl.sh/automated-${{ github.run_id }}/admin-console - CHART_VERSION: 0.0.0-main + CHART_PATH: ${{ inputs.chart-path }} run: ./run.sh shell: bash diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index 9847800..f78a7e7 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -8,13 +8,17 @@ jobs: build: name: Build runs-on: ubuntu-latest + outputs: + chart-path: ${{ steps.build.outputs.chart-path }} steps: - name: Checkout uses: actions/checkout@v4 - - name: ttl.sh - env: - GITHUB_USER: automated-${{ github.run_id }} - run: make build-ttl.sh + - name: build local + id: build + run: | + KOTS_TAG=$(gh release view --repo replicatedhq/kots --json tagName -q .tagName) + ./scripts/build-local.sh "$KOTS_TAG" + echo "chart-path=admin-console-${KOTS_TAG#v}.tgz" >> "$GITHUB_OUTPUT" e2e: runs-on: ubuntu-latest @@ -31,6 +35,7 @@ jobs: - uses: ./.github/actions/e2e with: test-name: ${{ matrix.test }} + chart-path: ${{ needs.build.outputs.chart-path }} replicated-api-token: ${{ secrets.C11Y_MATRIX_TOKEN }} # this job will validate that all the tests passed diff --git a/Makefile b/Makefile deleted file mode 100644 index c49e41d..0000000 --- a/Makefile +++ /dev/null @@ -1,3 +0,0 @@ -.PHONY: build-ttl.sh -build-ttl.sh: - ./scripts/build-ttl.sh \ No newline at end of file diff --git a/README.md b/README.md index 9461716..dd53c4f 100644 --- a/README.md +++ b/README.md @@ -19,7 +19,7 @@ Run build-local.sh script located in the scripts directory of this repository to The input parameter is the kots version to package ``` -./scripts/build-local.sh 1.75.0 +./scripts/build-local.sh v1.75.0 ``` To build a chart that uses ttl images, run the build-ttl.sh script located in the scripts directory. diff --git a/e2e/s3-to-rqlite/run.sh b/e2e/s3-to-rqlite/run.sh index 9bb5851..151524f 100755 --- a/e2e/s3-to-rqlite/run.sh +++ b/e2e/s3-to-rqlite/run.sh @@ -20,14 +20,14 @@ curl -LO "https://github.com/replicatedhq/kots/releases/latest/download/kots_lin kubectl kots install s3-to-rqlite \ --namespace s3-to-rqlite \ --shared-password=password \ - --license-file=license.yaml + --license-file=license.yaml \ + --no-port-forward # wait for the app to be ready ../shared/wait-for-app.sh s3-to-rqlite # upgrade the chart -helm upgrade -i s3-to-rqlite "$CHART_URL" \ - --version "$CHART_VERSION" \ +helm upgrade -i s3-to-rqlite "$CHART_PATH" \ --namespace s3-to-rqlite \ --wait diff --git a/scripts/build-local.sh b/scripts/build-local.sh index 2f64180..4bc2871 100755 --- a/scripts/build-local.sh +++ b/scripts/build-local.sh @@ -2,20 +2,21 @@ set -e -export CURRENT_USER=${GITHUB_USER:-$(id -u -n)} -export KOTS_VERSION=$1 -export KOTS_TAG=v${KOTS_VERSION} +if [ -z "$1" ]; then + echo "Usage: $0 " + exit 1 +fi + +export KOTS_TAG=$1 export KOTSADM_REGISTRY=kotsadm # docker.io is implicit -export CHART_VERSION=${KOTS_VERSION} +export CHART_VERSION=${KOTS_TAG#v} -curl -O -L https://raw.githubusercontent.com/replicatedhq/kots/${KOTS_TAG}/.image.env +curl -O -L https://raw.githubusercontent.com/replicatedhq/kots/"${KOTS_TAG}"/.image.env export $(cat .image.env | sed 's/#.*//g' | xargs) envsubst < Chart.yaml.tmpl > Chart.yaml envsubst < values.yaml.tmpl > values.yaml rm -f admin-console-*.tgz -export CHART_NAME=`helm package . | rev | cut -d/ -f1 | rev` -helm push $CHART_NAME oci://ttl.sh/${CURRENT_USER} - +helm package . rm -f Chart.yaml values.yaml .image.env \ No newline at end of file From 4eb37b030b6963b8aab1d99d1f9dacd2afb5e04c Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 18:08:47 +0000 Subject: [PATCH 10/13] gh token --- .github/workflows/pull-request.yaml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index f78a7e7..f91b57b 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -15,6 +15,8 @@ jobs: uses: actions/checkout@v4 - name: build local id: build + env: + GH_TOKEN: ${{ github.token }} run: | KOTS_TAG=$(gh release view --repo replicatedhq/kots --json tagName -q .tagName) ./scripts/build-local.sh "$KOTS_TAG" From 94d3c1c6be60ac0d814037a9720db8eecc6436fe Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 18:19:29 +0000 Subject: [PATCH 11/13] one more try --- .github/workflows/pull-request.yaml | 6 +++--- Makefile | 3 +++ 2 files changed, 6 insertions(+), 3 deletions(-) create mode 100644 Makefile diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index f91b57b..4b1e7a4 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -18,9 +18,9 @@ jobs: env: GH_TOKEN: ${{ github.token }} run: | - KOTS_TAG=$(gh release view --repo replicatedhq/kots --json tagName -q .tagName) - ./scripts/build-local.sh "$KOTS_TAG" - echo "chart-path=admin-console-${KOTS_TAG#v}.tgz" >> "$GITHUB_OUTPUT" + export KOTS_TAG=$(gh release view --repo replicatedhq/kots --json tagName -q .tagName) + make build + echo "chart-path=${{ github.workspace }}/admin-console-${{ env.KOTS_TAG#v }}.tgz" >> "$GITHUB_OUTPUT" e2e: runs-on: ubuntu-latest diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..981ec30 --- /dev/null +++ b/Makefile @@ -0,0 +1,3 @@ +.PHONY: build +build: + ./scripts/build-local.sh ${KOTS_TAG} \ No newline at end of file From f0bc3bdf475084f38f3ed15f57bcb5851e34e4bf Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 18:20:08 +0000 Subject: [PATCH 12/13] fix --- .github/workflows/pull-request.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index 4b1e7a4..07b4a3b 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -20,7 +20,7 @@ jobs: run: | export KOTS_TAG=$(gh release view --repo replicatedhq/kots --json tagName -q .tagName) make build - echo "chart-path=${{ github.workspace }}/admin-console-${{ env.KOTS_TAG#v }}.tgz" >> "$GITHUB_OUTPUT" + echo "chart-path=${{ github.workspace }}/admin-console-${KOTS_TAG#v}.tgz" >> "$GITHUB_OUTPUT" e2e: runs-on: ubuntu-latest From 8e011403f762e9cf83c700d07319800db53d739c Mon Sep 17 00:00:00 2001 From: Salah Al Saleh Date: Fri, 31 May 2024 18:42:06 +0000 Subject: [PATCH 13/13] updates --- .github/workflows/pull-request.yaml | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index 07b4a3b..f83a5ac 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -8,19 +8,21 @@ jobs: build: name: Build runs-on: ubuntu-latest - outputs: - chart-path: ${{ steps.build.outputs.chart-path }} steps: - name: Checkout uses: actions/checkout@v4 - - name: build local - id: build + - name: Build local env: GH_TOKEN: ${{ github.token }} run: | export KOTS_TAG=$(gh release view --repo replicatedhq/kots --json tagName -q .tagName) make build - echo "chart-path=${{ github.workspace }}/admin-console-${KOTS_TAG#v}.tgz" >> "$GITHUB_OUTPUT" + mv admin-console-${KOTS_TAG#v}.tgz admin-console-chart.tgz + - name: Upload chart + uses: actions/upload-artifact@v4 + with: + name: admin-console-chart + path: admin-console-chart.tgz e2e: runs-on: ubuntu-latest @@ -34,10 +36,14 @@ jobs: steps: - name: Checkout uses: actions/checkout@v4 + - name: Download chart + uses: actions/download-artifact@v4 + with: + name: admin-console-chart - uses: ./.github/actions/e2e with: test-name: ${{ matrix.test }} - chart-path: ${{ needs.build.outputs.chart-path }} + chart-path: ${{ github.workspace }}/admin-console-chart.tgz replicated-api-token: ${{ secrets.C11Y_MATRIX_TOKEN }} # this job will validate that all the tests passed