summaryrefslogtreecommitdiffstats
path: root/test/units/testsuite-04.journal-append.sh
blob: 35f9433b8356b21ad9cf534b3ac1e745a0d6acea (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#!/usr/bin/env bash
# SPDX-License-Identifier: LGPL-2.1-or-later
set -eux
set -o pipefail

# test-journal-append corrupts the journal file by flipping a bit at a given offset and
# following it by a write to check if we handle appending messages to corrupted journals
# gracefully

TEST_JOURNAL_APPEND=/usr/lib/systemd/tests/unit-tests/manual/test-journal-append

[[ -x "$TEST_JOURNAL_APPEND" ]]

# Corrupt the first ~1024 bytes, this should be pretty quick
"$TEST_JOURNAL_APPEND" --sequential --start-offset=0 --iterations=350 --iteration-step=3

# Skip most of the test when running without acceleration, as it's excruciatingly slow
# (this shouldn't be an issue, as it should run in nspawn as well)
if ! [[ "$(systemd-detect-virt -v)" == "qemu" ]]; then
    # Corrupt the beginning of every 1K block between 1K - 32K
    for ((i = 1024; i <= (32 * 1024); i += 1024)); do
        "$TEST_JOURNAL_APPEND" --sequential --start-offset="$i" --iterations=5 --iteration-step=13
    done

    # Corrupt the beginning of every 16K block between 32K - 128K
    for ((i = (32 * 1024); i <= (256 * 1024); i += (16 * 1024))); do
        "$TEST_JOURNAL_APPEND" --sequential --start-offset="$i" --iterations=5 --iteration-step=13
    done

    # Corrupt the beginning of every 128K block between 128K - 1M
    for ((i = (128 * 1024); i <= (1 * 1024 * 1024); i += (128 * 1024))); do
        "$TEST_JOURNAL_APPEND" --sequential --start-offset="$i" --iterations=5 --iteration-step=13
    done

    # And finally the beginning of every 1M block between 1M and 8M
    for ((i = (1 * 1024 * 1024); i < (8 * 1024 * 1024); i += (1 * 1024 * 1024))); do
        "$TEST_JOURNAL_APPEND" --sequential --start-offset="$i" --iterations=5 --iteration-step=13
    done

    if [[ "$(nproc)" -ge 2 ]]; then
        # Try to corrupt random bytes throughout the journal
        "$TEST_JOURNAL_APPEND" --iterations=25
    fi
else
    "$TEST_JOURNAL_APPEND" --iterations=10
fi