mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 07:57:47 +00:00
CI: Split off clang toolchain builds from normal CI and schedule them
Clang builds will no longer be apart of the automated CI for every Push/ Pull Request, and will instead be ran at 00:00 UTC every day, with the results posted to the discord #clang-toolchain channel.
This commit is contained in:
parent
97010d4903
commit
bac3c2cf6d
2 changed files with 245 additions and 150 deletions
99
.github/workflows/clang.yml
vendored
Normal file
99
.github/workflows/clang.yml
vendored
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
name: Clang toolchain status
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: '0 0 * * *'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build_and_test_serenity:
|
||||||
|
runs-on: ubuntu-20.04
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
arch: [ 'i686', 'x86_64' ]
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Install Ubuntu dependencies
|
||||||
|
run: |
|
||||||
|
sudo add-apt-repository ppa:canonical-server/server-backports
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install libmpfr-dev libmpc-dev ninja-build e2fsprogs qemu-utils qemu-system-i386
|
||||||
|
|
||||||
|
- name: Check versions
|
||||||
|
run: set +e; g++ --version; g++-10 --version; ninja --version; qemu-system-i386 --version
|
||||||
|
|
||||||
|
- name: Regenerate Toolchain
|
||||||
|
run: TRY_USE_LOCAL_TOOLCHAIN=y ARCH="${{ matrix.arch }}" ${{ github.workspace }}/Toolchain/BuildClang.sh
|
||||||
|
|
||||||
|
- name: Create build directory
|
||||||
|
run: |
|
||||||
|
mkdir -p ${{ github.workspace }}/Build
|
||||||
|
mkdir -p ${{ github.workspace }}/Build/UCD
|
||||||
|
|
||||||
|
- name: UnicodeData cache
|
||||||
|
# TODO: Change the version to the released version when https://github.com/actions/cache/pull/489 (or 571) is merged.
|
||||||
|
uses: actions/cache@03e00da99d75a2204924908e1cca7902cafce66b
|
||||||
|
with:
|
||||||
|
path: ${{ github.workspace }}/Build/UCD
|
||||||
|
key: UnicodeData-${{ hashFiles('Userland/Libraries/LibUnicode/unicode_data.cmake') }}
|
||||||
|
|
||||||
|
- name: Create build environment
|
||||||
|
working-directory: ${{ github.workspace }}/Build
|
||||||
|
run: cmake .. -GNinja -DSERENITY_ARCH=${{ matrix.arch }} -DUSE_CLANG_TOOLCHAIN=ON -DENABLE_UNDEFINED_SANITIZER=ON -DENABLE_PCI_IDS_DOWNLOAD=OFF -DENABLE_USB_IDS_DOWNLOAD=OFF -DCMAKE_C_COMPILER=gcc-10 -DCMAKE_CXX_COMPILER=g++-10
|
||||||
|
|
||||||
|
- name: Build Serenity and Tests
|
||||||
|
working-directory: ${{ github.workspace }}/Build
|
||||||
|
run: cmake --build .
|
||||||
|
- name: Show ccache stats after build
|
||||||
|
run: ccache -s
|
||||||
|
|
||||||
|
- name: Create Serenity Rootfs
|
||||||
|
working-directory: ${{ github.workspace }}/Build
|
||||||
|
run: ninja install && ninja image
|
||||||
|
|
||||||
|
- name: Run On-Target Tests
|
||||||
|
working-directory: ${{ github.workspace }}/Build
|
||||||
|
env:
|
||||||
|
SERENITY_QEMU_CPU: "max,vmx=off"
|
||||||
|
SERENITY_KERNEL_CMDLINE: "boot_mode=self-test"
|
||||||
|
SERENITY_RUN: "ci"
|
||||||
|
run: |
|
||||||
|
echo "::group::ninja run # Qemu output"
|
||||||
|
ninja run
|
||||||
|
echo "::endgroup::"
|
||||||
|
echo "::group::Verify Output File"
|
||||||
|
mkdir fsmount
|
||||||
|
sudo mount -t ext2 -o loop,rw _disk_image fsmount
|
||||||
|
echo "Results: "
|
||||||
|
sudo cat fsmount/home/anon/test-results.log
|
||||||
|
if ! sudo grep -q "Failed: 0" fsmount/home/anon/test-results.log
|
||||||
|
then
|
||||||
|
echo "::error :^( Tests failed, failing job"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "::endgroup::"
|
||||||
|
timeout-minutes: 60
|
||||||
|
|
||||||
|
- name: Print Target Logs
|
||||||
|
# Extremely useful if Serenity hangs trying to run one of the tests
|
||||||
|
if: ${{ !cancelled() }}
|
||||||
|
working-directory: ${{ github.workspace }}/Build
|
||||||
|
run: '[ ! -e debug.log ] || cat debug.log'
|
||||||
|
|
||||||
|
notify_discord:
|
||||||
|
runs-on: ubuntu-20.04
|
||||||
|
needs: build_and_test_serenity
|
||||||
|
if: always()
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- uses: technote-space/workflow-conclusion-action@v2
|
||||||
|
- name: Send discord notification
|
||||||
|
env:
|
||||||
|
DISCORD_WEBHOOK: ${{ secrets.DISCORD_CLANG_WEBHOOK }}
|
||||||
|
DISCORD_USERNAME: GitHub # we have to set these manually for non-default messages
|
||||||
|
DISCORD_AVATAR: https://github.githubassets.com/images/modules/logos_page/GitHub-Mark.png
|
||||||
|
uses: IdanHo/action-discord@754598254f288e6d8e9fca637832e3c163515ba8
|
||||||
|
with:
|
||||||
|
args: "The clang build ${{ env.WORKFLOW_CONCLUSION == 'success' && 'passed :white_check_mark:' || 'failed :x:' }} :( https://github.com/SerenityOS/serenity/runs/${{github.run_id}}"
|
||||||
|
|
296
.github/workflows/cmake.yml
vendored
296
.github/workflows/cmake.yml
vendored
|
@ -21,173 +21,169 @@ jobs:
|
||||||
debug-options: ['ALL_DEBUG', 'NORMAL_DEBUG']
|
debug-options: ['ALL_DEBUG', 'NORMAL_DEBUG']
|
||||||
os: [ubuntu-20.04]
|
os: [ubuntu-20.04]
|
||||||
arch: ['i686', 'x86_64']
|
arch: ['i686', 'x86_64']
|
||||||
compiler: ['GCC', 'Clang']
|
|
||||||
# If ccache is broken and you would like to bust the ccache cache on Github Actions, increment this:
|
# If ccache is broken and you would like to bust the ccache cache on Github Actions, increment this:
|
||||||
ccache-mark: [0]
|
ccache-mark: [0]
|
||||||
exclude:
|
exclude:
|
||||||
# We currently manually disable the ALL_DEBUG build on x86_64 for sake of saving CI time, as it is not our main target right now
|
# We currently manually disable the ALL_DEBUG build on x86_64 for sake of saving CI time, as it is not our main target right now
|
||||||
- debug-options: 'ALL_DEBUG'
|
- debug-options: 'ALL_DEBUG'
|
||||||
arch: 'x86_64'
|
arch: 'x86_64'
|
||||||
- debug-options: 'ALL_DEBUG'
|
|
||||||
compiler: 'Clang'
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
# Set default Python to python 3.x, and set Python path such that pip install works properly
|
# Set default Python to python 3.x, and set Python path such that pip install works properly
|
||||||
- uses: actions/setup-python@v2
|
- uses: actions/setup-python@v2
|
||||||
|
|
||||||
# === OS SETUP ===
|
# === OS SETUP ===
|
||||||
|
|
||||||
# Do we need to update the package cache first?
|
# Do we need to update the package cache first?
|
||||||
# sudo apt-get update -qq
|
# sudo apt-get update -qq
|
||||||
- name: "Install Ubuntu dependencies"
|
- name: "Install Ubuntu dependencies"
|
||||||
# These packages are already part of the ubuntu-20.04 image:
|
# These packages are already part of the ubuntu-20.04 image:
|
||||||
# cmake clang-format-11 gcc-10 g++-10 libstdc++-10-dev libgmp-dev npm shellcheck
|
# cmake clang-format-11 gcc-10 g++-10 libstdc++-10-dev libgmp-dev npm shellcheck
|
||||||
# Packages below aren't.
|
# Packages below aren't.
|
||||||
#
|
#
|
||||||
# We add the canonical-server/server-backports PPA to get updated QEMU releases without having to manage
|
# We add the canonical-server/server-backports PPA to get updated QEMU releases without having to manage
|
||||||
# yet another cache in github actions
|
# yet another cache in github actions
|
||||||
run: |
|
run: |
|
||||||
sudo add-apt-repository ppa:canonical-server/server-backports
|
sudo add-apt-repository ppa:canonical-server/server-backports
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install libmpfr-dev libmpc-dev ninja-build e2fsprogs qemu-utils qemu-system-i386 ccache
|
sudo apt-get install libmpfr-dev libmpc-dev ninja-build e2fsprogs qemu-utils qemu-system-i386 ccache
|
||||||
- name: Install JS dependencies
|
- name: Install JS dependencies
|
||||||
run: sudo npm install -g prettier@2.2.1
|
run: sudo npm install -g prettier@2.2.1
|
||||||
- name: Install Python dependencies
|
- name: Install Python dependencies
|
||||||
# The setup-python action set default python to python3.x. Note that we are not using system python here.
|
# The setup-python action set default python to python3.x. Note that we are not using system python here.
|
||||||
run: |
|
run: |
|
||||||
python -m pip install --upgrade pip
|
python -m pip install --upgrade pip
|
||||||
pip install flake8 requests
|
pip install flake8 requests
|
||||||
- name: Check versions
|
- name: Check versions
|
||||||
run: set +e; g++ --version; g++-10 --version; clang-format --version; clang-format-11 --version; prettier --version; python --version; python3 --version; ninja --version; flake8 --version; ccache --version; qemu-system-i386 --version
|
run: set +e; g++ --version; g++-10 --version; clang-format --version; clang-format-11 --version; prettier --version; python --version; python3 --version; ninja --version; flake8 --version; ccache --version; qemu-system-i386 --version
|
||||||
|
|
||||||
# === PREPARE FOR BUILDING ===
|
# === PREPARE FOR BUILDING ===
|
||||||
|
|
||||||
- name: Lint (Phase 1/2)
|
- name: Lint (Phase 1/2)
|
||||||
run: ${{ github.workspace }}/Meta/lint-ci.sh
|
run: ${{ github.workspace }}/Meta/lint-ci.sh
|
||||||
- name: Prepare useful stamps
|
- name: Prepare useful stamps
|
||||||
id: stamps
|
id: stamps
|
||||||
shell: cmake -P {0}
|
shell: cmake -P {0}
|
||||||
run: |
|
run: |
|
||||||
string(TIMESTAMP current_date "%Y_%m_%d_%H_%M_%S" UTC)
|
string(TIMESTAMP current_date "%Y_%m_%d_%H_%M_%S" UTC)
|
||||||
# Output everything twice to make it visible both in the logs
|
# Output everything twice to make it visible both in the logs
|
||||||
# *and* as actual output variable, in this order.
|
# *and* as actual output variable, in this order.
|
||||||
message(" set-output name=time::${current_date}")
|
message(" set-output name=time::${current_date}")
|
||||||
message("::set-output name=time::${current_date}")
|
message("::set-output name=time::${current_date}")
|
||||||
message(" set-output name=libc_headers::${{ hashFiles('Userland/Libraries/LibC/**/*.h', 'Userland/Libraries/LibPthread/**/*.h', 'Toolchain/Patches/*.patch', 'Toolchain/BuildIt.sh') }}")
|
message(" set-output name=libc_headers::${{ hashFiles('Userland/Libraries/LibC/**/*.h', 'Userland/Libraries/LibPthread/**/*.h', 'Toolchain/Patches/*.patch', 'Toolchain/BuildIt.sh') }}")
|
||||||
message("::set-output name=libc_headers::${{ hashFiles('Userland/Libraries/LibC/**/*.h', 'Userland/Libraries/LibPthread/**/*.h', 'Toolchain/Patches/*.patch', 'Toolchain/BuildIt.sh') }}")
|
message("::set-output name=libc_headers::${{ hashFiles('Userland/Libraries/LibC/**/*.h', 'Userland/Libraries/LibPthread/**/*.h', 'Toolchain/Patches/*.patch', 'Toolchain/BuildIt.sh') }}")
|
||||||
- name: Toolchain cache
|
|
||||||
# TODO: Change the version to the released version when https://github.com/actions/cache/pull/489 (or 571) is merged.
|
|
||||||
uses: actions/cache@03e00da99d75a2204924908e1cca7902cafce66b
|
|
||||||
env:
|
|
||||||
CACHE_SKIP_SAVE: ${{ github.event_name == 'pull_request' }}
|
|
||||||
with:
|
|
||||||
path: ${{ github.workspace }}/Toolchain/Cache/
|
|
||||||
# This assumes that *ALL* LibC and LibPthread headers have an impact on the Toolchain.
|
|
||||||
# This is wrong, and causes more Toolchain rebuilds than necessary.
|
|
||||||
# However, we want to avoid false cache hits at all costs.
|
|
||||||
key: ${{ runner.os }}-toolchain-${{ matrix.arch }}-${{ matrix.compiler }}-${{ steps.stamps.outputs.libc_headers }}
|
|
||||||
- name: Restore or regenerate GCC Toolchain
|
|
||||||
run: TRY_USE_LOCAL_TOOLCHAIN=y ARCH="${{ matrix.arch }}" ${{ github.workspace }}/Toolchain/BuildIt.sh
|
|
||||||
if: ${{ matrix.compiler == 'GCC' }}
|
|
||||||
- name: Restore or regenerate Clang Toolchain
|
|
||||||
run: TRY_USE_LOCAL_TOOLCHAIN=y ARCH="${{ matrix.arch }}" ${{ github.workspace }}/Toolchain/BuildClang.sh
|
|
||||||
if: ${{ matrix.compiler == 'Clang' }}
|
|
||||||
- name: ccache(1) cache
|
|
||||||
# Pull the ccache *after* building the toolchain, in case building the Toolchain somehow interferes.
|
|
||||||
# TODO: Change the version to the released version when https://github.com/actions/cache/pull/489 (or 571) is merged.
|
|
||||||
uses: actions/cache@03e00da99d75a2204924908e1cca7902cafce66b
|
|
||||||
env:
|
|
||||||
CACHE_SKIP_SAVE: ${{ github.event_name == 'pull_request' }}
|
|
||||||
with:
|
|
||||||
path: /home/runner/.ccache
|
|
||||||
# If you're here because ccache broke (it never should), increment matrix.ccache-mark.
|
|
||||||
# We want to always reuse the last cache, but upload a new one.
|
|
||||||
# This is achieved by using the "prefix-timestamp" format,
|
|
||||||
# and permitting the restore-key "prefix-" without specifying a timestamp.
|
|
||||||
# For this trick to work, the timestamp *must* come last, and it *must* be missing in 'restore-keys'.
|
|
||||||
key: ${{ runner.os }}-ccache-${{ matrix.arch }}-${{ matrix.compiler }}-v${{ matrix.ccache-mark }}-D${{ matrix.debug-options }}-toolchain_${{steps.stamps.outputs.libc_headers}}-time${{ steps.stamps.outputs.time }}
|
|
||||||
# IMPORTANT: Keep these two in sync!
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-ccache-${{ matrix.arch }}-${{ matrix.compiler }}-v${{ matrix.ccache-mark }}-D${{ matrix.debug-options }}-toolchain_${{steps.stamps.outputs.libc_headers}}-
|
|
||||||
- name: Show ccache stats before build and configure
|
|
||||||
run: |
|
|
||||||
# We only have 5 GiB of cache available *in total*. Beyond that, GitHub deletes caches.
|
|
||||||
# Currently, we use about 130 MB for the two toolchains (i686 & x86_64), and four ccache caches:
|
|
||||||
# Two with ALL_DEBUG (i686 & x86_64) and two with NORMAL_DEBUG (i686 & x86_64).
|
|
||||||
# Therefore, using 1.25 GB or more per cache causes disaster.
|
|
||||||
# Building from scratch fills the ccache cache from 0 to about 0.7 GB, and after compression it comes out to
|
|
||||||
# about 0.25 GB, so 1.5 GB (0.5GB after compression) should be plenty, all while comfortly fitting in the cache.
|
|
||||||
ccache -M 1500M
|
|
||||||
ccache -s
|
|
||||||
- name: Create build directory
|
|
||||||
run: |
|
|
||||||
mkdir -p ${{ github.workspace }}/Build
|
|
||||||
mkdir -p ${{ github.workspace }}/Build/UCD
|
|
||||||
- name: UnicodeData cache
|
|
||||||
# TODO: Change the version to the released version when https://github.com/actions/cache/pull/489 (or 571) is merged.
|
|
||||||
uses: actions/cache@03e00da99d75a2204924908e1cca7902cafce66b
|
|
||||||
with:
|
|
||||||
path: ${{ github.workspace }}/Build/UCD
|
|
||||||
key: UnicodeData-${{ hashFiles('Userland/Libraries/LibUnicode/unicode_data.cmake') }}
|
|
||||||
- name: Create build environment with extra debug options
|
|
||||||
working-directory: ${{ github.workspace }}/Build
|
|
||||||
# Build the entire project with all available debug options turned on, to prevent code rot.
|
|
||||||
# However, it is unweildy and slow to run tests with them enabled, so we will build twice.
|
|
||||||
run: cmake .. -GNinja -DSERENITY_ARCH=${{ matrix.arch }} -DUSE_CLANG_TOOLCHAIN=${{ matrix.compiler == 'Clang' }} -DBUILD_LAGOM=ON -DENABLE_ALL_DEBUG_FACILITIES=ON -DENABLE_PCI_IDS_DOWNLOAD=OFF -DENABLE_USB_IDS_DOWNLOAD=OFF -DCMAKE_C_COMPILER=gcc-10 -DCMAKE_CXX_COMPILER=g++-10
|
|
||||||
if: ${{ matrix.debug-options == 'ALL_DEBUG' }}
|
|
||||||
- name: Create build environment
|
|
||||||
working-directory: ${{ github.workspace }}/Build
|
|
||||||
# Note that we do not set BUILD_LAGOM for the normal debug build
|
|
||||||
# We build and run the Lagom tests in a separate job, and sanitizer builds take a good while longer than non-sanitized.
|
|
||||||
run: cmake .. -GNinja -DSERENITY_ARCH=${{ matrix.arch }} -DUSE_CLANG_TOOLCHAIN=${{ matrix.compiler == 'Clang' }} -DENABLE_UNDEFINED_SANITIZER=ON -DENABLE_PCI_IDS_DOWNLOAD=OFF -DENABLE_USB_IDS_DOWNLOAD=OFF -DCMAKE_C_COMPILER=gcc-10 -DCMAKE_CXX_COMPILER=g++-10
|
|
||||||
if: ${{ matrix.debug-options == 'NORMAL_DEBUG' }}
|
|
||||||
|
|
||||||
# === ACTUALLY BUILD ===
|
- name: Toolchain cache
|
||||||
|
# TODO: Change the version to the released version when https://github.com/actions/cache/pull/489 (or 571) is merged.
|
||||||
|
uses: actions/cache@03e00da99d75a2204924908e1cca7902cafce66b
|
||||||
|
env:
|
||||||
|
CACHE_SKIP_SAVE: ${{ github.event_name == 'pull_request' }}
|
||||||
|
with:
|
||||||
|
path: ${{ github.workspace }}/Toolchain/Cache/
|
||||||
|
# This assumes that *ALL* LibC and LibPthread headers have an impact on the Toolchain.
|
||||||
|
# This is wrong, and causes more Toolchain rebuilds than necessary.
|
||||||
|
# However, we want to avoid false cache hits at all costs.
|
||||||
|
key: ${{ runner.os }}-toolchain-${{ matrix.arch }}-${{ steps.stamps.outputs.libc_headers }}
|
||||||
|
|
||||||
- name: Build Serenity and Tests
|
- name: Restore or regenerate Toolchain
|
||||||
working-directory: ${{ github.workspace }}/Build
|
run: TRY_USE_LOCAL_TOOLCHAIN=y ARCH="${{ matrix.arch }}" ${{ github.workspace }}/Toolchain/BuildIt.sh
|
||||||
run: cmake --build .
|
|
||||||
- name: Show ccache stats after build
|
|
||||||
run: ccache -s
|
|
||||||
- name: Lint (Phase 2/2)
|
|
||||||
working-directory: ${{ github.workspace }}/Meta
|
|
||||||
run: ./check-symbols.sh
|
|
||||||
|
|
||||||
- name: Create Serenity Rootfs
|
- name: ccache(1) cache
|
||||||
if: ${{ matrix.debug-options == 'NORMAL_DEBUG'}}
|
# Pull the ccache *after* building the toolchain, in case building the Toolchain somehow interferes.
|
||||||
working-directory: ${{ github.workspace }}/Build
|
# TODO: Change the version to the released version when https://github.com/actions/cache/pull/489 (or 571) is merged.
|
||||||
run: ninja install && ninja image
|
uses: actions/cache@03e00da99d75a2204924908e1cca7902cafce66b
|
||||||
|
env:
|
||||||
|
CACHE_SKIP_SAVE: ${{ github.event_name == 'pull_request' }}
|
||||||
|
with:
|
||||||
|
path: /home/runner/.ccache
|
||||||
|
# If you're here because ccache broke (it never should), increment matrix.ccache-mark.
|
||||||
|
# We want to always reuse the last cache, but upload a new one.
|
||||||
|
# This is achieved by using the "prefix-timestamp" format,
|
||||||
|
# and permitting the restore-key "prefix-" without specifying a timestamp.
|
||||||
|
# For this trick to work, the timestamp *must* come last, and it *must* be missing in 'restore-keys'.
|
||||||
|
key: ${{ runner.os }}-ccache-${{ matrix.arch }}-v${{ matrix.ccache-mark }}-D${{ matrix.debug-options }}-toolchain_${{steps.stamps.outputs.libc_headers}}-time${{ steps.stamps.outputs.time }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-ccache-${{ matrix.arch }}-v${{ matrix.ccache-mark }}-D${{ matrix.debug-options }}-toolchain_${{steps.stamps.outputs.libc_headers}}-
|
||||||
|
|
||||||
- name: Run On-Target Tests
|
- name: Show ccache stats before build and configure
|
||||||
if: ${{ matrix.debug-options == 'NORMAL_DEBUG'}}
|
run: |
|
||||||
working-directory: ${{ github.workspace }}/Build
|
# We only have 5 GiB of cache available *in total*. Beyond that, GitHub deletes caches.
|
||||||
env:
|
# Currently, we use about 130 MB for the two toolchains (i686 & x86_64), and four ccache caches:
|
||||||
SERENITY_QEMU_CPU: "max,vmx=off"
|
# Two with ALL_DEBUG (i686 & x86_64) and two with NORMAL_DEBUG (i686 & x86_64).
|
||||||
SERENITY_KERNEL_CMDLINE: "boot_mode=self-test"
|
# Therefore, using 1.25 GB or more per cache causes disaster.
|
||||||
SERENITY_RUN: "ci"
|
# Building from scratch fills the ccache cache from 0 to about 0.7 GB, and after compression it comes out to
|
||||||
run: |
|
# about 0.25 GB, so 1.5 GB (0.5GB after compression) should be plenty, all while comfortly fitting in the cache.
|
||||||
echo "::group::ninja run # Qemu output"
|
ccache -M 1500M
|
||||||
ninja run
|
ccache -s
|
||||||
echo "::endgroup::"
|
- name: Create build directory
|
||||||
echo "::group::Verify Output File"
|
run: |
|
||||||
mkdir fsmount
|
mkdir -p ${{ github.workspace }}/Build
|
||||||
sudo mount -t ext2 -o loop,rw _disk_image fsmount
|
mkdir -p ${{ github.workspace }}/Build/UCD
|
||||||
echo "Results: "
|
- name: UnicodeData cache
|
||||||
sudo cat fsmount/home/anon/test-results.log
|
# TODO: Change the version to the released version when https://github.com/actions/cache/pull/489 (or 571) is merged.
|
||||||
if ! sudo grep -q "Failed: 0" fsmount/home/anon/test-results.log
|
uses: actions/cache@03e00da99d75a2204924908e1cca7902cafce66b
|
||||||
then
|
with:
|
||||||
echo "::error :^( Tests failed, failing job"
|
path: ${{ github.workspace }}/Build/UCD
|
||||||
exit 1
|
key: UnicodeData-${{ hashFiles('Userland/Libraries/LibUnicode/unicode_data.cmake') }}
|
||||||
fi
|
- name: Create build environment with extra debug options
|
||||||
echo "::endgroup::"
|
working-directory: ${{ github.workspace }}/Build
|
||||||
timeout-minutes: 60
|
# Build the entire project with all available debug options turned on, to prevent code rot.
|
||||||
|
# However, it is unweildy and slow to run tests with them enabled, so we will build twice.
|
||||||
|
run: cmake .. -GNinja -DSERENITY_ARCH=${{ matrix.arch }} -DBUILD_LAGOM=ON -DENABLE_ALL_DEBUG_FACILITIES=ON -DENABLE_PCI_IDS_DOWNLOAD=OFF -DENABLE_USB_IDS_DOWNLOAD=OFF -DCMAKE_C_COMPILER=gcc-10 -DCMAKE_CXX_COMPILER=g++-10
|
||||||
|
if: ${{ matrix.debug-options == 'ALL_DEBUG' }}
|
||||||
|
- name: Create build environment
|
||||||
|
working-directory: ${{ github.workspace }}/Build
|
||||||
|
# Note that we do not set BUILD_LAGOM for the normal debug build
|
||||||
|
# We build and run the Lagom tests in a separate job, and sanitizer builds take a good while longer than non-sanitized.
|
||||||
|
run: cmake .. -GNinja -DSERENITY_ARCH=${{ matrix.arch }} -DENABLE_UNDEFINED_SANITIZER=ON -DENABLE_PCI_IDS_DOWNLOAD=OFF -DENABLE_USB_IDS_DOWNLOAD=OFF -DCMAKE_C_COMPILER=gcc-10 -DCMAKE_CXX_COMPILER=g++-10
|
||||||
|
if: ${{ matrix.debug-options == 'NORMAL_DEBUG' }}
|
||||||
|
|
||||||
- name: Print Target Logs
|
# === ACTUALLY BUILD ===
|
||||||
# Extremely useful if Serenity hangs trying to run one of the tests
|
|
||||||
if: ${{ !cancelled() && matrix.debug-options == 'NORMAL_DEBUG'}}
|
- name: Build Serenity and Tests
|
||||||
working-directory: ${{ github.workspace }}/Build
|
working-directory: ${{ github.workspace }}/Build
|
||||||
run: '[ ! -e debug.log ] || cat debug.log'
|
run: cmake --build .
|
||||||
|
- name: Show ccache stats after build
|
||||||
|
run: ccache -s
|
||||||
|
- name: Lint (Phase 2/2)
|
||||||
|
working-directory: ${{ github.workspace }}/Meta
|
||||||
|
run: ./check-symbols.sh
|
||||||
|
|
||||||
|
- name: Create Serenity Rootfs
|
||||||
|
if: ${{ matrix.debug-options == 'NORMAL_DEBUG'}}
|
||||||
|
working-directory: ${{ github.workspace }}/Build
|
||||||
|
run: ninja install && ninja image
|
||||||
|
|
||||||
|
- name: Run On-Target Tests
|
||||||
|
if: ${{ matrix.debug-options == 'NORMAL_DEBUG'}}
|
||||||
|
working-directory: ${{ github.workspace }}/Build
|
||||||
|
env:
|
||||||
|
SERENITY_QEMU_CPU: "max,vmx=off"
|
||||||
|
SERENITY_KERNEL_CMDLINE: "boot_mode=self-test"
|
||||||
|
SERENITY_RUN: "ci"
|
||||||
|
run: |
|
||||||
|
echo "::group::ninja run # Qemu output"
|
||||||
|
ninja run
|
||||||
|
echo "::endgroup::"
|
||||||
|
echo "::group::Verify Output File"
|
||||||
|
mkdir fsmount
|
||||||
|
sudo mount -t ext2 -o loop,rw _disk_image fsmount
|
||||||
|
echo "Results: "
|
||||||
|
sudo cat fsmount/home/anon/test-results.log
|
||||||
|
if ! sudo grep -q "Failed: 0" fsmount/home/anon/test-results.log
|
||||||
|
then
|
||||||
|
echo "::error :^( Tests failed, failing job"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "::endgroup::"
|
||||||
|
timeout-minutes: 60
|
||||||
|
|
||||||
|
- name: Print Target Logs
|
||||||
|
# Extremely useful if Serenity hangs trying to run one of the tests
|
||||||
|
if: ${{ !cancelled() && matrix.debug-options == 'NORMAL_DEBUG'}}
|
||||||
|
working-directory: ${{ github.workspace }}/Build
|
||||||
|
run: '[ ! -e debug.log ] || cat debug.log'
|
||||||
|
|
||||||
build_and_test_lagom:
|
build_and_test_lagom:
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue