#!/bin/bash # # SPDX-License-Identifier: GPL-2.0-only # # Copyright (C) 2019 Simon Marchi # 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 SH_TAP=1 source "$UTILSSH" NUM_TESTS=15 plan_tests $NUM_TESTS data_dir="${BT_TESTS_DATADIR}/cli/query" plugin_dir="${data_dir}" stdout_expected_file=$(mktemp -t test_cli_query_stdout_xpected.XXXXXX) stdout_file=$(mktemp -t test_cli_query_stdout.XXXXXX) stderr_file=$(mktemp -t test_cli_query_stderr.XXXXXX) expect_success() { local expected_str="$1" shift 1 local args=("$@") echo "$expected_str" > "$stdout_expected_file" bt_diff_cli "$stdout_expected_file" /dev/null \ --plugin-path "$plugin_dir" \ query "src.query.SourceWithQueryThatPrintsParams" \ "${args[@]}" ok "$?" "${args[*]}" } expect_failure() { local expected_str="$1" shift 1 local args=("$@") local test_name="${args[*]}" echo -n > "$stdout_expected_file" bt_cli "$stdout_file" "$stderr_file" \ --plugin-path "$plugin_dir" \ query \ "${args[@]}" isnt "$?" 0 "${test_name}: exit code is not 0" bt_diff /dev/null "$stdout_file" ok "$?" "${test_name}: nothing output on stout" # Ensure that a CLI error stack is printed (and that babeltrace doesn't # abort before that). grep --silent "^ERROR: " "${stderr_file}" ok $? "${test_name}: babeltrace produces an error stack" grep --silent "${expected_str}" "${stderr_file}" ok "$?" "${test_name}: expect \`${expected_str}\` error message on stderr" } expect_success 'the-object:{}' \ 'the-object' expect_success "the-object:{a=2}" \ 'the-object' -p 'a=2' # Check that -p parameters are processed in order. expect_success "the-object:{a=3, ben=kin, voyons=donc}" \ 'the-object' -p 'a=2,ben=kin' -p 'voyons=donc,a=3' # Failure inside the component class' query method. expect_failure "ValueError: catastrophic failure" \ 'src.query.SourceWithQueryThatPrintsParams' 'please-fail' '-p' 'a=2' # Non-existent component class. expect_failure 'Cannot find component class: plugin-name="query", comp-cls-name="NonExistentSource", comp-cls-type=1' \ 'src.query.NonExistentSource' 'the-object' '-p' 'a=2' # Wrong parameter syntax. expect_failure "Invalid format for --params option's argument:" \ 'src.query.SourceWithQueryThatPrintsParams' 'please-fail' '-p' 'a=3,' rm -f "$stdout_expected_file" rm -f "$stdout_file" rm -f "$stderr_file"