Skip to content

Use appropriate commit for push/pr #110

Use appropriate commit for push/pr

Use appropriate commit for push/pr #110

Workflow file for this run

on: # Run the workflow for each of the following events:
push: # - A branch is pushed or updated.
pull_request: # - A pull-request is opened or updated.
workflow_dispatch: # - A manual run of the workflow is requested from the GitHub web interface.
release:
types: [created] # - A release is created.
jobs:
main:
strategy:
fail-fast: false # Don't stop all the workflows when one of them fails.
matrix:
os: [ubuntu-latest, windows-latest, macos-latest] # List of GitHub Actions platform to run the workflow on
runs-on: ${{ matrix.os }} # Run the continuous integration workflow on each OS listed in the matrix.
steps:
# Check-out the repository
- uses: actions/checkout@v2
# Install and setup Alire package manager
- uses: alire-project/setup-alire@v1
with:
version: 1.2.2
# Build the project using the validation build profile to enforce static analysis and coding style.
- run: alr build --validation
# Run GNATprove to perform automatic formal verification of the SPARK code.
- run: alr gnatprove -j0 --level=4
# Instrument the project code for coverage analysis.
- run: cd tests && alr gnatcov instrument --level=stmt --dump-trigger=atexit --projects ada_spark_workflow.gpr
# Build testsuite with instrumented code.
- run: cd tests && alr build -- --src-subdirs=gnatcov-instr --implicit-with=gnatcov_rts_full
# Run the instrumented testsuite. This will produce at least one `.srctrace` file for the coverage analysis.
- run: cd tests && alr exec ./bin/tests
# Run the GNATcov code coverage analysis on the trace files.
- run: cd tests && alr gnatcov coverage --annotate=xcov --output-dir gnatcov_out --level=stmt --projects ada_spark_workflow.gpr *.srctrace
# Upload the code coverage analysis results to codecov.io
- uses: alire-project/gnatcov-to-codecovio-action@main
with:
fail_ci_if_error: false # Don't fail the workflow if codecov.io failed
verbose: true
# Produce an Alire release manifest
- name: Configure Github credentials
run: |
# Set user GitHub login required for `alr publish`
alr config --set --global user.github_login ${{github.repository_owner}}
# Run Alire publish assistant with the appropriate commit
alr publish ${{github.server_url}}/${{github.repository}} ${{ github.event_name == 'pull_request' && github.event.pull_request.head.sha || github.sha }}
- if: github.event_name == 'pull_request'
run: alr publish ${{github.server_url}}/${{github.repository}} ${{ github.event.pull_request.head.sha }}
- if: github.event_name == 'push'
run: alr publish ${{github.server_url}}/${{github.repository}} ${{ github.sha }}
# Save the path to the release manifest for the next step.
# This is a little trick to get around the fact that the actions/upload-release-asset doesn't allow globing pattern.
- name: Get Release Manifest PATH
run: |
export MANIFEST_PATHNAME=$(ls alire/releases/*.toml | head -n 1)
echo MANIFEST_PATHNAME=$MANIFEST_PATHNAME >> $GITHUB_ENV
echo MANIFEST_NAME=$(basename $MANIFEST_PATHNAME) >> $GITHUB_ENV
# If this workflow was triggered by a release event, upload the release manifest as a GitHub release asset.
- name: Upload release manifest
if: (github.event_name == 'release')
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ github.event.release.upload_url }}
asset_path: ${{ env.MANIFEST_PATHNAME }}
asset_name: ${{ env.MANIFEST_NAME }}
asset_content_type: application/toml