-
Notifications
You must be signed in to change notification settings - Fork 6
88 lines (70 loc) · 3.79 KB
/
main.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
name: Main
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-13] # 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@v4
with:
version: 2.0.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 build && 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
if: matrix.os != 'macos-13'
# TODO: diagnose why it fails on macOS
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 and generate manifest
shell: bash
run: |
# Set user GitHub login required for `alr publish`
alr settings --set --global user.github_login ${{github.repository_owner}}
# Run Alire publish assistant with the appropriate commit
# Force to allow generation for -dev version
alr -f publish --skip-submit \
${{github.server_url}}/${{github.repository}} \
${{ github.event_name == 'pull_request' && github.event.pull_request.head.sha || 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
shell: bash
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