tests: fix shellcheck warnings in plugins/sink.ctf.fs/succeed/test_succeed
[babeltrace.git] / tests / plugins / sink.ctf.fs / succeed / test_succeed
CommitLineData
1fba7c7b
PP
1#!/bin/bash
2#
3# Copyright (C) 2019 Philippe Proulx <pproulx@efficios.com>
4#
5# This program is free software; you can redistribute it and/or
6# modify it under the terms of the GNU General Public License
7# as published by the Free Software Foundation; only version 2
8# of the License.
9#
10# This program is distributed in the hope that it will be useful,
11# but WITHOUT ANY WARRANTY; without even the implied warranty of
12# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13# GNU General Public License for more details.
14#
15# You should have received a copy of the GNU General Public License
16# along with this program; if not, write to the Free Software
17# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18
19# This test validates that a `src.ctf.fs` component successfully reads
20# specific CTF traces and creates the expected messages.
21#
22# Such CTF traces to open either exist (in `tests/ctf-traces/succeed`)
23# or are generated by this test using local trace generators.
24
25SH_TAP=1
26
27if [ "x${BT_TESTS_SRCDIR:-}" != "x" ]; then
28 UTILSSH="$BT_TESTS_SRCDIR/utils/utils.sh"
29else
30 UTILSSH="$(dirname "$0")/../../../utils/utils.sh"
31fi
32
33# shellcheck source=../../../utils/utils.sh
34source "$UTILSSH"
35
36this_dir_relative="plugins/sink.ctf.fs/succeed"
37this_dir_build="$BT_TESTS_BUILDDIR/$this_dir_relative"
38expect_dir="$BT_TESTS_DATADIR/$this_dir_relative"
45c51519 39succeed_traces="$BT_CTF_TRACES_PATH/succeed"
1fba7c7b 40
45c51519
PP
41test_ctf_single() {
42 local name="$1"
43 local in_trace_dir="$2"
72c6811a
SM
44 local temp_out_trace_dir
45
46 temp_out_trace_dir="$(mktemp -d)"
1fba7c7b
PP
47
48 diag "Converting trace '$name' to CTF through 'sink.ctf.fs'"
45c51519 49 "$BT_TESTS_BT2_BIN" >/dev/null "$in_trace_dir" -o ctf -w "$temp_out_trace_dir"
1fba7c7b
PP
50 ret=$?
51 ok $ret "'sink.ctf.fs' component succeeds with input trace '$name'"
52 converted_test_name="Converted trace '$name' gives the expected output"
53
54 if [ $ret -eq 0 ]; then
53cc240b
MJ
55 bt_diff_details_ctf_single "$expect_dir/trace-$name.expect" \
56 "$temp_out_trace_dir" \
45c51519 57 '-p' 'with-uuid=no,with-trace-name=no,with-stream-name=no'
1fba7c7b
PP
58 ok $? "$converted_test_name"
59 else
60 fail "$converted_test_name"
61 fi
62
1fba7c7b
PP
63 rm -rf "$temp_out_trace_dir"
64}
65
45c51519
PP
66test_ctf_existing_single() {
67 local name="$1"
68 local trace_dir="$succeed_traces/$name"
69
70 test_ctf_single "$name" "$trace_dir"
71}
72
73test_ctf_gen_single() {
74 local name="$1"
72c6811a
SM
75 local temp_gen_trace_dir
76
77 temp_gen_trace_dir="$(mktemp -d)"
45c51519
PP
78
79 diag "Generating trace '$name'"
80
81 if ! "$this_dir_build/gen-trace-$name" "$temp_gen_trace_dir"; then
82 # this is not part of the test itself; it must not fail
83 echo "ERROR: \"$this_dir_build/gen-trace-$name" "$temp_gen_trace_dir\" failed" >&2
84 rm -rf "$temp_gen_trace_dir"
85 exit 1
86 fi
87
88 test_ctf_single "$name" "$temp_gen_trace_dir"
89 rm -rf "$temp_gen_trace_dir"
90}
91
92plan_tests 14
1fba7c7b
PP
93
94test_ctf_gen_single float
95test_ctf_gen_single double
45c51519
PP
96test_ctf_existing_single meta-variant-no-underscore
97test_ctf_existing_single meta-variant-one-underscore
98test_ctf_existing_single meta-variant-reserved-keywords
99test_ctf_existing_single meta-variant-same-with-underscore
100test_ctf_existing_single meta-variant-two-underscores
This page took 0.040423 seconds and 4 git commands to generate.