aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/.github/workflows/test.yml
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--.github/workflows/test.yml128
1 files changed, 36 insertions, 92 deletions
diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml
index dcb1b46..5de83a8 100644
--- a/.github/workflows/test.yml
+++ b/.github/workflows/test.yml
@@ -9,118 +9,62 @@ on:
workflow_dispatch:
jobs:
- test:
+ ubuntu:
strategy:
- fail-fast: false
matrix:
platform: [x86, x64]
- cygwin: [0, 1]
- hardlinks: [0, 1]
- os: [ubuntu-18.04, ubuntu-20.04, ubuntu-latest, windows-latest]
-
- include:
- # Prettier run names.
- - {os: ubuntu-18.04, name: Ubuntu 18.04}
- - {os: ubuntu-20.04, name: Ubuntu 20.04}
- - {os: ubuntu-latest, name: Ubuntu (latest)}
- - {cygwin: 1, name: Cygwin}
- exclude:
- # No Cygwin on Ubuntu.
- - {os: ubuntu-18.04, cygwin: 1}
- - {os: ubuntu-20.04, cygwin: 1}
- - {os: ubuntu-latest, cygwin: 1}
- # This action is not suitable for Windows hosts, use setup-mingw for
- # that.
- - {os: windows-latest, cygwin: 0}
- # Only test hardlinks on Cygwin.
- - {cygwin: 0, hardlinks: 1}
-
+ os: [ubuntu-18.04, ubuntu-20.04, ubuntu-latest]
runs-on: '${{ matrix.os }}'
-
- name: '${{ matrix.name }} / ${{ matrix.platform }} / Hardlinks: ${{ matrix.hardlinks }}'
-
- defaults:
- run:
- shell: pwsh
-
+ name: 'Test: ${{ matrix.os }} / ${{ matrix.platform }}'
steps:
- name: Checkout
uses: actions/checkout@v2
+ - name: Set up GCC
+ uses: ./
+ with:
+ platform: '${{ matrix.platform }}'
+ cc: 1
+ - name: Build foo.exe
+ uses: ./.github/actions/build-foo
+ - name: Run foo.exe
+ uses: ./.github/actions/run-foo
+ - name: Check cc/c++
+ uses: ./.github/actions/check-cc
+ cygwin:
+ strategy:
+ matrix:
+ platform: [x86, x64]
+ hardlinks: [0, 1]
+ runs-on: windows-latest
+ name: 'Cygwin: ${{ matrix.platform }} / hardlinks${{ matrix.hardlinks }}'
+ steps:
+ - name: Checkout
+ uses: actions/checkout@v2
- name: Clean up PATH
uses: egor-tensin/cleanup-path@v1
- if: runner.os == 'Windows'
-
- name: Install Cygwin
uses: egor-tensin/setup-cygwin@v3
with:
platform: '${{ matrix.platform }}'
- if: matrix.cygwin
-
- name: Set up GCC
uses: ./
with:
platform: '${{ matrix.platform }}'
- cygwin: '${{ matrix.cygwin }}'
+ cygwin: 1
cc: 1
hardlinks: '${{ matrix.hardlinks }}'
-
- name: Build foo.exe
- run: |
- $flags = @()
- if ('${{ matrix.platform }}' -eq 'x86') {
- $flags += '-m32'
- }
- $flags += '-std=c++14','-o','foo','foo.cpp'
- if ('${{ runner.os }}' -eq 'Linux') {
- $flags += '-lpthread'
- }
- g++ $flags
- if: '!matrix.cygwin || matrix.hardlinks'
-
- - name: Build foo.exe on Cygwin
- run: |
- $cwd = cygpath.exe -ua (Get-Location)
- $arch = if ('${{ matrix.platform }}' -eq 'x64') { '-m64' } else { '-m32' }
- $cmd = printf.exe -- 'cd %q && g++ %q -std=c++14 -o foo foo.cpp' $cwd $arch
- bash.exe --login -o errexit -c $cmd
- if: matrix.cygwin && !matrix.hardlinks
-
+ uses: ./.github/actions/build-foo
+ if: matrix.hardlinks
+ - name: Build foo.exe
+ uses: ./.github/actions/build-foo-cygwin
+ if: '!matrix.hardlinks'
- name: Run foo.exe
- run: |
- $expected = @"
- Doing something #1
- Doing something #2
- Doing something #3
- "@
-
- $actual = & (Join-Path . foo)
- $actual = $actual -join [Environment]::NewLine
-
- $($actual -eq $expected) -or $(throw @"
- Unexpected output:
- $actual
- "@)
-
- # Is this really the most stable piece of `gcc --version` output?
+ uses: ./.github/actions/run-foo
- name: Check cc/c++
- run: |
- echo (Get-Command cc).Path
- $cc = & cc --version
- echo $cc
- $($cc | Select-String -Pattern "This is free software; see the source for copying conditions." -SimpleMatch -Quiet) -or $(throw "Unexpected `cc --version` output")
- echo (Get-Command c++).Path
- $cxx = & c++ --version
- echo $cxx
- $($cxx | Select-String -Pattern "This is free software; see the source for copying conditions." -SimpleMatch -Quiet) -or $(throw "Unexpected `c++ --version` output")
- if: '!matrix.cygwin || matrix.hardlinks'
-
- - name: Check cc/c++ on Cygwin
- run: |
- $cc = bash.exe --login -o errexit -c 'cc --version'
- echo $cc
- $($cc | Select-String -Pattern "This is free software; see the source for copying conditions." -SimpleMatch -Quiet) -or $(throw "Unexpected `cc --version` output")
- $cxx = bash.exe --login -o errexit -c 'c++ --version'
- echo $cxx
- $($cxx | Select-String -Pattern "This is free software; see the source for copying conditions." -SimpleMatch -Quiet) -or $(throw "Unexpected `c++ --version` output")
- if: matrix.cygwin && !matrix.hardlinks
+ uses: ./.github/actions/check-cc
+ if: matrix.hardlinks
+ - name: Check cc/c++
+ uses: ./.github/actions/check-cc-cygwin
+ if: '!matrix.hardlinks'