mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2024-11-17 01:51:00 +03:00
d7ab2816ee
On failure attempt to include the most relevant portions of the ztest logs in the CI output. This full logs are still available for download but often a backtrace and the last output is enough. Install libunwind to improve the odds of a useful backtrace. Reviewed-by: Tino Reichardt <milky-zfs@mcmilk.de> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #16573
78 lines
2.0 KiB
YAML
78 lines
2.0 KiB
YAML
name: zloop
|
|
|
|
on:
|
|
push:
|
|
pull_request:
|
|
|
|
concurrency:
|
|
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
zloop:
|
|
runs-on: ubuntu-24.04
|
|
env:
|
|
TEST_DIR: /var/tmp/zloop
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
with:
|
|
ref: ${{ github.event.pull_request.head.sha }}
|
|
- name: Install dependencies
|
|
run: |
|
|
sudo apt-get purge -y snapd google-chrome-stable firefox
|
|
ONLY_DEPS=1 .github/workflows/scripts/qemu-3-deps.sh ubuntu24
|
|
- name: Autogen.sh
|
|
run: |
|
|
sed -i '/DEBUG_CFLAGS="-Werror"/s/^/#/' config/zfs-build.m4
|
|
./autogen.sh
|
|
- name: Configure
|
|
run: |
|
|
./configure --prefix=/usr --enable-debug --enable-debuginfo \
|
|
--enable-asan --enable-ubsan \
|
|
--enable-debug-kmem --enable-debug-kmem-tracking
|
|
- name: Make
|
|
run: |
|
|
make -j$(nproc)
|
|
- name: Install
|
|
run: |
|
|
sudo make install
|
|
sudo depmod
|
|
sudo modprobe zfs
|
|
- name: Tests
|
|
run: |
|
|
sudo mkdir -p $TEST_DIR
|
|
# run for 10 minutes or at most 6 iterations for a maximum runner
|
|
# time of 60 minutes.
|
|
sudo /usr/share/zfs/zloop.sh -t 600 -I 6 -l -m 1 -- -T 120 -P 60
|
|
- name: Prepare artifacts
|
|
if: failure()
|
|
run: |
|
|
sudo chmod +r -R $TEST_DIR/
|
|
- name: Ztest log
|
|
if: failure()
|
|
run: |
|
|
grep -B10 -A1000 'ASSERT' $TEST_DIR/*/ztest.out || tail -n 1000 $TEST_DIR/*/ztest.out
|
|
- name: Gdb log
|
|
if: failure()
|
|
run: |
|
|
sed -n '/Backtraces (full)/q;p' $TEST_DIR/*/ztest.gdb
|
|
- name: Zdb log
|
|
if: failure()
|
|
run: |
|
|
cat $TEST_DIR/*/ztest.zdb
|
|
- uses: actions/upload-artifact@v4
|
|
if: failure()
|
|
with:
|
|
name: Logs
|
|
path: |
|
|
/var/tmp/zloop/*/
|
|
!/var/tmp/zloop/*/vdev/
|
|
if-no-files-found: ignore
|
|
- uses: actions/upload-artifact@v4
|
|
if: failure()
|
|
with:
|
|
name: Pool files
|
|
path: |
|
|
/var/tmp/zloop/*/vdev/
|
|
if-no-files-found: ignore
|