Skip to content

Install mssql-tools18 in GitHub action and use -C to trust server cer… #261

Install mssql-tools18 in GitHub action and use -C to trust server cer…

Install mssql-tools18 in GitHub action and use -C to trust server cer… #261

Workflow file for this run

name: Flowable SQL Server Build
on:
push:
branches:
- main
- 'flowable-release-*'
env:
MAVEN_ARGS: >-
-Dmaven.javadoc.skip=true
-B -V --no-transfer-progress
-Dhttp.keepAlive=false -Dmaven.wagon.http.pool=false -Dmaven.wagon.httpconnectionManager.ttlSeconds=120
jobs:
test_mssql:
name: SQL Server ${{ matrix.mssql }}
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
mssql: [2019-latest, 2022-latest]
services:
mssql:
image: mcr.microsoft.com/mssql/server:${{ matrix.mssql }}
env:
SA_PASSWORD: flowableStr0ngPassword
ACCEPT_EULA: Y
ports:
- 1433/tcp
# needed because the mssql container does not provide a health check
options: >-
--health-cmd="/opt/mssql-tools18/bin/sqlcmd -C -S localhost -U sa -P flowableStr0ngPassword -l 30 -Q \"SELECT 1\" || exit 1"
--health-start-period 10s
--health-interval 10s
--health-timeout 5s
--health-retries 10
steps:
- uses: actions/checkout@v4
- name: Prepare Database
run: ./.github/actions/scripts/prepare-mssql.sh
env:
# use localhost for the host here because we have specified a vm for the job.
# If we were running the job on a container this would be mssql
MSSQL_HOST: localhost
MSSQL_PORT: ${{ job.services.mssql.ports[1433] }} # get randomly assigned published port
- uses: actions/setup-java@v3
with:
distribution: 'zulu'
java-version: 17
- name: Test
id: test
# use localhost for the host here because we have specified a vm for the job.
# If we were running the job on a container this would be mssql
# '>-' is a special YAML syntax and means that new lines would be replaced with spaces
# and new lines from the end would be removed
run: >-
./mvnw clean install
${MAVEN_ARGS}
-PcleanDb,mssql,distro
-P'!include-spring-boot-samples'
-Djdbc.url="jdbc:sqlserver://localhost:${{ job.services.mssql.ports[1433] }};database=flowable;encrypt=false"
-Djdbc.username=flowable
-Djdbc.password=flowable
-Djdbc.driver=com.microsoft.sqlserver.jdbc.SQLServerDriver
-Dspring.datasource.url="jdbc:sqlserver://localhost:${{ job.services.mssql.ports[1433] }};database=flowable;encrypt=false"
-Dspring.datasource.username=flowable
-Dspring.datasource.password=flowable
-Dmaven.test.redirectTestOutputToFile=false
- name: Upload test artifacts
uses: actions/upload-artifact@v4
if: ${{ failure() && steps.test.conclusion == 'failure' }}
with:
name: surefire-test-reports-${{ matrix.mssql }}
path: '**/target/surefire-reports/*'