#!/bin/bash # # Copyright (C) 2015 Julien Desfossez # # This program is free software; you can redistribute it and/or modify it # under the terms of the GNU General Public License, version 2 only, as # published by the Free Software Foundation. # # This program is distributed in the hope that it will be useful, but WITHOUT # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for # more details. # # You should have received a copy of the GNU General Public License along with # this program; if not, write to the Free Software Foundation, Inc., 51 # Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. SH_TAP=1 if [ "x${BT_TESTS_SRCDIR:-}" != "x" ]; then UTILSSH="$BT_TESTS_SRCDIR/utils/utils.sh" else UTILSSH="$(dirname "$0")/../utils/utils.sh" fi # shellcheck source=../utils/utils.sh source "$UTILSSH" plan_tests 20 stdout=$(mktemp -t test_intersection_stdout.XXXXXX) stderr=$(mktemp -t test_intersection_stderr.XXXXXX) test_intersect() { local trace="$1" local totalevents="$2" local intersect="$3" local cnt bt_cli "${stdout}" "/dev/null" "${trace}" ok $? "run without --stream-intersection" cnt=$(wc -l < "${stdout}") test "${cnt// /}" = "$totalevents" ok $? "$totalevents events in the whole trace" bt_cli "${stdout}" "/dev/null" --stream-intersection "${trace}" ok $? "run with --stream-intersection" cnt=$(wc -l < "${stdout}") test "${cnt// /}" = "$intersect" ok $? "$intersect events in streams intersecting" } test_intersect_fails() { local trace="$1" local totalevents="$2" local expected_error_message="$3" bt_cli "${stdout}" "/dev/null" "${trace}" ok $? "run without --stream-intersection" cnt=$(wc -l < "${stdout}") test "${cnt// /}" = "$totalevents" ok $? "$totalevents events in the whole trace" bt_cli "${stdout}" "${stderr}" --stream-intersection "${trace}" isnt "$?" 0 "run with --stream-intersection fails" grep --silent "${expected_error_message}" "${stderr}" ok $? "stderr contains expected error message" } diag "Test the stream intersection feature" diag "2 streams offsetted with 3 packets intersecting" test_intersect "${BT_CTF_TRACES_PATH}/intersection/3eventsintersect" 8 3 diag "2 streams offsetted with 3 packets intersecting (exchanged file names)" test_intersect "${BT_CTF_TRACES_PATH}/intersection/3eventsintersectreverse" 8 3 diag "Only 1 stream" test_intersect "${BT_CTF_TRACES_PATH}/intersection/onestream" 3 3 diag "No intersection between 2 streams" test_intersect_fails "${BT_CTF_TRACES_PATH}/intersection/nointersect" 6 \ "Trimming time range's beginning time is greater than end time: " diag "No stream at all" test_intersect_fails "${BT_CTF_TRACES_PATH}/intersection/nostream" 0 \ "Trace has no streams: " rm -f "${stdout}" "${stderr}"