This repository sets up an automated CI/CD pipeline for a Go-based web application using GitHub Actions. It integrates Docker for containerization and GitOps deployment using Helm and ArgoCD on Kubernetes.
| Component | Purpose | 
|---|---|
| Go (Golang) | Web application backend | 
| GitHub Actions | CI/CD workflow automation | 
| Docker | Containerization | 
| Helm | Kubernetes package manager | 
| Kubernetes | Container orchestration platform | 
| ArgoCD | GitOps-based continuous delivery | 
| GitHub | Source and Helm chart repository | 
| Docker Hub | Container image registry | 
Located at .github/workflows/ci-cd.yml, this workflow automates the build, test, image creation, and deployment stages for the Go app.
- 
Build & Test - Sets up Go (1.22)
- Builds the app binary
- Runs unit tests
 
- 
Code Quality (Linting) - Uses golangci-lintto analyze the code for best practices and issues
 
- Uses 
- 
Docker Image - Builds and pushes a Docker image to Docker Hub
- Tags image with GitHub workflow run ID
 
- 
Helm Chart Update - Updates the image.taginhelm/go-web-app-chart/values.yaml
- Commits and pushes the change to Git
 
- Updates the 
- 
GitOps Deployment - ArgoCD detects the Helm chart update and syncs the Kubernetes cluster accordingly
 
Add the following secrets under GitHub → Settings → Secrets and variables → Actions:
| Name | Description | 
|---|---|
| DOCKER_USERNAME | Your Docker Hub username | 
| DOCKER_PASSWORD | Your Docker Hub password or access token | 
| TOKEN | GitHub Personal Access Token (with reposcope) for pushing chart updates | 
kubectl create namespace argocd
kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/stable/manifests/install.yaml
# Expose ArgoCD UI via LoadBalancer
kubectl patch svc argocd-server -n argocd -p '{"spec": {"type": "LoadBalancer"}}'If you're using AKS (Azure Kubernetes Service), you can install NGINX with:
kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-v1.13.0/deploy/static/provider/cloud/deploy.yamlFor other platforms like GKE, EKS, Minikube etc., refer to the official documentation:
https://kubernetes.github.io/ingress-nginx/deploy/
Map the domain from your Ingress config to the controller IP in /etc/hosts:
<INGRESS_IP>   go-web-app.localThis repo automates the CI/CD of a Go web app using GitHub Actions, Docker, and GitOps deployment via Helm and ArgoCD to Kubernetes.