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