-
Notifications
You must be signed in to change notification settings - Fork 480
86 lines (75 loc) · 2.64 KB
/
coverity2.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
on:
# scheduled workflows run on the latest commit on the default or base branch
#schedule:
# - cron: '0 0/12 * * *'
workflow_dispatch:
jobs:
xrt_coverity_scan:
runs-on: ubuntu-latest
# Only run in main repository as Coverity scans are limitted
if: github.repository == 'Xilinx/XRT'
steps:
- name: Checkout XRT
uses: actions/checkout@v2
- name: Store sha
run: echo ${{ github.sha }} > sha
- name: Compare sha
uses: actions/cache@v2
id: cache-sha
with:
path: sha
key: commit-${{ github.sha }}
- name: Download and extract Coverity Build Tool
if: steps.cache-sha.outputs.cache-hit != 'true'
run: |
wget -q https://scan.coverity.com/download/cxx/linux64 --post-data "token=$TOKEN&project=Xilinx/XRT" -O cov-analysis-linux64.tar.gz
mkdir cov-analysis-linux64
tar xzf cov-analysis-linux64.tar.gz --strip 1 -C cov-analysis-linux64
env:
TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }}
- name: Install dependencies
if: steps.cache-sha.outputs.cache-hit != 'true'
run: |
sudo apt update
sudo src/runtime_src/tools/scripts/xrtdeps.sh
sudo apt install jq
- name: Build with cov-build
if: steps.cache-sha.outputs.cache-hit != 'true'
run: |
export PATH=`pwd`/cov-analysis-linux64/bin:$PATH
cov-build --dir cov-int build/build.sh -noert -opt -verbose -driver
- name: Submut the results to Coverity Scan
if: steps.cache-sha.outputs.cache-hit != 'true'
run: |
# compress cov-int
tar czvf xrt.tgz cov-int
# Fetch cloud upload URL
curl -X POST \
-d version=trunk \
-d description=$SHA \
-d email=runtime@xilinx.com \
-d token=$TOKEN \
-d file_name=xrt.tgz \
https://scan.coverity.com/projects/17781/builds/init \
| tee response
# Store response data
upload_url=$(jq -r '.url' response)
build_id=$(jq -r '.build_id' response)
# Upload the tarball to the Cloud
curl -X PUT \
--header 'Content-Type: application/json' \
--upload-file xrt.tgz \
$upload_url
# Trigger the build on Scan
curl -X PUT \
-d token=$TOKEN \
https://scan.coverity.com/projects/17781/builds/$build_id/enqueue
env:
TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }}
SHA: ${{ github.sha }}
- name: Upload Coverity imed to artifactory
if: steps.cache-sha.outputs.cache-hit != 'true'
uses: actions/upload-artifact@v4
with:
name: cov-int-file
path: xrt.tgz