Skip to content

Add automated release workflows #24

Add automated release workflows

Add automated release workflows #24

Workflow file for this run

name: Lint & Test
on: ['pull_request']
permissions:
contents: read
jobs:
commitlint:
name: Lint commits
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
fetch-depth: 0
persist-credentials: false
- name: Setup Node.js
uses: actions/setup-node@v3
with:
node-version: 16.x
cache: 'npm'
- name: Install dependencies
run: npm clean-install
- name: Lint commits
run: npx commitlint --from ${{ github.event.pull_request.head.sha }}~${{ github.event.pull_request.commits }} --to ${{ github.event.pull_request.head.sha }} --verbose
lintcode:
name: Lint code
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
persist-credentials: false
- name: Setup Node.js
uses: actions/setup-node@v3
with:
node-version: 16.x
cache: 'npm'
- name: Install dependencies
run: npm clean-install
- name: Lint code
run: npm run lint
test:
name: Run tests
runs-on: ubuntu-latest
env:
MSSQL_USER: 'sa'
MSSQL_PASSWORD: 'yourStrong(!)Password'
MSSQL_SERVER: 'localhost'
MSSQL_PORT: '1433'
MSSQL_DATABASE: 'master'
strategy:
matrix:
node-version: [14.x, 16.x, 18.x, 20.x]
sql-version: [2017, 2019, 2022]
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
persist-credentials: false
- name: Setup Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node-version }}
cache: 'npm'
- name: Install dependencies
run: npm clean-install
- name: Run unit tests
run: npm run test-unit
- name: Setup docker cache
id: cache-docker
uses: actions/cache@v3
with:
path: ../.docker
key: ${{ runner.os }}-${{ matrix.sql-version }}-latest
- name: Save docker image
if: steps.cahce-docker.outputs.cache-hit != 'true'
run: |
mkdir ../.docker
docker pull mcr.microsoft.com/mssql/server:${{ matrix.sql-version }}-latest
docker image save mcr.microsoft.com/mssql/server:${{ matrix.sql-version }}-latest -o "../.docker/${{ matrix.sql-version }}.tar"
- name: Load docker image
if: steps.cahce-docker.outputs.cache-hit == 'true'
run: docker image load -i "../.docker/${{ matrix.sql-version }}.tar"
- name: Start docker container
run: docker run --name mssql -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=$MSSQL_PASSWORD" -p 1433:1433 -d mcr.microsoft.com/mssql/server:${{ matrix.sql-version }}-latest
- name: Store test config
run: echo "{\"user\":\"$MSSQL_USER\",\"password\":\"$MSSQL_PASSWORD\",\"server\":\"$MSSQL_SERVER\",\"port\":$MSSQL_PORT,\"database\":\"$MSSQL_DATABASE\",\"options\":{\"trustServerCertificate\":true}}" > ./test/.mssql.json
- name: Wait for database to be ready
run: |
set +e
ATTEMPT=0
while [ $ATTEMPT -le 10 ]; do
ATTEMPT=$(( ATTEMPT + 1 ))
docker exec -it mssql /opt/mssql-tools/bin/sqlcmd -S localhost -U "$MSSQL_USER" -P "$MSSQL_PASSWORD" -q 'SELECT 1;'
if [[ "$STATE" -eq "ready" ]]; then
break
fi
sleep 1
done
- name: Run tedious tests
run: npm run test-tedious
- name: Stop container
if: ${{ always() }}
run: docker rm -f -v mssql