Support ImagePullSecret for pulling from private registry #80
Workflow file for this run
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
--- | |
# these integration tests need to be per operator since they don't do clean up | |
# | |
# NOTE: can't use chart-testing because `ct` does not allow for a fixed release so you can't run two different tests that affect the same resources | |
name: Install Integration Test - operators-installer | |
on: | |
pull_request: | |
paths: | |
- .github/** | |
- _test/charts-integration-tests/operators-installer/** | |
- charts/operators-installer/** | |
# Declare default permissions as read only. | |
permissions: read-all | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
env: | |
registry_user: registryuser1 | |
registry_password: registrypassword1 | |
jobs: | |
install-integration-test: | |
runs-on: ubuntu-latest | |
env: | |
# renovate: datasource=github-releases depName=helm/helm | |
HELM_VERSION: v3.16.3 | |
# renovate: datasource=github-tags depName=python/cpython | |
PYTHON_VERSION: v3.13.0 | |
# renovate: datasource=github-releases depName=kubernetes-sigs/kind | |
KIND_VERSION: v0.25.0 | |
# renovate: datasource=github-releases depName=operator-framework/operator-lifecycle-manager | |
OLM_VERSION: v0.30.0 | |
steps: | |
- name: Checkout 🛎️ | |
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4 | |
with: | |
fetch-depth: 0 | |
- name: Setup Helm 🧰 | |
uses: azure/setup-helm@fe7b79cd5ee1e45176fcad797de68ecaf3ca4814 # v4 | |
with: | |
version: ${{ env.HELM_VERSION }} | |
- name: Setup Python 🐍 | |
uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5 | |
with: | |
python-version: ${{ env.PYTHON_VERSION }} | |
- name: Setup kind cluster 🧰 | |
uses: helm/kind-action@0025e74a8c7512023d06dc019c617aa3cf561fde # v1.10.0 | |
with: | |
version: ${{ env.KIND_VERSION }} | |
# for helm charts we are testing that require installing operators | |
- name: Setup kind cluster - Install OLM 🧰 | |
run: | | |
curl -L https://github.com/operator-framework/operator-lifecycle-manager/releases/download/${OLM_VERSION}/install.sh -o install.sh | |
chmod +x install.sh | |
./install.sh ${OLM_VERSION} | |
# for helm charts we are testing that require ingress | |
- name: Setup kind cluster - Install ingress controller 🧰 | |
run: | | |
helm repo add haproxy-ingress https://haproxy-ingress.github.io/charts | |
helm install haproxy-ingress haproxy-ingress/haproxy-ingress \ | |
--create-namespace --namespace=ingress-controller \ | |
--set controller.hostNetwork=true | |
kubectl apply -f - <<EOF | |
apiVersion: networking.k8s.io/v1 | |
kind: IngressClass | |
metadata: | |
name: haproxy | |
annotations: | |
ingressclass.kubernetes.io/is-default-class: 'true' | |
spec: | |
controller: haproxy-ingress.github.io/controller | |
EOF | |
# for testing operators-installer image from private repository | |
- name: Setup private registry in kind cluster 🧰 | |
run: | | |
helm upgrade --install private-registry charts/operators-installer/_integration-tests/private-registry \ | |
--namespace registry \ | |
--create-namespace \ | |
--wait \ | |
--set registryUser=${registry_user} \ | |
--set registryPassword=${registry_password} | |
# copies image used to install argo into local private registry | |
- name: Copy image into private repository 💿 | |
run: | | |
skopeo copy --dest-creds ${registry_user}:${registry_password} \ | |
docker://$(awk '$1 ~/Image:/ {print $2}' charts/operators-installer/_integration-tests/test-install-operator-0-automatic-intermediate-manual-upgrades-values.yaml) \ | |
docker://registry.localhost/origin-cli:5000 | |
# NOTE: can't use chart-testing because `ct` does not allow for a fixed release so you can't run two different tests that affect the same resources | |
- name: Run integration tests 🧪 | |
timeout-minutes: 30 | |
run: | | |
echo "##########################################################################################################" | |
echo "# Install argo at old version #" | |
echo "##########################################################################################################" | |
helm upgrade --install operators-installer-integration-test charts/operators-installer \ | |
--namespace operators-installer-integration-test \ | |
--create-namespace \ | |
--wait \ | |
--values charts/operators-installer/_integration-tests/test-install-operator-0-automatic-intermediate-manual-upgrades-values.yaml \ | |
--debug --timeout 10m0s | |
echo "##########################################################################################################" | |
echo "# Create pull secret used in next step #" | |
echo "##########################################################################################################" | |
oc create secret docker-registry local-registry-pullsecret \ | |
--namespace operators-installer-integration-test \ | |
--docker-password="${registry_user}" \ | |
--docker-username="${registry_password}" \ | |
--docker-server=registry.localhost | |
echo "##########################################################################################################" | |
echo "# Upgrade argo to newer version requiring many intermediate updates along the way #" | |
echo "##########################################################################################################" | |
helm upgrade --install operators-installer-integration-test charts/operators-installer \ | |
--namespace operators-installer-integration-test \ | |
--wait \ | |
--values charts/operators-installer/_integration-tests/test-install-operator-1-automatic-intermediate-manual-upgrades-values.yaml \ | |
--debug --timeout 30m0s |