Test: save/load: pid_tracker basic test
[lttng-tools.git] / tests / regression / tools / save-load / test_save
CommitLineData
e02b109b
DG
1#!/bin/bash
2#
3# Copyright (C) - 2014 David Goulet <dgoulet@efficios.com>
4#
5# This library is free software; you can redistribute it and/or modify it under
6# the terms of the GNU Lesser General Public License as published by the Free
7# Software Foundation; version 2.1 of the License.
8#
9# This library is distributed in the hope that it will be useful, but WITHOUT
10# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
11# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
12# details.
13#
14# You should have received a copy of the GNU Lesser General Public License
15# along with this library; if not, write to the Free Software Foundation, Inc.,
16# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
18TEST_DESC="Save session(s)"
19
20CURDIR=$(dirname $0)/
21TESTDIR=$CURDIR/../../../
22SESSIOND_BIN="lttng-sessiond"
23RELAYD_BIN="lttng-relayd"
24LTTNG_BIN="lttng"
25
26SESSION_NAME="save-42"
27CHANNEL_NAME="chan-save"
28EVENT_NAME="tp:tptest"
29
30DIR=$(readlink -f $TESTDIR)
31
722f854b 32NUM_TESTS=41
e02b109b
DG
33
34source $TESTDIR/utils/utils.sh
35
36# MUST set TESTDIR before calling those functions
37plan_tests $NUM_TESTS
38
39print_test_banner "$TEST_DESC"
40
41# Expected to fail
42function save_lttng_fail()
43{
44 local sess_name=$1
45 local opts=$2
46
47 $TESTDIR/../src/bin/lttng/$LTTNG_BIN save $sess_name $opts >/dev/null 2>&1
48 if [ $? -ne 0 ]; then
49 ok 0 "Session failed to be saved. Expected!"
50 else
51 ok 1 "Session has been saved. NOT expected!"
52 fi
53}
54
55function is_session_saved()
56{
57 local path=$1
58 local name=$2
59
60 [ -f "$path/$name.lttng" ];
61 ok $? "Session $name.lttng file found!"
62}
63
64function test_basic_save()
65{
66 diag "Test basic save"
67
bf6ae429 68 create_lttng_session_ok $SESSION_NAME $TRACE_PATH
827caf52 69 enable_ust_lttng_channel_ok $SESSION_NAME $CHANNEL_NAME
c4926bb5 70 enable_ust_lttng_event_ok $SESSION_NAME $EVENT_NAME $CHANNEL_NAME
722f854b 71 lttng_track_ok "-p 666 -u -s $SESSION_NAME"
e02b109b
DG
72
73 lttng_save $SESSION_NAME "-o $TRACE_PATH"
74
75 is_session_saved $TRACE_PATH $SESSION_NAME
76
67b4c664 77 destroy_lttng_session_ok $SESSION_NAME
e02b109b
DG
78}
79
80function test_basic_save_all()
81{
82 diag "Test basic save all"
83
bf6ae429
JR
84 create_lttng_session_ok $SESSION_NAME-1 $TRACE_PATH
85 create_lttng_session_ok $SESSION_NAME-2 $TRACE_PATH
86 create_lttng_session_ok $SESSION_NAME-3 $TRACE_PATH
e02b109b 87
827caf52
JR
88 enable_ust_lttng_channel_ok $SESSION_NAME-1 $CHANNEL_NAME
89 enable_ust_lttng_channel_ok $SESSION_NAME-2 $CHANNEL_NAME
90 enable_ust_lttng_channel_ok $SESSION_NAME-3 $CHANNEL_NAME
e02b109b 91
c4926bb5
JR
92 enable_ust_lttng_event_ok $SESSION_NAME-1 $EVENT_NAME $CHANNEL_NAME
93 enable_ust_lttng_event_ok $SESSION_NAME-2 $EVENT_NAME $CHANNEL_NAME
94 enable_ust_lttng_event_ok $SESSION_NAME-3 $EVENT_NAME $CHANNEL_NAME
e02b109b 95
722f854b
JR
96 lttng_track_ok "-p 666 -u -s $SESSION_NAME-1"
97 lttng_track_ok "-p 666 -u -s $SESSION_NAME-2"
98 lttng_track_ok "-p 666 -u -s $SESSION_NAME-3"
99
e02b109b
DG
100 lttng_save "" "-a -o $TRACE_PATH"
101
102 is_session_saved $TRACE_PATH $SESSION_NAME-1
103 is_session_saved $TRACE_PATH $SESSION_NAME-2
104 is_session_saved $TRACE_PATH $SESSION_NAME-3
105
67b4c664
JR
106 destroy_lttng_session_ok $SESSION_NAME-1
107 destroy_lttng_session_ok $SESSION_NAME-2
108 destroy_lttng_session_ok $SESSION_NAME-3
e02b109b
DG
109}
110
111function test_overwrite()
112{
113 diag "Test overwrite session file"
114
bf6ae429 115 create_lttng_session_ok $SESSION_NAME $TRACE_PATH
827caf52 116 enable_ust_lttng_channel_ok $SESSION_NAME $CHANNEL_NAME
c4926bb5 117 enable_ust_lttng_event_ok $SESSION_NAME $EVENT_NAME $CHANNEL_NAME
e02b109b
DG
118
119 lttng_save $SESSION_NAME "-o $TRACE_PATH"
120
121 is_session_saved $TRACE_PATH $SESSION_NAME
122
67b4c664 123 destroy_lttng_session_ok $SESSION_NAME
e02b109b
DG
124
125 # Create a new session with same name so we can force the overwrite
bf6ae429 126 create_lttng_session_ok $SESSION_NAME $TRACE_PATH
827caf52 127 enable_ust_lttng_channel_ok $SESSION_NAME $CHANNEL_NAME
c4926bb5 128 enable_ust_lttng_event_ok $SESSION_NAME $EVENT_NAME $CHANNEL_NAME
e02b109b
DG
129
130 # This one MUST fail
131 save_lttng_fail $SESSION_NAME "-o $TRACE_PATH"
132
133 # This one MUST succeed
134 lttng_save $SESSION_NAME "-f -o $TRACE_PATH"
135
136 is_session_saved $TRACE_PATH $SESSION_NAME
137
67b4c664 138 destroy_lttng_session_ok $SESSION_NAME
e02b109b
DG
139}
140
141start_lttng_sessiond
142
143TESTS=(
144 test_basic_save
145 test_basic_save_all
146 test_overwrite
147)
148
149for fct_test in ${TESTS[@]};
150do
151 TRACE_PATH=$(mktemp -d)
152
153 ${fct_test}
154 if [ $? -ne 0 ]; then
155 break;
156 fi
157 # Only delete if successful
edb62ef5 158 rm -rf $TRACE_PATH
e02b109b
DG
159done
160
161stop_lttng_sessiond
This page took 0.030578 seconds and 4 git commands to generate.