Skip to content

add kind self-host

add kind self-host #1

Workflow file for this run

name: main
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
on: [push, pull_request]
jobs:
kind:
runs-on: ubuntu-latest
timeout-minutes: 10
steps:
- name: "Checkout repository"
uses: actions/checkout@v4
with:
path: ${{ github.workspace }}/src/github.com/${{ github.repository }}
- name: "Install kind"
run: |
[ $(uname -m) = x86_64 ] && curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.26.0/kind-linux-amd64
# For ARM64
[ $(uname -m) = aarch64 ] && curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.26.0/kind-linux-arm64
chmod +x ./kind
sudo mv ./kind /usr/local/bin/kind
- name: "Setup k8s cluster"
run: |
cat <<EOF | kind create cluster --wait=3m --config=-
kind: Cluster
apiVersion: kind.x-k8s.io/v1alpha4
nodes:
- role: control-plane
extraPortMappings:
- containerPort: 80
hostPort: 80
protocol: TCP
- containerPort: 443
hostPort: 443
protocol: TCP
EOF
- name: "Print cluster details"
run: |
kubectl cluster-info
kubectl version
kubectl get pods -n kube-system
echo "current-context:" $(kubectl config current-context)
echo "environment-kubeconfig:" ${KUBECONFIG}
- name: "Install nginx ingress controller"
run: |
kubectl apply -f https://kind.sigs.k8s.io/examples/ingress/deploy-ingress-nginx.yaml
kubectl wait --namespace ingress-nginx \
--for=condition=ready pod \
--selector=app.kubernetes.io/component=controller \
--timeout=90s
- name: "Huly deploy"
working-directory: ${{ github.workspace }}/src/github.com/${{ github.repository }}
run: |
kubectl apply -R -f .
kubectl wait --for=condition=Ready deployment/front --timeout 120s
kubectl wait --for=condition=Ready deployment/account --timeout 120s
kubectl wait --for=condition=Ready deployment/mongodb --timeout 120s
- name: "Check login"
run: |
token=$(curl -s -H 'Content-Type: application/json' \
-d '{"method":"createAccount","params":["user3","1234","user","1"]}' \
-X POST \
http://account.huly.example/ | jq -r '.result.token')
curl http://account.huly.example/ \
-X POST \
-d '{"method":"getUserWorkspaces","params":[]}' \
-H 'Content-Type: application/json' \
-H 'Accept: */*' \
-H "Authorization: Bearer $token"
- name: Cleanup resources
if: ${{ success() || failure() || cancelled() }}
run: kind delete clusters