SoW-2019-0002: Dynamic Snapshot
[lttng-tools.git] / tests / regression / tools / notification / test_notification_kernel_buffer_usage
CommitLineData
854382b8
JR
1#!/bin/bash
2#
9d16b343 3# Copyright (C) 2017 Jonathan Rajotte-Julien <jonathan.rajotte-julien@efficios.com>
854382b8 4#
9d16b343 5# SPDX-License-Identifier: LGPL-2.1-only
854382b8
JR
6
7CURDIR=$(dirname $0)/
8TESTDIR=$CURDIR/../../../
9
345ed219
JR
10TMPDIR=$(mktemp -d)
11
854382b8 12#This is needed since the testpoint create a pipe with the consumerd type suffixed
345ed219 13TESTPOINT_BASE_PATH=$(readlink -f "$TMPDIR/lttng.t_p_n")
854382b8 14TESTPOINT_PIPE_PATH=$(mktemp -u "${TESTPOINT_BASE_PATH}.XXXXXX")
854382b8
JR
15TESTPOINT=$(readlink -f ${CURDIR}/.libs/libpause_consumer.so)
16
17
18TESTAPP_PATH="$TESTDIR/utils/testapp"
19TESTAPP_NAME="gen-ust-events"
20TESTAPP_BIN="$TESTAPP_PATH/$TESTAPP_NAME/$TESTAPP_NAME"
345ed219 21TESTAPP_STATE_PATH=$(mktemp -u "$TMPDIR/application_state.XXXXXXXXXX")
854382b8 22
1831ae68
FD
23SYSCALL_TESTAPP_NAME="gen-syscall-events"
24SYSCALL_TESTAPP_BIN="$TESTAPP_PATH/$SYSCALL_TESTAPP_NAME/$SYSCALL_TESTAPP_NAME"
25
26USERSPACE_PROBE_ELF_TESTAPP_NAME="userspace-probe-elf-binary"
27USERSPACE_PROBE_ELF_TESTAPP_BIN="$TESTAPP_PATH/$USERSPACE_PROBE_ELF_TESTAPP_NAME/.libs/$USERSPACE_PROBE_ELF_TESTAPP_NAME"
854382b8
JR
28
29SESSION_NAME="my_session"
30CHANNEL_NAME="my_channel"
31
32TRACE_PATH=$(mktemp -d)
33PAGE_SIZE=$(getconf PAGE_SIZE)
34
35DIR=$(readlink -f $TESTDIR)
36NUM_TESTS=104
37
38source $TESTDIR/utils/utils.sh
39
cb723729 40function kernel_event_generator_toggle_state
854382b8
JR
41{
42 kernel_event_generator_suspended=$((kernel_event_generator_suspended==0))
1831ae68 43}
854382b8 44
1831ae68
FD
45function generate_filter_events
46{
47 /bin/echo -n "10" > /proc/lttng-test-filter-event 2> /dev/null
854382b8 48}
1831ae68 49
854382b8
JR
50function kernel_event_generator
51{
1831ae68
FD
52 command_to_run=$1
53 state_file=$2
854382b8 54 kernel_event_generator_suspended=0
cb723729 55 trap kernel_event_generator_toggle_state SIGUSR1
3be453c9 56
854382b8
JR
57 while (true); do
58 if [[ $kernel_event_generator_suspended -eq "1" ]]; then
59 touch $state_file
60 sleep 0.5
61 else
62 if [[ -f $state_file ]]; then
63 rm $state_file 2> /dev/null
64 fi
1831ae68 65 $command_to_run
854382b8
JR
66 fi
67 done
68}
69
1831ae68 70function test_buffer_usage_notification
854382b8 71{
1831ae68 72 local consumerd_pipe=$1
854382b8
JR
73 local event_name="lttng_test_filter_event"
74
854382b8
JR
75 create_lttng_session_notap $SESSION_NAME $TRACE_PATH
76
1831ae68
FD
77 lttng_enable_kernel_channel_notap $SESSION_NAME $CHANNEL_NAME \
78 --subbuf-size=$PAGE_SIZE
854382b8
JR
79 enable_kernel_lttng_event_notap $SESSION_NAME $event_name $CHANNEL_NAME
80
1831ae68 81 kernel_event_generator generate_filter_events $TESTAPP_STATE_PATH &
854382b8
JR
82 APP_PID=$!
83
1831ae68
FD
84 $CURDIR/notification 2 LTTNG_DOMAIN_KERNEL $APP_PID $TESTAPP_STATE_PATH \
85 $SESSION_NAME $CHANNEL_NAME ${consumerd_pipe[@]}
854382b8
JR
86
87 destroy_lttng_session_notap $SESSION_NAME
854382b8
JR
88
89 kill -9 $APP_PID
90 wait $APP_PID 2> /dev/null
1831ae68
FD
91}
92
93if [ "$(id -u)" == "0" ]; then
94 consumerd_pipe=()
854382b8 95
1831ae68
FD
96 validate_lttng_modules_present
97
98 # This is needed since the testpoint create a pipe with the consumer
99 # type suffixed.
100 for f in "$TESTPOINT_BASE_PATH"*; do
101 consumerd_pipe+=("$f")
102 done
103
104 modprobe lttng-test
105
106 LTTNG_SESSIOND_ENV_VARS="LTTNG_TESTPOINT_ENABLE=1 \
107 CONSUMER_PAUSE_PIPE_PATH=${TESTPOINT_PIPE_PATH} \
108 LD_PRELOAD=${TESTPOINT}"
854382b8 109
1831ae68
FD
110 start_lttng_sessiond_notap
111
112 test_buffer_usage_notification $consumerd_pipe
113
114 stop_lttng_sessiond_notap
854382b8
JR
115 rmmod lttng-test
116
345ed219 117 rm -rf ${consumerd_pipe[@]} 2> /dev/null
854382b8
JR
118else
119 # Kernel tests are skipped.
120 plan_tests $NUM_TESTS
121 skip 0 "Root access is needed. Skipping all kernel notification tests." $NUM_TESTS
122fi
123
124# Just in case cleanup
125rm -rf $TRACE_PATH
345ed219 126rm -rf $TMPDIR
This page took 0.041721 seconds and 5 git commands to generate.