-
Notifications
You must be signed in to change notification settings - Fork 68
97 lines (78 loc) · 3.4 KB
/
github-action-scan.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
89
90
91
92
93
94
95
96
# SPDX-License-Identifier: MIT
name: Build SecHub GHA (scan)
on:
push:
branches:
- 'gha_*'
jobs:
build-scan:
runs-on: ubuntu-latest
# Let's set the scan action folder as the working directory for all "run" steps:
defaults:
run:
working-directory: ./github-actions/scan
steps:
- name: Checkout
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
- name: Use Node.js
# We do not define a dedicated node version here, we just use the default environment
# which should be the default environment for the github actions runtime as well
uses: actions/setup-node@8f152de45cc393bb48ce5d89d36b731f54556e65
- name: Clean install
run: npm ci
- name: Build
run: npm run build --if-present
- name: Run unit tests
run: npm test
- name: Setup integration test data
id : version-selector
run: |
echo "sechub_server_version=1.4.1" >> "$GITHUB_ENV"
echo "sechub_server_port=8443" >> "$GITHUB_ENV"
echo "pds_version=1.4.0" >> "$GITHUB_ENV"
echo "pds_port=8444" >> "$GITHUB_ENV"
#- name: Cache SecHub server download
# # Cache V4 release: 13aacd865c20de90d75de3b17ebe84f7a17d57d2
# uses: actions/cache@13aacd865c20de90d75de3b17ebe84f7a17d57d2
# with:
# path: ./build/sechub-runtime/server/${{ steps.version-selector.outputs.sechub_server_version }}/
# key: ${{ runner.os }}-sechub-server-${{ steps.version-selector.outputs.sechub_server_version }}
#
#- name: Cache PDS download
# # Cache V4 release: 13aacd865c20de90d75de3b17ebe84f7a17d57d2
# uses: actions/cache@13aacd865c20de90d75de3b17ebe84f7a17d57d2
# with:
# path: ./build/sechub-runtime/pds/${{ steps.version-selector.outputs.pds_version }}/
# key: ${{ runner.os }}-pds-${{ steps.version-selector.outputs.pds_version }}
- name: Set up JDK 17 (to run servers)
uses: actions/setup-java@387ac29b308b003ca37ba93a6cab5eb57c8f5f93
with:
java-version: 17
distribution: temurin
- name: Start integration test servers
working-directory: ./github-actions/scan/__test__/integrationtest/
run: ./01-start.sh $sechub_server_version $sechub_server_port $pds_version $pds_port
- name: Init integration test data
working-directory: ./github-actions/scan/__test__/integrationtest/
run: ./03-init_sechub_data.sh $sechub_server_port $pds_port
- name: Run integration tests
run: npm run integration-test
- name: Cleanup integration tests
working-directory: ./github-actions/scan/__test__/integrationtest/
run: ./05-stop.sh $sechub_server_port $pds_port
# ------------------------------------ Archive runtime logs-------------------
- name: Archive runtime logs
if: always()
uses: actions/upload-artifact@v3
with:
name: sechub-runtime-logiles
path: ./build/sechub-runtime/**/*.log
retention-days: 14
# ------------------------------------ Archive report -----------------------
- name: Archive report
if: always()
uses: actions/upload-artifact@v3
with:
name: sechub-report
path: sechub-report*.json
retention-days: 14