This repository has been archived by the owner on Oct 1, 2024. It is now read-only.
Update README.md (#304) #223
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: Smoke test | |
on: | |
push: | |
branches: | |
- master | |
env: | |
TIMEOUT: 5m | |
NAMESPACE: tyk-ci | |
TYK_CE: .github/tyk_ce_values.yaml | |
TYK_PRO: .github/tyk_pro_values.yaml | |
TYK_HYBRID: .github/tyk_hybrid_values.yaml | |
jobs: | |
generate-matrix: | |
name: Generate matrix for smoke-tests | |
runs-on: ubuntu-latest | |
outputs: | |
matrix: ${{ steps.set-matrix.outputs.matrix }} | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Check changed files | |
id: diff | |
run: | | |
if [ $GITHUB_BASE_REF ]; then | |
# Pull Request | |
git fetch origin $GITHUB_BASE_REF --depth=1 | |
export DIFF=$( git diff --name-only origin/$GITHUB_BASE_REF $GITHUB_SHA ) | |
echo "Diff between origin/$GITHUB_BASE_REF and $GITHUB_SHA" | |
else | |
# Push | |
git fetch origin ${{ github.event.before }} --depth=1 | |
export DIFF=$( git diff --name-only ${{ github.event.before }} $GITHUB_SHA ) | |
echo "Diff between ${{ github.event.before }} and $GITHUB_SHA" | |
fi | |
echo "$DIFF" | |
# Escape newlines (replace \n with %0A) | |
echo "::set-output name=diff::$( echo "$DIFF" | sed ':a;N;$!ba;s/\n/%0A/g' )" | |
- name: Set matrix for smoke-tests | |
id: set-matrix | |
run: | | |
DIFF="${{ steps.diff.outputs.diff }}" | |
JSON="{\"directory\":[" | |
# Loop by lines | |
while read path; do | |
# Set $directory to substring before / | |
directory="$( echo $path | cut -d'/' -f1 -s )" | |
if [ "$directory" == .github ]; then | |
continue # Exclude .github directory | |
elif [ "$directory" == deploy ]; then | |
continue # Exclude deploy directory | |
elif [ "$directory" == samples ]; then | |
continue # Exclude samples directory | |
elif [ "$directory" == "" ]; then | |
continue # Exclude empty directory | |
fi | |
# Add build to the matrix only if it is not already included | |
JSONline="\"$directory\"," | |
if [[ "$JSON" != *"$JSONline"* ]]; then | |
JSON="$JSON$JSONline" | |
fi | |
done <<< "$DIFF" | |
# Remove last "," and add closing brackets | |
if [[ $JSON == *, ]]; then | |
JSON="${JSON%?}" | |
fi | |
JSON="$JSON]}" | |
ndir=$(echo $JSON | jq '.directory | length') | |
if [[ "$ndir" != 0 ]]; then | |
# Add different kubernetes versions for the smoke-tests | |
MATRIX_JSON=$(echo "$JSON" | jq --raw-output '.k8s += ["v1.26.3","v1.25.2","v1.24.6","v1.23.12","v1.22.15","v1.21.14","v1.20.15"]') | |
else | |
MATRIX_JSON="{}" | |
fi | |
# Set output | |
echo "::debug::matrix is ${MATRIX_JSON}" | |
echo "::set-output name=matrix::$( echo $MATRIX_JSON )" | |
smoke-tests: | |
runs-on: ubuntu-latest | |
name: Run Smoke Tests on "${{ matrix.directory }}" chart | |
needs: generate-matrix | |
strategy: | |
matrix: ${{fromJson(needs.generate-matrix.outputs.matrix)}} | |
if: needs.generate-matrix.outputs.matrix != '{}' | |
steps: | |
- name: Git Checkout | |
uses: actions/checkout@v3 | |
- name: Create Kind Cluster | |
uses: helm/[email protected] | |
with: | |
config: .github/kind-cluster.yml | |
node-image: "kindest/node:${{ matrix.k8s }}" | |
- name: Install helm | |
uses: Azure/setup-helm@v3 | |
with: | |
version: v3.12.1 | |
- name: Deploy "${{ matrix.directory }}" requisites | |
run: | | |
kubectl create namespace ${{ env.NAMESPACE }} | |
helm repo add tyk-helm https://helm.tyk.io/public/helm/charts/ | |
helm repo add bitnami https://charts.bitnami.com/bitnami | |
helm repo update | |
helm install mongo tyk-helm/simple-mongodb -n ${{ env.NAMESPACE }} --wait | |
helm install redis tyk-helm/simple-redis -n ${{ env.NAMESPACE }} --wait | |
helm install tyk-postgres bitnami/postgresql --set "auth.database=tyk_enterprise_portal" -n ${{ env.NAMESPACE }} | |
- name: Deploy "${{ matrix.directory }}" chart | |
run: | | |
if [ "${{ matrix.directory }}" == tyk-headless ]; then | |
helm install ${{ matrix.directory }} ./${{ matrix.directory }} -n ${{ env.NAMESPACE }} --timeout ${{ env.TIMEOUT }} | |
elif [ "${{ matrix.directory }}" == tyk-hybrid ]; then | |
helm install --set gateway.rpc.rpcKey=${{ secrets.HYBRID_RPC_KEY }} --set gateway.rpc.apiKey=${{ secrets.HYBRID_API_KEY }} --set gateway.rpc.connString=${{ secrets.HYBRID_MDCB_HOST }} ${{ matrix.directory }} ./${{ matrix.directory }} -n ${{ env.NAMESPACE }} --timeout ${{ env.TIMEOUT }} --debug | |
elif [ "${{ matrix.directory }}" == tyk-pro ]; then | |
helm install --set mdcb.license="${{ secrets.MDCB_LICENSE }}" --set dash.license="${{ secrets.DASH_LICENSE }}" ${{ matrix.directory }} ./${{ matrix.directory }} -n ${{ env.NAMESPACE }} --timeout ${{ env.TIMEOUT }} --wait --debug | |
fi | |
- name: Upgrade "${{ matrix.directory }}" chart | |
run: | | |
if [ "${{ matrix.directory }}" == tyk-headless ]; then | |
helm upgrade -f ${{ env.TYK_CE }} ${{ matrix.directory }} ./${{ matrix.directory }} -n ${{ env.NAMESPACE }} --timeout ${{ env.TIMEOUT }} | |
elif [ "${{ matrix.directory }}" == tyk-hybrid ]; then | |
helm upgrade -f ${{ env.TYK_HYBRID }} --set gateway.rpc.rpcKey=${{ secrets.HYBRID_RPC_KEY }} --set gateway.rpc.apiKey=${{ secrets.HYBRID_API_KEY }} --set gateway.rpc.connString=${{ secrets.HYBRID_MDCB_HOST }} ${{ matrix.directory }} ./${{ matrix.directory }} -n ${{ env.NAMESPACE }} --timeout ${{ env.TIMEOUT }} | |
elif [ "${{ matrix.directory }}" == tyk-pro ]; then | |
helm upgrade -f ${{ env.TYK_PRO }} \ | |
--set mdcb.license="${{ secrets.MDCB_LICENSE }}" \ | |
--set dash.license="${{ secrets.DASH_LICENSE }}" \ | |
--set enterprisePortal.enabled="true" \ | |
--set enterprisePortal.license="${{ secrets.PORTAL_LICENSE }}" \ | |
--set enterprisePortal.storage.database.connectionString="host=tyk-postgres-postgresql.${{ env.NAMESPACE }}.svc.cluster.local port=5432 user=postgres password=$(kubectl get secret -n ${{ env.NAMESPACE }} tyk-postgres-postgresql -o jsonpath="{.data.postgres-password}" | base64 -d) database=tyk_enterprise_portal sslmode=disable" \ | |
${{ matrix.directory }} ./${{ matrix.directory }} -n ${{ env.NAMESPACE }} --timeout ${{ env.TIMEOUT }} | |
fi | |
- name: Uninstall "${{ matrix.directory }}" chart | |
run: | | |
helm uninstall ${{ matrix.directory }} -n ${{ env.NAMESPACE }} --timeout ${{ env.TIMEOUT }} |