3 # Copyright (C) 2014 David Goulet <dgoulet@efficios.com>
5 # SPDX-License-Identifier: LGPL-2.1-only
7 TEST_DESC
="Save session(s)"
10 TESTDIR
=$CURDIR/..
/..
/..
/
12 SESSION_NAME
="save-42"
13 CHANNEL_NAME
="chan-save"
14 EVENT_NAME
="tp:tptest"
16 DIR
=$
(readlink
-f $TESTDIR)
20 source $TESTDIR/utils
/utils.sh
22 # MUST set TESTDIR before calling those functions
25 print_test_banner
"$TEST_DESC"
28 function save_lttng_fail
()
33 $TESTDIR/..
/src
/bin
/lttng
/$LTTNG_BIN save
$sess_name $opts >/dev
/null
2>&1
35 ok
0 "Session failed to be saved. Expected!"
37 ok
1 "Session has been saved. NOT expected!"
41 function is_session_saved
()
46 [ -f "$path/$name.lttng" ];
47 ok $?
"Session $name.lttng file found!"
50 function test_basic_save
()
52 diag
"Test basic save"
54 create_lttng_session_ok
$SESSION_NAME $TRACE_PATH
55 enable_ust_lttng_channel_ok
$SESSION_NAME $CHANNEL_NAME
56 enable_ust_lttng_event_ok
$SESSION_NAME $EVENT_NAME $CHANNEL_NAME
57 lttng_track_ok
"-p 666 -u -s $SESSION_NAME"
59 lttng_save
$SESSION_NAME "-o $TRACE_PATH"
61 is_session_saved
$TRACE_PATH $SESSION_NAME
63 destroy_lttng_session_ok
$SESSION_NAME
66 function test_basic_save_all
()
68 diag
"Test basic save all"
70 create_lttng_session_ok
$SESSION_NAME-1 $TRACE_PATH
71 create_lttng_session_ok
$SESSION_NAME-2 $TRACE_PATH
72 create_lttng_session_ok
$SESSION_NAME-3 $TRACE_PATH
74 enable_ust_lttng_channel_ok
$SESSION_NAME-1 $CHANNEL_NAME
75 enable_ust_lttng_channel_ok
$SESSION_NAME-2 $CHANNEL_NAME
76 enable_ust_lttng_channel_ok
$SESSION_NAME-3 $CHANNEL_NAME
78 enable_ust_lttng_event_ok
$SESSION_NAME-1 $EVENT_NAME $CHANNEL_NAME
79 enable_ust_lttng_event_ok
$SESSION_NAME-2 $EVENT_NAME $CHANNEL_NAME
80 enable_ust_lttng_event_ok
$SESSION_NAME-3 $EVENT_NAME $CHANNEL_NAME
82 lttng_track_ok
"-p 666 -u -s $SESSION_NAME-1"
83 lttng_track_ok
"-p 666 -u -s $SESSION_NAME-2"
84 lttng_track_ok
"-p 666 -u -s $SESSION_NAME-3"
86 lttng_save
"" "-a -o $TRACE_PATH"
88 is_session_saved
$TRACE_PATH $SESSION_NAME-1
89 is_session_saved
$TRACE_PATH $SESSION_NAME-2
90 is_session_saved
$TRACE_PATH $SESSION_NAME-3
92 destroy_lttng_session_ok
$SESSION_NAME-1
93 destroy_lttng_session_ok
$SESSION_NAME-2
94 destroy_lttng_session_ok
$SESSION_NAME-3
97 function test_overwrite
()
99 diag
"Test overwrite session file"
101 create_lttng_session_ok
$SESSION_NAME $TRACE_PATH
102 enable_ust_lttng_channel_ok
$SESSION_NAME $CHANNEL_NAME
103 enable_ust_lttng_event_ok
$SESSION_NAME $EVENT_NAME $CHANNEL_NAME
105 lttng_save
$SESSION_NAME "-o $TRACE_PATH"
107 is_session_saved
$TRACE_PATH $SESSION_NAME
109 destroy_lttng_session_ok
$SESSION_NAME
111 # Create a new session with same name so we can force the overwrite
112 create_lttng_session_ok
$SESSION_NAME $TRACE_PATH
113 enable_ust_lttng_channel_ok
$SESSION_NAME $CHANNEL_NAME
114 enable_ust_lttng_event_ok
$SESSION_NAME $EVENT_NAME $CHANNEL_NAME
117 save_lttng_fail
$SESSION_NAME "-o $TRACE_PATH"
119 # This one MUST succeed
120 lttng_save
$SESSION_NAME "-f -o $TRACE_PATH"
122 is_session_saved
$TRACE_PATH $SESSION_NAME
124 destroy_lttng_session_ok
$SESSION_NAME
135 for fct_test
in ${TESTS[@]};
137 TRACE_PATH
=$
(mktemp
-d -t tmp.test_save_trace_path.XXXXXX
)
140 if [ $?
-ne 0 ]; then
143 # Only delete if successful