-
Notifications
You must be signed in to change notification settings - Fork 1
104 lines (83 loc) · 3.29 KB
/
BuildTest.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
97
98
99
100
101
102
103
104
# This is the name of the workflow, visible on GitHub UI.
name: 'Build tests'
env:
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
BUILD_TYPE: Release
TARGET_TEST: picoder
# Controls when the action will run.
# Here we tell GitHub to run the workflow when a commit.
on:
push:
paths:
- 'src/**'
- 'libs/**'
- '.github/workflows/*.yml'
- 'CMakeLists.txt'
pull_request:
paths:
- 'src/**'
# Scheduled the first day of every month at 00:00h UTC
schedule:
- cron: '0 0 1 * *'
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
build:
# This is the name of the job
name: 'Build for ${{ matrix.config.name }}'
# The CMake configure and build commands are platform agnostic and should work equally
# well on Windows, Linux or Mac.
runs-on: ${{ matrix.config.os }}
# Job env var for cmake build directory
env:
BUILD_DIR: ${{ github.workspace }}/build
# Here we tell GitHub that the jobs must be determined
# dynamically depending on a matrix configuration.
strategy:
# Set to false so that GitHub does not cancel all jobs
# in progress if any array job fails.
fail-fast: false
# The matrix will produce one job for each configuration:
matrix:
config:
- name: 'Linux x86_64'
os: 'ubuntu-latest'
bindir: 'echo "BIN_DIR=$BUILD_DIR" >> $GITHUB_ENV'
- name: 'macOS Universal'
os: 'macos-latest'
bindir: 'echo "BIN_DIR=$BUILD_DIR" >> $GITHUB_ENV'
- name: 'Windows x86_64'
os: 'windows-latest'
bindir: 'echo "BIN_DIR=$env:BUILD_DIR/$Env:BUILD_TYPE" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf-8 -Append'
# This is the list of steps this job will run.
steps:
# Clone repo using the checkout action.
- name: Checkout
uses: actions/checkout@v2
with:
submodules: recursive
- name: Create Build Environment
# Some projects don't allow in-source building, so create a separate build directory
# We'll use this as our working directory for all subsequent commands
run: cmake -E make_directory ${{ env.BUILD_DIR }}
- name: Running CMake
working-directory: ${{ env.BUILD_DIR }}
run: cmake .. -DCMAKE_BUILD_TYPE=${{ env.BUILD_TYPE }}
- name: Build ${{ env.TARGET_TEST }}
working-directory: ${{ env.BUILD_DIR }}
# Execute the build. You can specify a specific target with "--target <NAME>"
run: cmake --build . --config ${{ env.BUILD_TYPE }} --target ${{ env.TARGET_TEST }}
# Set BIN_DIR from matrix bindir command
- name: Setting the binaries directory
run: ${{ matrix.config.bindir }}
# Execute test
- name: Execution test ${{env.TARGET_TEST}}
run: ${{ env.BIN_DIR }}/${{ env.TARGET_TEST }} version
# Upload binary files to artifacts
- name: Upload compiled binaries to Artifacts
uses: actions/upload-artifact@v2
with:
name: "Picoder binary for ${{ matrix.config.name }}"
path: |
${{ env.BIN_DIR }}/${{ env.TARGET_TEST }}
${{ env.BIN_DIR }}/${{ env.TARGET_TEST }}.exe