summaryrefslogtreecommitdiff
path: root/test/TEST-31-OOMPOLICY/testsuite.sh
blob: f0b1470d42e69df08a8eac78f79599ebbf05cb46 (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
#!/bin/bash
# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
# ex: ts=8 sw=4 sts=4 et filetype=sh
set -ex
set -o pipefail

# Let's run this test only if the "memory.oom.group" cgroupfs attribute
# exists. This test is a bit too strict, since the "memory.events"/"oom_kill"
# logic has been around since a longer time than "memory.oom.group", but it's
# an easier thing to test for, and also: let's not get confused by older
# kernels where the concept was still new.

if test -f /sys/fs/cgroup/system.slice/testsuite.service/memory.oom.group ; then

    systemd-analyze log-level debug
    systemd-analyze log-target console

    # Run a service that is guaranteed to be the first candidate for OOM killing
    systemd-run --unit=oomtest.service -p Type=exec -p OOMScoreAdjust=1000 -p OOMPolicy=stop -p MemoryAccounting=yes /bin/sleep infinity

    # Trigger an OOM killer run
    echo 1 > /proc/sys/kernel/sysrq
    echo f > /proc/sysrq-trigger

    while : ; do
        STATE=`systemctl show -p ActiveState --value oomtest.service`
        [ "$STATE" = "failed" ] && break
        sleep .5
    done

    RESULT=`systemctl show -p Result --value oomtest.service`
    test "$RESULT" = "oom-kill"

    systemd-analyze log-level info
fi

echo OK > /testok

exit 0