diff options
Diffstat (limited to '')
-rw-r--r-- | .github/workflows/test.yml | 128 |
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' |