Skip to content

build driver with unit test #1188

build driver with unit test

build driver with unit test #1188

Workflow file for this run

name: Dockerized Tests
on:
push:
branches:
- main
pull_request:
branches:
- '*'
paths-ignore:
- '**/*.md'
- '**/*.jpg'
- '**/README.txt'
- '**/LICENSE.txt'
- 'docs/**'
- 'ISSUE_TEMPLATE/**'
- '**/remove-old-artifacts.yml'
env:
BUILD_TYPE: Release
jobs:
build-dockerized-community-tests:
name: Dockerized Community Tests
runs-on: ubuntu-20.04
env:
CMAKE_GENERATOR: Unix Makefiles
steps:
- name: Checkout source code
uses: actions/checkout@v2
- name: Cache AWS SDK libraries
id: cache-dynamic-aws-sdk
uses: actions/cache@v3
with:
path: |
aws_sdk
key: ${{ runner.os }}-aws-sdk-dynamic-lib
- name: Build and install AWS SDK C++
working-directory: ./scripts
if: steps.cache-dynamic-aws-sdk.outputs.cache-hit != 'true'
run: |
./build_aws_sdk_unix.sh $BUILD_TYPE
- name: 'Set up JDK 8'
uses: actions/setup-java@v1
with:
java-version: 8
- name: 'Run Community Tests'
working-directory: ${{ github.workspace }}/testframework
run: |
./gradlew --no-parallel --no-daemon test-community --info
env:
TEST_DSN: awsmysqlodbca
TEST_USERNAME: root
TEST_PASSWORD: root
DRIVER_PATH: ${{ github.workspace }}
build-dockerized-integration-tests:
concurrency: # Cancel previous runs in the same branch
group: environment-${{ github.ref }}
cancel-in-progress: true
name: Dockerized Integration Tests
runs-on: ubuntu-20.04
env:
CMAKE_GENERATOR: Unix Makefiles
steps:
- name: Checkout source code
uses: actions/checkout@v2
- name: Cache AWS SDK libraries
id: cache-dynamic-aws-sdk
uses: actions/cache@v3
with:
path: |
aws_sdk
key: ${{ runner.os }}-aws-sdk-dynamic-lib
- name: Build and install AWS SDK C++
working-directory: ./scripts
if: steps.cache-dynamic-aws-sdk.outputs.cache-hit != 'true'
run: |
./build_aws_sdk_unix.sh $BUILD_TYPE
- name: 'Set up JDK 8'
uses: actions/setup-java@v1
with:
java-version: 8
- name: 'Configure AWS Credentials'
uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: ${{ secrets.AWS_DEFAULT_REGION }}
- name: 'Set up Temp AWS Credentials'
run: |
creds=($(aws sts get-session-token \
--duration-seconds 7200 \
--query 'Credentials.[AccessKeyId, SecretAccessKey, SessionToken]' \
--output text \
| xargs));
echo "::add-mask::${creds[0]}"
echo "::add-mask::${creds[1]}"
echo "::add-mask::${creds[2]}"
echo "TEMP_AWS_ACCESS_KEY_ID=${creds[0]}" >> $GITHUB_ENV
echo "TEMP_AWS_SECRET_ACCESS_KEY=${creds[1]}" >> $GITHUB_ENV
echo "TEMP_AWS_SESSION_TOKEN=${creds[2]}" >> $GITHUB_ENV
- name: 'Run Integration Tests'
working-directory: ${{ github.workspace }}/testframework
run: |
./gradlew --no-parallel --no-daemon test-failover --info
env:
TEST_DSN: awsmysqlodbca
TEST_USERNAME: ${{ secrets.TEST_USERNAME }}
TEST_PASSWORD: ${{ secrets.TEST_PASSWORD }}
TEST_DB_CLUSTER_IDENTIFIER: ${{ secrets.TEST_DB_CLUSTER_IDENTIFIER }}-${{ github.run_id }}-${{ github.run_attempt }}
AWS_ACCESS_KEY_ID: ${{ env.TEMP_AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ env.TEMP_AWS_SECRET_ACCESS_KEY }}
AWS_SESSION_TOKEN: ${{ env.TEMP_AWS_SESSION_TOKEN }}
DRIVER_PATH: ${{ github.workspace }}
- name: 'Get Github Action IP'
id: ip
uses: haythem/public-ip@v1.2
- name: 'Remove Github Action IP'
if: always()
run: |
aws ec2 revoke-security-group-ingress \
--group-name default \
--protocol tcp \
--port 3306 \
--cidr ${{ steps.ip.outputs.ipv4 }}/32 \
2>&1 > /dev/null;
- name: 'Display and save log'
if: always()
working-directory: ${{ github.workspace }}
run: |
echo "Displaying logs"
mkdir -p ./reports/tests
if [[ -f myodbc.log && -s myodbc.log ]]; then
cat myodbc.log
cp myodbc.log ./reports/tests/myodbc.log
fi
if [[ -f failover_performance.xlsx && -s failover_performance.xlsx ]]; then
cp failover_performance.xlsx ./reports/tests/failover_performance.xlsx
fi
if [[ -f efm_performance.xlsx && -s efm_performance.xlsx ]]; then
cp efm_performance.xlsx ./reports/tests/efm_performance.xlsx
fi
if [[ -f efm_detection_performance.xlsx && -s efm_detection_performance.xlsx ]]; then
cp efm_detection_performance.xlsx ./reports/tests/efm_detection_performance.xlsx
fi
- name: 'Archive log results'
if: always()
uses: actions/upload-artifact@v2
with:
name: 'integration-test-logs'
path: reports/tests/
retention-days: 3
- name: 'Delete Test Clusters if Ungraceful Cancel'
if: cancelled()
run: |
db_instances=($(aws rds describe-db-clusters \
--db-cluster-identifier ${{ secrets.TEST_DB_CLUSTER_IDENTIFIER }}-${{ github.run_id }}-${{ github.run_attempt }} \
--query 'DBClusters[].DBClusterMembers[].DBInstanceIdentifier' \
--output text \
| xargs));
for ((i = 0; i < ${#db_instances[@]}; i++)); \
do \
aws rds delete-db-instance \
--db-instance-identifier ${db_instances[i]} \
--skip-final-snapshot \
2>&1 > /dev/null; \
done;
aws rds delete-db-cluster \
--db-cluster-identifier ${{ secrets.TEST_DB_CLUSTER_IDENTIFIER }}-${{ github.run_id }}-${{ github.run_attempt }} \
--skip-final-snapshot \
2>&1 > /dev/null;