Test controlplane multi az #765
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
name: unit-func-e2e-test | |
on: | |
push: | |
branches: | |
- 'main' | |
paths: | |
- "**.go" | |
- "**.yaml" | |
- "!capm.yaml" | |
- "!osc-secret.yaml" | |
- "!example/**.yaml" | |
- "!testclean/**" | |
- "!helm/**" | |
- "Makefile" | |
- "hack/*.sh" | |
- "!docs/src/**" | |
- "!hack/json-format/*.sh" | |
- "!hack/json-format/src/*.rs" | |
- "!hack/json-format/Makefile" | |
- "!hack/json-format/Cargo.*" | |
- "!hack/json-format/tests/*.rs" | |
pull_request: | |
branches: [ main ] | |
paths: | |
- "**.go" | |
- "**.yaml" | |
- "!capm.yaml" | |
- "!osc-secret.yaml" | |
- "!example/**.yaml" | |
- "!testclean/**" | |
- "!helm/**" | |
- "Makefile" | |
- "hack/*.sh" | |
- "!docs/src/**" | |
- "!hack/json-format/*.sh" | |
- "!hack/json-format/src/*.rs" | |
- "!hack/json-format/Makefile" | |
- "!hack/json-format/Cargo.*" | |
- "!hack/json-format/tests/*.rs" | |
jobs: | |
testenv: | |
runs-on: [self-hosted, linux] | |
needs: [unit_test] | |
steps: | |
- name: Checkout cluster-api-outscale | |
uses: actions/checkout@v3 | |
with: | |
repository: ${{ github.event.pull_request.head.repo.full_name }} | |
ref: ${{ github.event.pull_request.head.ref }} | |
- name: Checkout osc-k8s-rke-cluster | |
uses: actions/checkout@v3 | |
with: | |
repository: 'outscale-dev/osc-k8s-rke-cluster' | |
path: "rke-cluster-for-cluster-api" | |
ref: master | |
- name: Install kubectl | |
uses: azure/[email protected] | |
with: | |
version: v1.22.7 | |
id: install | |
- name: Install golang | |
uses: actions/setup-go@v3 | |
with: | |
go-version: '>=1.17.8' | |
- name: Install kustomize | |
uses: imranismail/setup-kustomize@v1 | |
with: | |
kustomize-version: v4.5.7 | |
- uses: outscale-dev/frieza-github-actions/frieza-clean@master | |
with: | |
access_key: ${{ secrets.OSC_ACCESS_KEY }} | |
secret_key: ${{ secrets.OSC_SECRET_KEY }} | |
region: ${{ secrets.OSC_REGION }} | |
- name: Deploy Cluster | |
uses: ./rke-cluster-for-cluster-api/github_actions/deploy_cluster/ | |
with: | |
repository_folder: "rke-cluster-for-cluster-api" | |
osc_access_key: ${{ secrets.OSC_ACCESS_KEY }} | |
osc_secret_key: ${{ secrets.OSC_SECRET_KEY }} | |
osc_region: ${{ secrets.OSC_REGION }} | |
image_id: ${{ secrets.OMI_ID }} | |
control_plane_vm_type: ${{ secrets.CP_VMTYPE }} | |
bastion_vm_type: ${{ secrets.BASTION_VMTYPE }} | |
worker_vm_type: ${{ secrets.WORKER_VMTYPE }} | |
rke_version: ${{ secrets.RKE_VERSION }} | |
kubernetes_version: ${{ secrets.KUBERNETES_VERSION }} | |
- name: Wait Kubernetes control plane is up and running | |
uses: nick-invision/retry@v2 | |
with: | |
timeout_seconds: 30 | |
max_attempts: 20 | |
retry_wait_seconds: 30 | |
command: kubectl get --raw='/readyz?verbose' | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
- name: Wait all infrastructure app are really up and running | |
uses: jupyterhub/action-k8s-await-workloads@v1 | |
with: | |
workloads: "" | |
namespace: "" | |
timeout: 600 | |
max-restarts: -1 | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
- name: Deploy Docker-registry into cluster | |
run: | | |
ansible-playbook addons/docker-registry/playbook.yaml | |
./addons/docker-registry/start_port_forwarding.sh & | |
env: | |
KUBECONFIG: rke/kube_config_cluster.yml | |
ANSIBLE_CONFIG: ansible.cfg | |
working-directory: rke-cluster-for-cluster-api | |
- name: Wait registry up | |
uses: GuillaumeFalourd/wait-sleep-action@v1 | |
with: | |
time: '2m' | |
- name: Build and Push Docker image | |
run: | | |
sudo apt-get update | |
sudo apt install -y docker-buildx-plugin | |
make docker-buildx | |
make docker-push | |
docker image prune -a -f | |
env: | |
IMG: 127.0.0.1:4242/cluster-api-outscale-controller:${{ github.sha }} | |
DOCKER_BUILDKIT: 1 | |
- name: Retrieve NodePort Ip and NodePort | |
run: | | |
echo nodeport_port=$(kubectl get --namespace default -o jsonpath="{.spec.ports[0].nodePort}" services docker-registry) >> $GITHUB_ENV | |
echo nodeport_ip=$(kubectl get nodes --namespace default -o jsonpath="{.items[0].status.addresses[0].address}") >> $GITHUB_ENV | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
- name: Create ns and set credential | |
run: make credential | |
shell: bash | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
OSC_ACCESS_KEY: ${{secrets.OSC_ACCESS_KEY}} | |
OSC_SECRET_KEY: ${{secrets.OSC_SECRET_KEY}} | |
OSC_REGION: ${{ secrets.OSC_REGION }} | |
- name: Deploy cluster-api | |
run: make deploy-clusterapi | |
id: deploy-capi | |
shell: bash | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
- name: Deploy cluster-api-outscale | |
run: make deploy | |
shell: bash | |
id: deploy-capo | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
IMG: ${nodeport_ip}:${nodeport_port}/cluster-api-outscale-controller:${{ github.sha }} | |
- name: Launch functional test | |
run: make testenv | |
shell: bash | |
id: func-test | |
env: | |
KUBECONFIG: ${{ github.workspace }}/rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
OSC_ACCESS_KEY: ${{secrets.OSC_ACCESS_KEY}} | |
OSC_SECRET_KEY: ${{secrets.OSC_SECRET_KEY}} | |
OSC_REGION: ${{ secrets.OSC_REGION }} | |
OSC_SUBREGION_NAME: ${{ secrets.OSC_SUBREGION_NAME }} | |
IMG_UPGRADE_FROM: ${{ secrets.IMG_UPGRADE_FROM }} | |
- name: Get log capo master | |
run: make logs-capo | |
if: ${{ failure() && steps.func-test.conclusion == 'failure' }} | |
shell: bash | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
CAPO_NAMESPACE: cluster-api-provider-outscale-system | |
- name: Get log capi | |
run: make logs-capi | |
if: ${{ failure() && steps.func-test.conclusion == 'failure' }} | |
shell: bash | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
CAPO_NAMESPACE: cluster-api-provider-outscale-system | |
- name: Destroy cluster | |
uses: ./rke-cluster-for-cluster-api/github_actions/destroy_cluster/ | |
if: ${{ always() }} | |
with: | |
repository_folder: "./rke-cluster-for-cluster-api" | |
osc_access_key: ${{ secrets.OSC_ACCESS_KEY }} | |
osc_secret_key: ${{ secrets.OSC_SECRET_KEY }} | |
osc_region: ${{ secrets.OSC_REGION }} | |
unit_test: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
repository: ${{ github.event.pull_request.head.repo.full_name }} | |
ref: ${{ github.event.pull_request.head.ref }} | |
- uses: actions/setup-go@v3 | |
with: | |
go-version: '1.19.8' | |
- name: unit-test | |
run: | | |
make unit-test | |
cat covers.txt | |
shell: bash | |
e2etest: | |
runs-on: [self-hosted, linux] | |
needs: [unit_test, testenv] | |
steps: | |
- name: Checkout cluster-api-outscales | |
uses: actions/checkout@v3 | |
with: | |
repository: ${{ github.event.pull_request.head.repo.full_name }} | |
ref: ${{ github.event.pull_request.head.ref }} | |
- name: Checkout osc-k8s-rke-cluster | |
uses: actions/checkout@v3 | |
with: | |
repository: 'outscale-dev/osc-k8s-rke-cluster' | |
path: "rke-cluster-for-cluster-api" | |
ref: master | |
- name: Install kubectl | |
uses: azure/[email protected] | |
with: | |
version: v1.22.7 | |
id: install | |
- name: Install golang | |
uses: actions/setup-go@v3 | |
with: | |
go-version: '>=1.17.8' | |
- name: Install kustomize | |
uses: imranismail/setup-kustomize@v1 | |
with: | |
kustomize-version: v4.5.7 | |
- uses: outscale-dev/frieza-github-actions/frieza-clean@master | |
with: | |
access_key: ${{ secrets.OSC_ACCESS_KEY }} | |
secret_key: ${{ secrets.OSC_SECRET_KEY }} | |
region: ${{ secrets.OSC_REGION }} | |
- name: Deploy Cluster | |
uses: ./rke-cluster-for-cluster-api/github_actions/deploy_cluster/ | |
with: | |
repository_folder: "rke-cluster-for-cluster-api" | |
osc_access_key: ${{ secrets.OSC_ACCESS_KEY }} | |
osc_secret_key: ${{ secrets.OSC_SECRET_KEY }} | |
osc_region: ${{ secrets.OSC_REGION }} | |
image_id: ${{ secrets.OMI_ID }} | |
control_plane_vm_type: ${{ secrets.CP_VMTYPE }} | |
bastion_vm_type: ${{ secrets.BASTION_VMTYPE }} | |
worker_vm_type: ${{ secrets.WORKER_VMTYPE }} | |
rke_version: ${{ secrets.RKE_VERSION }} | |
kubernetes_version: ${{ secrets.KUBERNETES_VERSION }} | |
- name: Wait Kubernetes control plane is up and running | |
uses: nick-invision/retry@v2 | |
with: | |
timeout_seconds: 30 | |
max_attempts: 20 | |
retry_wait_seconds: 30 | |
command: kubectl get --raw='/readyz?verbose' | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
- name: Wait all infrastructure app are really up and running | |
uses: jupyterhub/action-k8s-await-workloads@v1 | |
with: | |
workloads: "" | |
namespace: "" | |
timeout: 600 | |
max-restarts: -1 | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
- name: Deploy Docker-registry into cluster | |
run: | | |
ansible-playbook addons/docker-registry/playbook.yaml | |
./addons/docker-registry/start_port_forwarding.sh & | |
env: | |
KUBECONFIG: rke/kube_config_cluster.yml | |
ANSIBLE_CONFIG: ansible.cfg | |
working-directory: rke-cluster-for-cluster-api | |
- name: Wait registry up | |
uses: GuillaumeFalourd/wait-sleep-action@v1 | |
with: | |
time: '2m' | |
- name: Build and Push Docker image | |
run: | | |
sudo apt-get update | |
sudo apt install -y docker-buildx-plugin | |
make docker-buildx | |
make docker-push | |
docker image prune -a -f | |
env: | |
IMG: 127.0.0.1:4242/cluster-api-outscale-controller:${{ github.sha }} | |
DOCKER_BUILDKIT: 1 | |
- name: Retrieve NodePort Ip and NodePort | |
run: | | |
echo 'NODEPORT_PORT<<EOF' >> $GITHUB_ENV | |
echo "$(kubectl get --namespace default -o jsonpath='{.spec.ports[0].nodePort}' services docker-registry)" >> $GITHUB_ENV | |
echo 'EOF' >> $GITHUB_ENV | |
echo 'NODEPORT_IP<<EOF' >> $GITHUB_ENV | |
echo "$(kubectl get nodes --namespace default -o jsonpath='{.items[0].status.addresses[0].address}')" >> $GITHUB_ENV | |
echo 'EOF' >> $GITHUB_ENV | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
- name: Create ns and set credential | |
run: make credential | |
shell: bash | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
OSC_ACCESS_KEY: ${{secrets.OSC_ACCESS_KEY}} | |
OSC_SECRET_KEY: ${{secrets.OSC_SECRET_KEY}} | |
OSC_REGION: ${{ secrets.OSC_REGION }} | |
- name: Launch e2etest | |
run: KUBECONFIG=$GITHUB_WORKSPACE/rke-cluster-for-cluster-api/rke/kube_config_cluster.yml make e2etestexistingcluster | |
shell: bash | |
id: e2etest | |
env: | |
IMG: ${{ env.NODEPORT_IP }}:${{ env.NODEPORT_PORT }}/cluster-api-outscale-controller:${{ github.sha }} | |
OSC_ACCESS_KEY: ${{secrets.OSC_ACCESS_KEY}} | |
OSC_SECRET_KEY: ${{secrets.OSC_SECRET_KEY}} | |
OSC_REGION: ${{ secrets.OSC_REGION }} | |
OSC_SUBREGION_NAME: ${{ secrets.OSC_SUBREGION_NAME }} | |
IMG_UPGRADE_FROM: ${{ secrets.IMG_UPGRADE_FROM }} | |
IMG_UPGRADE_TO: ${{ secrets.IMG_UPGRADE_TO }} | |
- name: Get cluster api outscale logs | |
run: make logs-capo | |
if: ${{ failure() && steps.e2etest.conclusion == 'failure' }} | |
shell: bash | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
CAPO_NAMESPACE: cluster-api-provider-outscale-system | |
- name: Get cluster api logs | |
run: make logs-capi | |
if: ${{ failure() && steps.e2etest.conclusion == 'failure' }} | |
shell: bash | |
env: | |
KUBECONFIG: rke-cluster-for-cluster-api/rke/kube_config_cluster.yml | |
CAPI_NAMESPACE: capi-kubeadm-bootstrap-system | |
- name: Destroy cluster | |
uses: ./rke-cluster-for-cluster-api/github_actions/destroy_cluster/ | |
if: ${{ always() }} | |
with: | |
repository_folder: "./rke-cluster-for-cluster-api" | |
osc_access_key: ${{ secrets.OSC_ACCESS_KEY }} | |
osc_secret_key: ${{ secrets.OSC_SECRET_KEY }} | |
osc_region: ${{ secrets.OSC_REGION }} |