Skip to content

(ci): pre-configuration of e2e testing #56

(ci): pre-configuration of e2e testing

(ci): pre-configuration of e2e testing #56

Workflow file for this run

name: E2E
on:
workflow_dispatch:
inputs:
debug_enabled:
type: boolean
description: Run the build with upterm debugging enabled
(https://github.com/lhotari/action-upterm/)
required: false
default: false
pull_request:
branches:
- main
concurrency:
group: e2e-${{ github.head_ref || github.ref_name }}
cancel-in-progress: true
jobs:
unit-test:
runs-on: ubuntu-latest
name: Unit Test
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Set up Go
uses: actions/setup-go@v4
with:
go-version: "1.22"
- name: Run Unit Tests
run: go test ./...
e2e-test-empty:
runs-on: ubuntu-latest
# container:
# image: quay.io/containers/podman:latest
# options: --privileged
name: E2E Empty Test
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Install Kind
run: |
curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.12.0/kind-linux-amd64
chmod +x ./kind
sudo mv ./kind /usr/local/bin/kind
- name: Create and Start Kind Cluster
run: kind create cluster
- name: Install kubectl
run: |
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"
chmod +x ./kubectl
sudo mv ./kubectl /usr/local/bin/kubectl
- name: Set up kubectl
run: |
kind export kubeconfig --name kind-kind
kubectl cluster-info
# - name: Set up Go
# uses: actions/setup-go@v4
# with:
# go-version: "1.22"
# - name: Install Orbstack
# run: go install github.com/your-username/orbstack
# - name: Run Orbstack Tests
# run: |
# orbstack --test
- name: Install DevSpace
run: |
curl -fsSL -o /tmp/devspace https://github.com/devspace-cloud/devspace/releases/latest/download/devspace-linux-amd64
chmod +x /tmp/devspace
sudo mv /tmp/devspace /usr/local/bin/devspace
# - name: Configure kubectl
# uses: actions-hub/kubectl@master
# env:
# KUBE_CONFIG: apiVersion: v1
clusters:
  - cluster:
      certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUJkakNDQVIyZ0F3SUJBZ0lCQURBS0JnZ3Foa2pPUFFRREFqQWpNU0V3SHdZRFZRUUREQmhyTTNNdGMyVnkKZG1WeUxXTmhRREUzTURnd01EZ3lNVE13SGhjTk1qUXdNakUxTVRRME16TXpXaGNOTXpRd01qRXlNVFEwTXpNegpXakFqTVNFd0h3WURWUVFEREJock0zTXRjMlZ5ZG1WeUxXTmhRREUzTURnd01EZ3lNVE13V1RBVEJnY3Foa2pPClBRSUJCZ2dxaGtqT1BRTUJCd05DQUFSOXlqRmRnS1NGcjY4eDlIbUM3LzJ3ZkEyVEFoeEZ1NGJZY1dHUEY0REUKN09XYThueVRMemJBeFVHRlVCcG4vQXA0bWRoS25SU1YvZVZSOXF0Zk13eTdvMEl3UURBT0JnTlZIUThCQWY4RQpCQU1DQXFRd0R3WURWUjBUQVFIL0JBVXdBd0VCL3pBZEJnTlZIUTRFRmdRVW5GajRxQktMUGRmd0xyVEpKZ2pyCjdreE84N3N3Q2dZSUtvWkl6ajBFQXdJRFJ3QXdSQUlnRGwvOThQSHE0M3pPenN5Q05jWUEzb085RE0rV25xQmEKZHJKQndON0tPTDBDSUE1ZVh1ZkxNdmhFZXNGS094VVdSZU1hUkdMZCs4Yno1RHRTYjhlMGEzbXQKLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=
      server: https://localhost:11755
    name: vcluster_test_vcluster-test_orbstack
  - cluster:
      certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUJkakNDQVIyZ0F3SUJBZ0lCQURBS0JnZ3Foa2pPUFFRREFqQWpNU0V3SHdZRFZRUUREQmhyTTNNdGMyVnkKZG1WeUxXTmhRREUzTURnd01ESTJNell3SGhjTk1qUXdNakUxTVRNeE1ETTJXaGNOTXpRd01qRXlNVE14TURNMgpXakFqTVNFd0h3WURWUVFEREJock0zTXRjMlZ5ZG1WeUxXTmhRREUzTURnd01ESTJNell3V1RBVEJnY3Foa2pPClBRSUJCZ2dxaGtqT1BRTUJCd05DQUFTcjlNNlNsdHRzajErUTROSk8vTVlKY3RHSkp0a08vbDkxR2R6R3ZER3YKUXgwTVBEVnlYcSt0ajlOUVpwbUV6NWNoQmttQVNTcW40cGQvTW1hUE1NTDRvMEl3UURBT0JnTlZIUThCQWY4RQpCQU1DQXFRd0R3WURWUjBUQVFIL0JBVXdBd0VCL3pBZEJnTlZIUTRFRmdRVTlGQlhuWGdNSWxZbDJaRGtGQTI1CnlPeVBqT3N3Q2dZSUtvWkl6ajBFQXdJRFJ3QXdSQUlmSE9PSlFJbkVFQndaMGZLUlRxOUE0NHBySE5BbXpVc20KcisrZzFjLzM2UUloQU9CbktuRHRPTTY0V05oU25vMnVJV2o1Ty85VjZlWTRJRWt0VUNmZDRjWFkKLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=
      server: https://127.0.0.1:26443
    name: orbstack
contexts:
  - context:
      cluster: vcluster_test_vcluster-test_orbstack
      user: vcluster_test_vcluster-test_orbstack
    name: vcluster_test_vcluster-test_orbstack
  - context:
      cluster: orbstack
      user: orbstack
    name: orbstack
current-context: orbstack
kind: Config
preferences: {}
users:
  - name: vcluster_test_vcluster-test_orbstack
    user:
      client-certificate-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUJrakNDQVRlZ0F3SUJBZ0lJT2FQRzhMc21MNWd3Q2dZSUtvWkl6ajBFQXdJd0l6RWhNQjhHQTFVRUF3d1kKYXpOekxXTnNhV1Z1ZEMxallVQXhOekE0TURBNE1qRXpNQjRYRFRJME1ESXhOVEUwTkRNek0xb1hEVEkxTURJeApOREUwTkRNek0xb3dNREVYTUJVR0ExVUVDaE1PYzNsemRHVnRPbTFoYzNSbGNuTXhGVEFUQmdOVkJBTVRESE41CmMzUmxiVHBoWkcxcGJqQlpNQk1HQnlxR1NNNDlBZ0VHQ0NxR1NNNDlBd0VIQTBJQUJDbysyRzRzQ0pjaTVZTlMKMkp6VTd5ZnEzSUR0dE1tcnU2bGtGV2NMR2FJSVRTVDZPbFdzaDdaYkJRb3FrTkk5c3dTOStCWHptV2FOQ1FzRgp1Q0ZaL0F1alNEQkdNQTRHQTFVZER3RUIvd1FFQXdJRm9EQVRCZ05WSFNVRUREQUtCZ2dyQmdFRkJRY0RBakFmCkJnTlZIU01FR0RBV2dCUyt0MG1hMFR2ZHN5d2RuVGpYd0ExWis0eFZJakFLQmdncWhrak9QUVFEQWdOSkFEQkcKQWlFQThjZXNlcWhjOFpGU0Z3TERzdDJYUS9lU0xiVWFuNnNYenhFeHFtSlNEbXNDSVFEcDdJWmRJd3FaVmY2WQpQMWRaOWwzeE9JTDFRL2Y5VXdNVC9aOFRaZEZJa2c9PQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tQkVHSU4gQ0VSVElGSUNBVEUtLS0tLQpNSUlCZGpDQ0FSMmdBd0lCQWdJQkFEQUtCZ2dxaGtqT1BRUURBakFqTVNFd0h3WURWUVFEREJock0zTXRZMnhwClpXNTBMV05oUURFM01EZ3dNRGd5TVRNd0hoY05NalF3TWpFMU1UUTBNek16V2hjTk16UXdNakV5TVRRME16TXoKV2pBak1TRXdId1lEVlFRRERCaHJNM010WTJ4cFpXNTBMV05oUURFM01EZ3dNRGd5TVRNd1dUQVRCZ2NxaGtqTwpQUUlCQmdncWhrak9QUU1CQndOQ0FBVCtZbTVnL0o4TzIwQ0llSFB4Z2hRWTBXajl3QVZzc0QxdHRzS0VnMFFRCjA3UDNLZEttV3AzS3BvV3FkdkN4dTNFMkp4ZDBGVDh5eG1IOVJiamVXRW90bzBJd1FEQU9CZ05WSFE4QkFmOEUKQkFNQ0FxUXdEd1lEVlIwVEFRSC9CQVV3QXdFQi96QWRCZ05WSFE0RUZnUVV2cmRKbXRFNzNiTXNIWjA0MThBTgpXZnVNVlNJd0NnWUlLb1pJemowRUF3SURSd0F3UkFJZ1VldS9yVnBmc1NoUUZmSjIyb05CMVhwY1djUWFPY2FBCnF4ZGg0dzhGdHBRQ0lIdmVTRE00clN2V3ZGZktROXRWTDRFZkpUdDc2cWliMFMyY2FBdDQwUHNGCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K
      client-key-data: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSVBWS2JlQzJua2JaZ1UxZUNaS2NxUHpnSXd0MWxtOGcxZFNRaENoaHRURWVvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFS2o3WWJpd0lseUxsZzFMWW5OVHZKK3JjZ08yMHlhdTdxV1FWWndzWm9naE5KUG82VmF5SAp0bHNGQ2lxUTBqMnpCTDM0RmZPWlpvMEpDd1c0SVZuOEN3PT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo=
  - name: orbstack
    user:
      client-certificate-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUJrakNDQVRlZ0F3SUJBZ0lJT0VPZVF3Yitlb1V3Q2dZSUtvWkl6ajBFQXdJd0l6RWhNQjhHQTFVRUF3d1kKYXpOekxXTnNhV1Z1ZEMxallVQXhOekE0TURBeU5qTTJNQjRYRFRJME1ESXhOVEV6TVRBek5sb1hEVEkxTURJeApOREV6TVRBek5sb3dNREVYTUJVR0ExVUVDaE1PYzNsemRHVnRPbTFoYzNSbGNuTXhGVEFUQmdOVkJBTVRESE41CmMzUmxiVHBoWkcxcGJqQlpNQk1HQnlxR1NNNDlBZ0VHQ0NxR1NNNDlBd0VIQTBJQUJITitvSWtsMThmdkM0eUkKa25La2pMV0Y2MkVhZHFJbDlyVmszZnFhZmNqSllvdEh5SkJHaXhSOHZ4Vm5pdkJvdFM0L256RDdwcWhNMTZVdwozUm9zbk4yalNEQkdNQTRHQTFVZER3RUIvd1FFQXdJRm9EQVRCZ05WSFNVRUREQUtCZ2dyQmdFRkJRY0RBakFmCkJnTlZIU01FR0RBV2dCU1JvZkh3b2wwV21JT0NuMU1PdTBLOEFDUTVIekFLQmdncWhrak9QUVFEQWdOSkFEQkcKQWlFQW44S1RhK0ZyL3pNd25NUndRS3dKMFFTNkZTYnd5bHQ5N1NLTVdod1ZYcm9DSVFEMW1pWDhvRW5xZk5jRApJUDM1L2FDdkpQQ3lQUEFkTlJJTXhSaE5tRkQzUnc9PQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tQkVHSU4gQ0VSVElGSUNBVEUtLS0tLQpNSUlCZURDQ0FSMmdBd0lCQWdJQkFEQUtCZ2dxaGtqT1BRUURBakFqTVNFd0h3WURWUVFEREJock0zTXRZMnhwClpXNTBMV05oUURFM01EZ3dNREkyTXpZd0hoY05NalF3TWpFMU1UTXhNRE0yV2hjTk16UXdNakV5TVRNeE1ETTIKV2pBak1TRXdId1lEVlFRRERCaHJNM010WTJ4cFpXNTBMV05oUURFM01EZ3dNREkyTXpZd1dUQVRCZ2NxaGtqTwpQUUlCQmdncWhrak9QUU1CQndOQ0FBU1dRVktOWm5kR1k4QmZ5Tnd0NDhiMUVEaldhdDlpWG9JVHJpaDBVSSt2CjVpNnpIdk5LaU1vbVZUVkJMNDJ0TkR6aTdNdzEydE5jRVNzT2FhQ2JGaGRFbzBJd1FEQU9CZ05WSFE4QkFmOEUKQkFNQ0FxUXdEd1lEVlIwVEFRSC9CQVV3QXdFQi96QWRCZ05WSFE0RUZnUVVrYUh4OEtKZEZwaURncDlURHJ0Qwp2QUFrT1I4d0NnWUlLb1pJemowRUF3SURTUUF3UmdJaEFPM2FHOU1CR3JVTXZxWGhVVG5SNEFiYS96NjdTSFNNCmlwcGVOTlYrUlcybUFpRUF3SDNtbDdsMmYxdWs1U0lHMUpvSXdMS1ljaWFibFNFNGlLUmdKREhlWFF3PQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg==
      client-key-data: LS0tLS1CRUdJTiBFQyBQUklWQVRFIEtFWS0tLS0tCk1IY0NBUUVFSU9JNkYrODBXamdRNEhFcFoyVWpoTVlET0xBazBHdkg4SkxueUJCMXdrdzRvQW9HQ0NxR1NNNDkKQXdFSG9VUURRZ0FFYzM2Z2lTWFh4KzhMaklpU2NxU010WVhyWVJwMm9pWDJ0V1RkK3BwOXlNbGlpMGZJa0VhTApGSHkvRldlSzhHaTFMaitmTVB1bXFFelhwVERkR2l5YzNRPT0KLS0tLS1FTkQgRUMgUFJJVkFURSBLRVktLS0tLQo=

# with:
# args: get pods
# - name: Setup Kubernetes
# uses: azure/aks-set-context@v1
# with:
# creds: ${{ secrets.KUBE_CONFIG }}
# kubeconfig: config
# context: your-context-name
# - name: Check Kubernetes config
# run: |
# cat config
# - name: Install kubectl, kustomize and clusterctl
# run: |
# # curl -LO "https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl" && chmod +x kubectl && sudo mv kubectl /usr/local/bin/
# curl -s "https://raw.githubusercontent.com/kubernetes-sigs/kustomize/master/hack/install_kustomize.sh" | bash && sudo mv kustomize /usr/local/bin/
# curl -L https://github.com/kubernetes-sigs/cluster-api/releases/download/v1.6.1/clusterctl-linux-amd64 -o clusterctl && chmod +x clusterctl && sudo mv clusterctl /usr/local/bin/
# - name: Run clusterctl command
# run: |
# clusterctl config repositories | grep vcluster
# - name: Set Kubernetes context
# run: |
# kubectl config set-context test-PR --kubeconfig=$HOME/.kube/config
# - name: Set Podman as current context for kubectl
# run: |
# export KUBECONFIG=/run/user/$(id -u)/podman/podman.sock
# - name: Run podman
# run: |
# sudo podman --storage-driver=overlay version
# - name: Run kubectl
# run: |
# kubectl version --client
- name: Verify Kubernetes context
run: |
kubectl config get-contexts
- name: Check Kubernetes config file
run: |
cat $HOME/.kube/config
# - name: Configure kubectl
# run: |
# kubectl config set-context test-PR
- name: Check Kubernetes connectivity
run: |
echo "=== Kube config ==="
cat $HOME/.kube/config
echo "=== Kubectl version ==="
kubectl version --client
echo "=== Kubectl config ==="
kubectl config view
echo "=== Kubectl current context ==="
kubectl config current-context
echo "=== Kubectl cluster info ==="
kubectl cluster-info
echo "=== Kubectl get nodes ==="
kubectl get nodes
echo "=== Kubectl get pods ==="
kubectl get pods --all-namespaces
echo "=== Kubectl get namespaces ==="
kubectl get namespaces
echo "=== Test kubectl command ==="
kubectl get all --all-namespaces
- name: Run kubectl get namespaces
run: |
kubectl get namespaces
- name: DevSpace Deploy
run: |
devspace deploy -p deploy