Initial implementation for DP to CP #1868
Workflow file for this run
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: start and run cucumber and go integration tests | |
on: | |
workflow_dispatch: | |
pull_request_target: | |
types: [opened, synchronize, reopened] | |
concurrency: | |
group: integration-test-${{ github.event.number || github.run_id }} | |
env: | |
GH_TOKEN: ${{ secrets.WSO2_BOT_TOKEN }} | |
jobs: | |
build_adapter: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' | |
uses: ./.github/workflows/adapter-release.yml | |
with: | |
aks_deployment: true | |
secrets: | |
WSO2_BOT_TOKEN: ${{ secrets.WSO2_BOT_TOKEN }} | |
WSO2_BOT_USER: ${{ secrets.WSO2_BOT_USER }} | |
WSO2_BOT_EMAIL: ${{ secrets.WSO2_BOT_EMAIL }} | |
DOCKER_ORGANIZATION: ${{ secrets.AZURE_ACR_NAME }}.azurecr.io | |
AZURE_ACR_NAME: ${{ secrets.AZURE_ACR_NAME }} | |
AZURE_CREDENTIALS: ${{ secrets.AZURE_CREDENTIALS }} | |
build_common_controller: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' | |
uses: ./.github/workflows/common-controller-release.yml | |
with: | |
aks_deployment: true | |
secrets: | |
WSO2_BOT_TOKEN: ${{ secrets.WSO2_BOT_TOKEN }} | |
WSO2_BOT_USER: ${{ secrets.WSO2_BOT_USER }} | |
WSO2_BOT_EMAIL: ${{ secrets.WSO2_BOT_EMAIL }} | |
DOCKER_ORGANIZATION: ${{ secrets.AZURE_ACR_NAME }}.azurecr.io | |
AZURE_ACR_NAME: ${{ secrets.AZURE_ACR_NAME }} | |
AZURE_CREDENTIALS: ${{ secrets.AZURE_CREDENTIALS }} | |
build_enforcer: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' | |
uses: ./.github/workflows/enforcer-release.yml | |
with: | |
aks_deployment: true | |
secrets: | |
WSO2_BOT_TOKEN: ${{ secrets.WSO2_BOT_TOKEN }} | |
WSO2_BOT_USER: ${{ secrets.WSO2_BOT_USER }} | |
WSO2_BOT_EMAIL: ${{ secrets.WSO2_BOT_EMAIL }} | |
DOCKER_ORGANIZATION: ${{ secrets.AZURE_ACR_NAME }}.azurecr.io | |
AZURE_ACR_NAME: ${{ secrets.AZURE_ACR_NAME }} | |
AZURE_CREDENTIALS: ${{ secrets.AZURE_CREDENTIALS }} | |
build_router: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' | |
uses: ./.github/workflows/router-release.yml | |
with: | |
aks_deployment: true | |
secrets: | |
WSO2_BOT_TOKEN: ${{ secrets.WSO2_BOT_TOKEN }} | |
WSO2_BOT_USER: ${{ secrets.WSO2_BOT_USER }} | |
WSO2_BOT_EMAIL: ${{ secrets.WSO2_BOT_EMAIL }} | |
DOCKER_ORGANIZATION: ${{ secrets.AZURE_ACR_NAME }}.azurecr.io | |
AZURE_ACR_NAME: ${{ secrets.AZURE_ACR_NAME }} | |
AZURE_CREDENTIALS: ${{ secrets.AZURE_CREDENTIALS }} | |
build_ratelimiter: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' | |
uses: ./.github/workflows/ratelimiter-release.yml | |
with: | |
aks_deployment: true | |
secrets: | |
WSO2_BOT_TOKEN: ${{ secrets.WSO2_BOT_TOKEN }} | |
WSO2_BOT_USER: ${{ secrets.WSO2_BOT_USER }} | |
WSO2_BOT_EMAIL: ${{ secrets.WSO2_BOT_EMAIL }} | |
DOCKER_ORGANIZATION: ${{ secrets.AZURE_ACR_NAME }}.azurecr.io | |
AZURE_ACR_NAME: ${{ secrets.AZURE_ACR_NAME }} | |
AZURE_CREDENTIALS: ${{ secrets.AZURE_CREDENTIALS }} | |
build_config: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' | |
uses: ./.github/workflows/config-deployer-release.yml | |
with: | |
aks_deployment: true | |
secrets: | |
WSO2_BOT_TOKEN: ${{ secrets.WSO2_BOT_TOKEN }} | |
WSO2_BOT_USER: ${{ secrets.WSO2_BOT_USER }} | |
WSO2_BOT_EMAIL: ${{ secrets.WSO2_BOT_EMAIL }} | |
DOCKER_ORGANIZATION: ${{ secrets.AZURE_ACR_NAME }}.azurecr.io | |
AZURE_ACR_NAME: ${{ secrets.AZURE_ACR_NAME }} | |
AZURE_CREDENTIALS: ${{ secrets.AZURE_CREDENTIALS }} | |
build_idpds: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' | |
uses: ./.github/workflows/idp-domain-service-release.yml | |
with: | |
aks_deployment: true | |
secrets: | |
WSO2_BOT_TOKEN: ${{ secrets.WSO2_BOT_TOKEN }} | |
WSO2_BOT_USER: ${{ secrets.WSO2_BOT_USER }} | |
WSO2_BOT_EMAIL: ${{ secrets.WSO2_BOT_EMAIL }} | |
DOCKER_ORGANIZATION: ${{ secrets.AZURE_ACR_NAME }}.azurecr.io | |
AZURE_ACR_NAME: ${{ secrets.AZURE_ACR_NAME }} | |
AZURE_CREDENTIALS: ${{ secrets.AZURE_CREDENTIALS }} | |
build_idpui: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' | |
uses: ./.github/workflows/idp-ui-release.yml | |
with: | |
aks_deployment: true | |
secrets: | |
WSO2_BOT_TOKEN: ${{ secrets.WSO2_BOT_TOKEN }} | |
WSO2_BOT_USER: ${{ secrets.WSO2_BOT_USER }} | |
WSO2_BOT_EMAIL: ${{ secrets.WSO2_BOT_EMAIL }} | |
DOCKER_ORGANIZATION: ${{ secrets.AZURE_ACR_NAME }}.azurecr.io | |
AZURE_ACR_NAME: ${{ secrets.AZURE_ACR_NAME }} | |
AZURE_CREDENTIALS: ${{ secrets.AZURE_CREDENTIALS }} | |
runs_go_integration_tests_on_pull_request_target: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.action == 'reopened' | |
needs: [build_adapter, build_common_controller, build_enforcer, build_router, build_config,build_idpds,build_idpui,build_ratelimiter] | |
runs-on: ubuntu-latest | |
steps: | |
- uses: azure/login@v1 | |
with: | |
creds: ${{ secrets.AZURE_CREDENTIALS }} | |
- name: Create AKS Cluster and set context | |
uses: azure/CLI@v1 | |
with: | |
azcliversion: 2.44.1 | |
inlineScript: | | |
az aks create --resource-group "${{ secrets.AZURE_RESOURCE_GROUP }}" --name "go-integ-${{ secrets.AKS_CLUSTER_NAME }}-${{ github.event.number || github.run_id }}" --enable-cluster-autoscaler --min-count 1 --max-count 3 --location "southeastasia" --generate-ssh-keys --verbose | |
- uses: azure/aks-set-context@v3 | |
with: | |
resource-group: '${{ secrets.AZURE_RESOURCE_GROUP }}' | |
cluster-name: 'go-integ-${{ secrets.AKS_CLUSTER_NAME }}-${{ github.event.number || github.run_id }}' | |
- name: Create Namespace apk-integration-test | |
shell: sh | |
run: | | |
kubectl create namespace apk-integration-test | |
kubectl get ns | |
- name: Create Image pull secret. | |
shell: sh | |
run: | | |
kubectl create secret docker-registry azure-registry --docker-server=${{ secrets.AZURE_ACR_NAME }}.azurecr.io --docker-username=${{ secrets.AZURE_ACR_USER }} --docker-password=${{ secrets.AZURE_ACR_PASSWORD }} --docker-email=${{ secrets.WSO2_BOT_EMAIL }} -n apk-integration-test | |
- name: Checkout apk-repo. | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: "0" | |
path: apk-repo | |
token: ${{ secrets.WSO2_BOT_TOKEN }} | |
- name: Set release username and email | |
shell: sh | |
run: | | |
git config --global user.name ${{ secrets.WSO2_BOT_USER }} | |
git config --global user.email ${{ secrets.WSO2_BOT_EMAIL }} | |
- name: checkout pull request and merge. | |
shell: sh | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.action == 'reopened' | |
run: | | |
cd apk-repo | |
gh pr checkout ${{ github.event.number }} -b pr-${{ github.event.number }} | |
git checkout pr-${{ github.event.number }} | |
git merge origin/main | |
- name: Helm release deploy | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.action == 'reopened' | |
shell: sh | |
run: | | |
cd apk-repo/helm-charts | |
helm repo add bitnami https://charts.bitnami.com/bitnami | |
helm repo add jetstack https://charts.jetstack.io | |
helm dependency build | |
helm install apk-test-setup -n apk-integration-test . --debug --wait --timeout 10m0s \ | |
--set wso2.subscription.imagePullSecrets=azure-registry \ | |
--set wso2.apk.dp.configdeployer.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-config-deployer-service:${{ github.sha }} \ | |
--set wso2.apk.dp.adapter.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-adapter:${{ github.sha }} \ | |
--set wso2.apk.dp.commonController.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-common-controller:${{ github.sha }} \ | |
--set wso2.apk.dp.gatewayRuntime.deployment.enforcer.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-enforcer:${{ github.sha }} \ | |
--set wso2.apk.dp.gatewayRuntime.deployment.router.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-router:${{ github.sha }} \ | |
--set idp.idpds.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-idp-domain-service:${{ github.sha }} \ | |
--set idp.idpui.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-idp-ui:${{ github.sha }} \ | |
--set wso2.apk.dp.ratelimiter.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-ratelimiter:${{ github.sha }} | |
kubectl get pods -n apk-integration-test | |
kubectl get svc -n apk-integration-test | |
- name: Run test cases | |
shell: sh | |
run: | | |
cd apk-repo/test/integration | |
sh ./scripts/setup-hosts.sh | |
go test -v integration_test.go | |
- name: Helm release undeploy | |
if: always() | |
shell: sh | |
run: | | |
cd apk-repo/helm-charts | |
kubectl get pods -n apk-integration-test | |
kubectl get svc -n apk-integration-test | |
helm uninstall apk-test-setup -n apk-integration-test | |
- name: Delete AKS cluster | |
if: always() | |
uses: azure/CLI@v1 | |
with: | |
azcliversion: 2.44.1 | |
inlineScript: | | |
az aks delete --resource-group ${{ secrets.AZURE_RESOURCE_GROUP }} --name go-integ-${{ secrets.AKS_CLUSTER_NAME }}-${{ github.event.number || github.run_id }} --yes | |
- name: Logout from azure | |
if: always() | |
uses: azure/CLI@v1 | |
with: | |
azcliversion: 2.44.1 | |
inlineScript: | | |
az logout | |
- name: Publish Test Report | |
if: always() | |
uses: malinthaprasan/action-surefire-report@v1 | |
with: | |
report_paths: 'apk-repo/test/postman-tests/build/*.xml' | |
fail_on_test_failures: true | |
runs_cucumber_integration_tests_on_pull_request_target: | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.action == 'reopened' | |
needs: [build_adapter, build_common_controller, build_enforcer, build_router, build_config,build_idpds,build_idpui,build_ratelimiter] | |
runs-on: ubuntu-latest | |
steps: | |
- uses: azure/login@v1 | |
with: | |
creds: ${{ secrets.AZURE_CREDENTIALS }} | |
- name: Create AKS Cluster and set context | |
uses: azure/CLI@v1 | |
with: | |
azcliversion: 2.44.1 | |
inlineScript: | | |
az aks create --resource-group "${{ secrets.AZURE_RESOURCE_GROUP }}" --name "integ-${{ secrets.AKS_CLUSTER_NAME }}-${{ github.event.number || github.run_id }}" --enable-cluster-autoscaler --min-count 1 --max-count 3 --location "southeastasia" --generate-ssh-keys --verbose | |
- uses: azure/aks-set-context@v3 | |
with: | |
resource-group: '${{ secrets.AZURE_RESOURCE_GROUP }}' | |
cluster-name: 'integ-${{ secrets.AKS_CLUSTER_NAME }}-${{ github.event.number || github.run_id }}' | |
- name: Create Namespace apk-integration-test | |
shell: sh | |
run: | | |
kubectl create namespace apk-integration-test | |
kubectl get ns | |
- name: Create Image pull secret. | |
shell: sh | |
run: | | |
kubectl create secret docker-registry azure-registry --docker-server=${{ secrets.AZURE_ACR_NAME }}.azurecr.io --docker-username=${{ secrets.AZURE_ACR_USER }} --docker-password=${{ secrets.AZURE_ACR_PASSWORD }} --docker-email=${{ secrets.WSO2_BOT_EMAIL }} -n apk-integration-test | |
- name: Checkout apk-repo. | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: "0" | |
path: apk-repo | |
token: ${{ secrets.WSO2_BOT_TOKEN }} | |
- name: Set release username and email | |
shell: sh | |
run: | | |
git config --global user.name ${{ secrets.WSO2_BOT_USER }} | |
git config --global user.email ${{ secrets.WSO2_BOT_EMAIL }} | |
- name: checkout pull request and merge. | |
shell: sh | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.action == 'reopened' | |
run: | | |
cd apk-repo | |
gh pr checkout ${{ github.event.number }} -b pr-${{ github.event.number }} | |
git checkout pr-${{ github.event.number }} | |
git merge origin/main | |
- name: Helm release deploy | |
if: github.event_name == 'pull_request_target' && github.event.action == 'opened' || github.event.action == 'synchronize' || github.event.action == 'reopened' | |
shell: sh | |
run: | | |
cd apk-repo/helm-charts | |
helm repo add bitnami https://charts.bitnami.com/bitnami | |
helm repo add jetstack https://charts.jetstack.io | |
helm dependency build | |
helm install apk-test-setup -n apk-integration-test . --debug --wait --timeout 15m0s \ | |
--set wso2.subscription.imagePullSecrets=azure-registry \ | |
--set wso2.apk.dp.configdeployer.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-config-deployer-service:${{ github.sha }} \ | |
--set wso2.apk.dp.adapter.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-adapter:${{ github.sha }} \ | |
--set wso2.apk.dp.commonController.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-common-controller:${{ github.sha }} \ | |
--set wso2.apk.dp.gatewayRuntime.deployment.enforcer.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-enforcer:${{ github.sha }} \ | |
--set wso2.apk.dp.gatewayRuntime.deployment.router.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-router:${{ github.sha }} \ | |
--set idp.idpds.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-idp-domain-service:${{ github.sha }} \ | |
--set idp.idpui.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-idp-ui:${{ github.sha }} \ | |
--set wso2.apk.dp.ratelimiter.deployment.image=${{ secrets.AZURE_ACR_NAME }}.azurecr.io/apk-ratelimiter:${{ github.sha }} | |
kubectl get pods -n apk-integration-test | |
kubectl get svc -n apk-integration-test | |
- name: Run test cases | |
shell: sh | |
run: | | |
cd apk-repo/test/cucumber-tests | |
sh ./scripts/setup-hosts.sh | |
./gradlew runTests | |
- name: Helm release undeploy | |
if: always() | |
shell: sh | |
run: | | |
cd apk-repo/helm-charts | |
kubectl get pods -n apk-integration-test | |
kubectl get svc -n apk-integration-test | |
helm uninstall apk-test-setup -n apk-integration-test | |
- name: Delete AKS cluster | |
if: always() | |
uses: azure/CLI@v1 | |
with: | |
azcliversion: 2.44.1 | |
inlineScript: | | |
az aks delete --resource-group ${{ secrets.AZURE_RESOURCE_GROUP }} --name integ-${{ secrets.AKS_CLUSTER_NAME }}-${{ github.event.number || github.run_id }} --yes | |
- name: Logout from azure | |
if: always() | |
uses: azure/CLI@v1 | |
with: | |
azcliversion: 2.44.1 | |
inlineScript: | | |
az logout | |
- name: Publish Test Report | |
if: always() | |
uses: malinthaprasan/action-surefire-report@v1 | |
with: | |
report_paths: 'apk-repo/test/cucumber-tests/build/test-output/junitreports/*.xml' | |
fail_on_test_failures: true |