Skip to content

[Integration tests] Add docker step for test containers #899

[Integration tests] Add docker step for test containers

[Integration tests] Add docker step for test containers #899

Workflow file for this run

# This workflow will build a .NET project
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-net
name: build
on:
push:
branches: ["master", "release/*", "feature/*"]
pull_request_target:
branches: ["master", "devops/*"]
workflow_dispatch:
branches: ["master", "release/*", "feature/*"]
permissions:
contents: read
env:
SOLUTION_NAME: SlimMessageBus.sln
SOLUTION_CONFIGURATION: Release
jobs:
build:
runs-on: ubuntu-latest
concurrency: int-tests
steps:
# - name: Dump GitHub context
# env:
# GITHUB_CONTEXT: ${{ toJson(github) }}
# run: echo "$GITHUB_CONTEXT"
- name: PR - Checkout
if: github.event_name == 'pull_request_target'
uses: actions/checkout@v3
with:
fetch-depth: 0
ref: ${{ github.event.pull_request.head.sha }}
# - name: PR - Create Branch
# if: github.event_name == 'pull_request_target'
# env:
# GITHUB_REF: ${{ secrets.GITHUB_REF }}
# run: |
# git branch new-branch
# git push origin new-branch -f
# echo GITHUB_REF: ${GITHUB_REF}
- name: Checkout
if: github.event_name != 'pull_request_target'
uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Setup .NET
uses: actions/setup-dotnet@v3
with:
dotnet-version: 8.0.x
- name: Restore dependencies
run: dotnet restore $SOLUTION_NAME
working-directory: ./src
- name: Install Coverlet
run: find . -name "*.Test.csproj" | xargs -t -I {} dotnet add {} package coverlet.collector
working-directory: ./src
- name: SonarCloud - Setup Java17
#if: github.event_name == 'pull_request_target'
uses: actions/setup-java@v3
with:
distribution: "zulu"
java-version: "17"
- name: SonarCloud - Install SonarCloud scanner
#if: github.event_name == 'pull_request_target'
run: dotnet tool update dotnet-sonarscanner --tool-path ./.sonar/scanner
- name: SonarCloud - SonarScanner Begin
#if: github.event_name == 'pull_request_target'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # Needed to get PR information, if any
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
run: |
params=""
pr_number="${{ github.event.pull_request.number }}"
if [[ -n "$pr_number" ]]; then
params="/d:sonar.pullrequest.key=${pr_number}"
fi
../.sonar/scanner/dotnet-sonarscanner begin /k:"zarusz_SlimMessageBus" /o:"zarusz" /d:sonar.token="${{ secrets.SONAR_TOKEN }}" /d:sonar.host.url="https://sonarcloud.io" /d:sonar.cs.opencover.reportsPaths="**/coverage.opencover.xml" /d:sonar.exclusions="Samples/**/*,Tests/**/*" $params
working-directory: ./src
- name: Build
run: dotnet build $SOLUTION_NAME --configuration $SOLUTION_CONFIGURATION --no-restore
working-directory: ./src
- name: Unit Tests
run: dotnet test $SOLUTION_NAME --configuration $SOLUTION_CONFIGURATION --no-build --verbosity normal --logger html --results-directory TestResults --collect:"XPlat Code Coverage;Format=opencover" --filter Category!=Integration
working-directory: ./src
- name: Integration Tests - Infrastructure
run: docker compose -f src/Infrastructure/docker-compose.yml up --detach --force-recreate -V
- name: Integration Tests
# Run integration tests against the test infrastructure if secrets are provided
run: dotnet test $SOLUTION_NAME --configuration $SOLUTION_CONFIGURATION --no-build --verbosity normal --logger html --results-directory TestResults --collect:"XPlat Code Coverage;Format=opencover" --filter Category=Integration
#run: dotnet test $SOLUTION_NAME --configuration $SOLUTION_CONFIGURATION --no-build --verbosity normal --logger html --results-directory TestResults --collect:"XPlat Code Coverage;Format=opencover" --filter "Category=Integration&Transport=Outbox"
working-directory: ./src
env:
# Connects to the Azure cloud
azure_servicebus_connectionstring: ${{ secrets.azure_servicebus_connectionstring }}
azure_eventhub_connectionstring: ${{ secrets.azure_eventhub_connectionstring }}
azure_storagecontainer_connectionstring: ${{ secrets.azure_storagecontainer_connectionstring }}
kafka_brokers: ${{ secrets.kafka_brokers }}
kafka_username: ${{ secrets.kafka_username }}
kafka_password: ${{ secrets.kafka_password }}
kafka_secure: ${{ secrets.kafka_secure }}
_mqtt_server: ${{ secrets.mqtt_server }}
_mqtt_port: ${{ secrets.mqtt_port }}
_mqtt_username: ${{ secrets.mqtt_username }}
_mqtt_password: ${{ secrets.mqtt_password }}
_mqtt_secure: ${{ secrets.mqtt_secure }}
_rabbitmq_connectionstring: ${{ secrets.rabbitmq_connectionstring }}
_redis_connectionstring: ${{ secrets.redis_connectionstring }}
_sqlserver_connectionstring: ${{ secrets.sqlserver_connectionstring }}
# Connects to the local Test Containers
# need to postpone until feature https://github.com/zarusz/SlimMessageBus/issues/110 is implemented
_kafka_brokers: localhost:9092
_kafka_username: user
_kafka_password: password
_kafka_secure: false
mqtt_server: localhost
mqtt_port: 1883
mqtt_username: "(empty)"
mqtt_password: "(empty)"
mqtt_secure: false
rabbitmq_connectionstring: amqp://localhost
redis_connectionstring: localhost:6379
sqlserver_connectionstring: "Server=localhost;Initial Catalog=SlimMessageBus_Outbox;User ID=sa;Password=SuperSecretP@55word;TrustServerCertificate=true;MultipleActiveResultSets=true;"
- name: SonarCloud - SonarScanner End
#if: github.event_name == 'pull_request_target'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # Needed to get PR information, if any
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
run: ../.sonar/scanner/dotnet-sonarscanner end /d:sonar.token="${{ secrets.SONAR_TOKEN }}"
working-directory: ./src
- name: Upload test results
uses: actions/upload-artifact@v3
with:
name: dotnet-results
path: ./src/TestResults
# Use always() to always run this step to publish test results when there are test failures
if: ${{ always() }}
- name: Copy NuGet packages
shell: bash
run: |
mkdir ./dist
find -name "*.nupkg" -exec cp {} ./dist \;
find -name "*.snupkg" -exec cp {} ./dist \;
find ./dist
- name: Archive NuGet packages
uses: actions/upload-artifact@v3
with:
name: nuget-packages
path: "./dist"