Skip to content

AKS Performance Test #1

AKS Performance Test

AKS Performance Test #1

Workflow file for this run

name: AKS Performance Test
on:
workflow_dispatch:
inputs:
analytics_enabled:
description: 'Enabled Analytics gathering'
required: false
default: false
type: boolean
auth_enabled:
description: 'Enabled Authentication'
required: false
default: false
type: boolean
quota_enabled:
description: 'Enabled Quota'
required: false
default: false
type: boolean
rate_limit_enabled:
description: 'Enabled Rate Limiting'
required: false
default: false
type: boolean
open_telemetry_enabled:
description: 'Enabled Open Telemetry'
required: false
default: false
type: boolean
open_telemetry_sampling_ratio:
description: 'Open Telemetry Sampling Ratio'
required: false
type: string
default: '0.5'
tyk_version:
description: 'Tyk Gateway version'
required: true
type: string
default: 'v5.3.0'
tests_timestamp_enabled:
description: 'Enabled Timestamp Test'
required: false
default: true
type: boolean
tests_httpbin_enabled:
description: 'Enabled Httpbin Test'
required: false
default: false
type: boolean
jobs:
performance_test:
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Configure AWS credentials
uses: azure/login@v2
with:
client-id: ${{ secrets.AZURE_CLIENT_ID }}
tenant-id: ${{ secrets.AZURE_TENANT_ID }}
subscription-id: ${{ vars.AZURE_SUBSCRIPTION_ID }}
- name: Install Terraform
uses: hashicorp/setup-terraform@v3
with:
cli_config_credentials_token: ${{ secrets.TF_API_TOKEN }}
- name: Create Terraform Cloud descriptors
run: |
cp ./aks/terraform.cloud.tf.example ./aks/terraform.cloud.tf
cp .github/aks/deployments.tf ./deployments/terraform.cloud.tf
cp .github/aks/tests.tf ./tests/terraform.cloud.tf
- name: Stand up EKS cluster
run: |
cd aks
terraform init
terraform apply \
--var="cluster_location=${{ vars.AZURE_CLUSTER_LOCATION }}" \
--var="cluster_machine_type=${{ vars.AZURE_CLUSTER_MACHINE_TYPE }}" \
--auto-approve
- name: Connect to AKS cluster
run: |
aws aks get-credentials \
--resource-group "pt-${{ vars.AZURE_CLUSTER_MACHINE_TYPE }}" \
--name "pt-${{ vars.AZURE_CLUSTER_MACHINE_TYPE }}"
kubectl config rename-context $(kubectl config current-context) performance-testing-eks
- name: Deploy testing resources
run: |
cd deployments
terraform init
terraform apply \
--var="kubernetes_config_context=performance-testing-aks" \
--var="analytics_enabled=${{ inputs.analytics_enabled }}" \
--var="auth_enabled=${{ inputs.auth_enabled }}" \
--var="quota_enabled=${{ inputs.quota_enabled }}" \
--var="rate_limit_enabled=${{ inputs.rate_limit_enabled }}" \
--var="open_telemetry_enabled=${{ inputs.open_telemetry_enabled }}" \
--var="open_telemetry_sampling_ratio=${{ inputs.open_telemetry_sampling_ratio }}" \
--var="tyk_version=${{ inputs.tyk_version }}" \
--var="grafana_service_type=LoadBalancer" \
--auto-approve
- name: Run Tests
run: |
cd tests
terraform init
terraform apply \
--var="kubernetes_config_context=performance-testing-aks" \
--var="tests_timestamp_enabled=${{ inputs.tests_timestamp_enabled }}" \
--var="tests_httpbin_enabled=${{ inputs.tests_httpbin_enabled }}" \
--auto-approve
- name: Access to Grafana Dashboard
run: |
echo "###################################################################
echo "#
echo "# http://$(kubectl get svc -n dependencies grafana -ojsonpath='{.status.loadBalancer.ingress[0].ip}')"
echo "# Username: Admin"
echo "# Password: topsecretpassword"
echo "#
echo "###################################################################