Skip to content

Feature/118 jacoco it test #351

Feature/118 jacoco it test

Feature/118 jacoco it test #351

Workflow file for this run

#
# Copyright 2022 ABSA Group Limited
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
name: Build
on:
push:
branches: [master ]
pull_request:
types: [ assigned, opened, synchronize, reopened, labeled ]
jobs:
build:
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
include:
- scala: 2.12.17
scalaShort: "2.12"
overall: 0.0
changed: 80.0
- scala: 2.13.12
scalaShort: "2.13"
overall: 0.0
changed: 80.0
name: Build and test
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Setup Scala
uses: olafurpg/setup-scala@v10
with:
java-version: "[email protected]"
- name: Build and run tests
run: sbt ++${{matrix.scala}} jacoco doc # We will need JaCoCo report in second job
- uses: actions/cache/save@v3
with:
path: |
${{ github.workspace }}/core/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml
${{ github.workspace }}/examples/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml
${{ github.workspace }}/slick/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml
${{ github.workspace }}/doobie/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml
key: ${{ runner.os }}-${{ matrix.scalaShort }}-${{ hashFiles('**/jacoco.xml') }}
jacoco:
runs-on: ubuntu-latest
needs: build
strategy:
fail-fast: false
matrix:
include:
- scala: 2.12.17
scalaShort: "2.12"
overall: 0.0
changed: 80.0
- scala: 2.13.12
scalaShort: "2.13"
overall: 0.0
changed: 80.0
name: JaCoCo Code Coverage ${{matrix.scala}}
steps:
- name: Checkout code
uses: actions/checkout@v2
- uses: actions/cache/restore@v3
with:
path: |
${{ github.workspace }}/core/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml
${{ github.workspace }}/examples/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml
${{ github.workspace }}/slick/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml
${{ github.workspace }}/doobie/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml
key: ${{ runner.os }}-${{ matrix.scalaShort }}-${{ hashFiles('**/jacoco.xml') }}
- name: Setup Scala
uses: olafurpg/setup-scala@v10
with:
java-version: "[email protected]"
- name: Add coverage to PR
id: jacoco
uses: madrapps/[email protected]
with:
paths: >
${{ github.workspace }}/core/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml,
${{ github.workspace }}/slick/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml,
${{ github.workspace }}/doobie/target/scala-${{ matrix.scalaShort }}/jacoco/report/jacoco.xml
# examples don't need code coverage - at least not now
token: ${{ secrets.GITHUB_TOKEN }}
min-coverage-overall: ${{ matrix.overall }}
min-coverage-changed-files: ${{ matrix.changed }}
title: JaCoCo code coverage report - scala ${{ matrix.scala }}
update-comment: true
- name: Get the Coverage info
run: |
echo "Total coverage ${{ steps.jacoco.outputs.coverage-overall }}"
echo "Changed Files coverage ${{ steps.jacoco.outputs.coverage-changed-files }}"
# temporarily disabled until we have a better way how to test against a database
# - name: Fail PR if changed files coverage is less than ${{ matrix.changed }}%
# if: ${{ steps.jacoco.outputs.coverage-changed-files < 80.0 }}
# uses: actions/github-script@v6
# with:
# script: |
# core.setFailed('Changed files coverage is less than ${{ matrix.changed }}%!')