aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/.github/workflows/test.yml
diff options
context:
space:
mode:
authorEgor Tensin <Egor.Tensin@gmail.com>2021-04-14 14:38:36 +0300
committerEgor Tensin <Egor.Tensin@gmail.com>2021-04-17 16:57:05 +0300
commit45c3e9a96144162f41f27fc474d612f2965a21c3 (patch)
tree45a2b2e67f26820ee039e71972890c7dfdbf612d /.github/workflows/test.yml
downloadbuild-boost-45c3e9a96144162f41f27fc474d612f2965a21c3.tar.gz
build-boost-45c3e9a96144162f41f27fc474d612f2965a21c3.zip
initial commit
Diffstat (limited to '')
-rw-r--r--.github/workflows/test.yml89
1 files changed, 89 insertions, 0 deletions
diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml
new file mode 100644
index 0000000..720eb38
--- /dev/null
+++ b/.github/workflows/test.yml
@@ -0,0 +1,89 @@
+name: Test
+
+on:
+ push:
+ pull_request:
+ schedule:
+ # Weekly, at 5:45 AM on Friday (somewhat randomly chosen).
+ - cron: '45 5 * * 5'
+ workflow_dispatch:
+
+jobs:
+ test:
+ strategy:
+ matrix:
+ version: [1.58.0, 1.74.0]
+ os: [ubuntu-18.04, ubuntu-20.04, windows-2016, windows-2019]
+ toolset: [auto, clang, gcc, mingw, msvc]
+
+ exclude:
+ # No Visual Studio on Linux.
+ - {os: ubuntu-18.04, toolset: msvc}
+ - {os: ubuntu-20.04, toolset: msvc}
+ # GCC == MinGW-w64 on Windows.
+ - {os: windows-2016, toolset: gcc}
+ - {os: windows-2019, toolset: gcc}
+
+ runs-on: '${{ matrix.os }}'
+
+ name: '${{ matrix.version }} / ${{ matrix.os }} / ${{ matrix.toolset }}'
+
+ defaults:
+ run:
+ shell: pwsh
+
+ steps:
+ - name: Checkout
+ uses: actions/checkout@v2
+
+ - name: Cache Boost
+ uses: actions/cache@v2.1.4
+ with:
+ path: '${{ runner.workspace }}/boost_*.tar.gz'
+ key: 'boost-${{ matrix.version }}'
+
+ - name: Clean up PATH
+ uses: egor-tensin/cleanup-path@v2
+ if: runner.os == 'Windows'
+
+ - name: Set up GCC
+ uses: egor-tensin/setup-gcc@v1
+ if: matrix.toolset == 'gcc'
+
+ - name: Set up MinGW
+ uses: egor-tensin/setup-mingw@v2
+ if: matrix.toolset == 'mingw' || (matrix.toolset == 'clang' && runner.os == 'Windows')
+
+ - name: Set up Clang
+ uses: egor-tensin/setup-clang@v1
+ if: matrix.toolset == 'clang'
+
+ - id: build
+ name: Build Boost
+ uses: ./
+ with:
+ version: '${{ matrix.version }}'
+ toolset: '${{ matrix.toolset }}'
+ configuration: Release
+ libraries: filesystem program_options system
+
+ - name: Check libraries
+ run: |
+ New-Variable os -Value '${{ runner.os }}' -Option Constant
+ New-Variable windows_host -Value ($os -eq 'Windows') -Option Constant
+
+ New-Variable toolset -Value '${{ matrix.toolset }}' -Option Constant
+ New-Variable librarydir -Value '${{ steps.build.outputs.librarydir }}' -Option Constant
+
+ $prefix = 'libboost_'
+ $ext = '.a'
+ if ($windows_host -and $toolset -in @('auto', 'clang', 'msvc')) {
+ $ext = '.lib'
+ }
+
+ $expected = @('filesystem', 'program_options', 'system')
+ $expected = $expected | %{"$prefix$_$ext"}
+ foreach ($lib in $expected) {
+ $path = Join-Path $librarydir $lib
+ $(Test-Path $path -Type Leaf) -or $(throw "Couldn't find Boost library at: $path")
+ }