211 lines
7.1 KiB
Bash
211 lines
7.1 KiB
Bash
|
#!/bin/bash
|
||
|
# vim: dict=/usr/share/beakerlib/dictionary.vim cpt=.,w,b,u,t,i,k
|
||
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
|
#
|
||
|
# runtest.sh of cli-sanity
|
||
|
# Description: does sanity on report-cli
|
||
|
# Author: Michal Nowak <mnowak@redhat.com>
|
||
|
#
|
||
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
|
#
|
||
|
# Copyright (c) 2011 Red Hat, Inc. All rights reserved.
|
||
|
#
|
||
|
# This program is free software: you can redistribute it and/or
|
||
|
# modify it under the terms of the GNU General Public License as
|
||
|
# published by the Free Software Foundation, either version 3 of
|
||
|
# the License, or (at your option) any later version.
|
||
|
#
|
||
|
# 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, see http://www.gnu.org/licenses/.
|
||
|
#
|
||
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
|
|
||
|
. /usr/share/beakerlib/beakerlib.sh
|
||
|
. ../aux/lib.sh
|
||
|
|
||
|
TEST="cli-sanity"
|
||
|
PACKAGE="abrt"
|
||
|
|
||
|
rlJournalStart
|
||
|
rlPhaseStartSetup
|
||
|
LANG=""
|
||
|
export LANG
|
||
|
|
||
|
# Since we send SIGSEGV to sleep(1) and coreutils will be unsigned.
|
||
|
rlRun "augtool set /files/etc/abrt/abrt-action-save-package-data.conf/OpenGPGCheck no" 0
|
||
|
|
||
|
check_prior_crashes
|
||
|
create_custom_event
|
||
|
rlServiceStart abrtd abrt-journal-core
|
||
|
|
||
|
TmpDir=$(mktemp -d)
|
||
|
pushd $TmpDir
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "--version"
|
||
|
rlRun "abrt-cli --version | grep 'abrt-cli'"
|
||
|
# rlAssertEquals "abrt-cli and abrt-cli RPM claim the same version" "$(abrt-cli -V | awk '{ print $2 }')" "$(rpmquery --qf='%{VERSION}' abrt-cli)"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "--help"
|
||
|
rlRun "abrt-cli --help" 0
|
||
|
rlRun "abrt-cli --help 2>&1 | grep 'Usage: abrt-cli'"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "list the same as ls"
|
||
|
abrt-cli list &> param_cmd
|
||
|
abrt-cli ls &> param_abbrev
|
||
|
rlAssertNotDiffer param_cmd param_abbrev
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "remove the same as rm"
|
||
|
abrt-cli remove &> param_cmd
|
||
|
abrt-cli rm &> param_abbrev
|
||
|
rlAssertNotDiffer param_cmd param_abbrev
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "report the same as e"
|
||
|
abrt-cli report &> param_cmd
|
||
|
abrt-cli e &> param_abbrev
|
||
|
rlAssertNotDiffer param_cmd param_abbrev
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "info the same as i"
|
||
|
abrt-cli info &> param_cmd
|
||
|
abrt-cli i &> param_abbrev
|
||
|
rlAssertNotDiffer param_cmd param_abbrev
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "status the same as st"
|
||
|
abrt-cli status &> param_cmd
|
||
|
abrt-cli st &> param_abbrev
|
||
|
rlAssertNotDiffer param_cmd param_abbrev
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "process the same as p"
|
||
|
abrt-cli process &> param_cmd
|
||
|
abrt-cli p &> param_abbrev
|
||
|
rlAssertNotDiffer param_cmd param_abbrev
|
||
|
rlPhaseEnd
|
||
|
|
||
|
|
||
|
rlPhaseStartTest "list"
|
||
|
timeout --signal=SEGV 1 sleep 10
|
||
|
wait_for_hooks
|
||
|
get_crash_path
|
||
|
|
||
|
rlRun "abrt-cli list | grep -i 'cmdline'"
|
||
|
rlRun "abrt-cli list | grep -i 'Package'"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "list -n" # list not-reported
|
||
|
rlRun "abrt-cli list -n | grep -i 'cmdline'"
|
||
|
rlRun "abrt-cli list -n | grep -i 'Package'"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "report FAKEDIR"
|
||
|
rlRun "abrt-cli report FAKEDIR" 1
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "report not-reportable"
|
||
|
rlRun "touch $crash_PATH/not-reportable"
|
||
|
|
||
|
cp $crash_PATH/{type,analyzer} ./
|
||
|
|
||
|
echo "cli_sanity_test_not_reportable" > $crash_PATH/type
|
||
|
echo "cli_sanity_test_not_reportable" > $crash_PATH/analyzer
|
||
|
|
||
|
rlRun "abrt-cli report $crash_PATH 2>&1 | tee abrt-cli-report-not-reportable.log" 0
|
||
|
rlAssertGrep "Problem '$crash_PATH' cannot be reported" abrt-cli-report-not-reportable.log
|
||
|
|
||
|
cp -f type analyzer $crash_PATH
|
||
|
|
||
|
rlRun "rm -f $crash_PATH/not-reportable"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "report not-reportable --unsafe parameter"
|
||
|
rlRun "touch $crash_PATH/not-reportable"
|
||
|
|
||
|
cp $crash_PATH/{type,analyzer} ./
|
||
|
|
||
|
echo "cli_sanity_test_not_reportable_unsafe" > $crash_PATH/type
|
||
|
echo "cli_sanity_test_not_reportable_unsafe" > $crash_PATH/analyzer
|
||
|
|
||
|
rlRun "abrt-cli report --unsafe $crash_PATH 2>&1 | tee abrt-cli-report-not-reportable-unsafe.log" 0
|
||
|
rlAssertNotGrep "Problem '$crash_PATH' cannot be reported" abrt-cli-report-not-reportable-unsafe.log
|
||
|
rlAssertGrep "Error: no processing is specified for event 'report-cli'" abrt-cli-report-not-reportable-unsafe.log
|
||
|
|
||
|
cp -f type analyzer $crash_PATH
|
||
|
|
||
|
rlRun "rm -f $crash_PATH/not-reportable"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
# This test used to select 1st analyzer (Local GNU Debugger)
|
||
|
# and run it, then "edit" data with cat (this merely prints data to stdout)
|
||
|
# and terminate. This was far from reliable (what if analyzer would change?).
|
||
|
#
|
||
|
# With the changed CLI, it probably can be emulated by running
|
||
|
# "report-cli -e analyze_LocalGDB $DIR"
|
||
|
# ...except that analyze_LocalGDB has <gui-review-elements>no</gui-review-elements>!
|
||
|
# Need to think about this...
|
||
|
#
|
||
|
#rlPhaseStartTest "report DIR"
|
||
|
# DIR=$(abrt-cli list -n | grep 'Directory' | head -n1 | awk '{ print $2 }')
|
||
|
# echo -e "1\n" | VISUAL="cat" EDITOR="cat" abrt-cli report $DIR > output.out 2>&1
|
||
|
#
|
||
|
# rlAssertGrep "\-cmdline" output.out
|
||
|
# rlAssertGrep "\-kernel" output.out
|
||
|
#rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "info DIR"
|
||
|
DIR=$(abrt-cli list | grep 'Directory' | head -n1 | awk '{ print $2 }')
|
||
|
rlRun "abrt-cli info $DIR"
|
||
|
rlRun "abrt-cli info -d $DIR > info.out"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "list (after reporting)"
|
||
|
DIR=$(abrt-cli list | grep 'Directory' | head -n1 | awk '{ print $2 }')
|
||
|
|
||
|
# this should ensure that ABRT will consider the problem as reported
|
||
|
rlRun "reporter-print -r -d $DIR -o /dev/null"
|
||
|
|
||
|
rlRun "abrt-cli list | grep -i 'cmdline'"
|
||
|
rlRun "abrt-cli list | grep -i 'Package'"
|
||
|
|
||
|
# this expects that reporter-print works and adds an URL to
|
||
|
# the output file to the problem's data
|
||
|
rlRun "abrt-cli list | grep -i 'file:///dev/null'"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "list -n (after reporting)" # list not-reported
|
||
|
BYTESNUM=$(abrt-cli list -n | wc -c)
|
||
|
rlAssert0 "No not-reported problem" "$BYTESNUM"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "info FAKEDIR"
|
||
|
rlRun "abrt-cli info FAKEDIR" 1
|
||
|
rlRun "abrt-cli info -d FAKEDIR" 1
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "rm FAKEDIR"
|
||
|
rlRun "abrt-cli rm FAKEDIR" 1
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartTest "rm DIR"
|
||
|
DIR_DELETE=$(abrt-cli list | grep 'Directory' | head -n1 | awk '{ print $2 }')
|
||
|
rlRun "abrt-cli rm $DIR_DELETE"
|
||
|
rlPhaseEnd
|
||
|
|
||
|
rlPhaseStartCleanup
|
||
|
remove_custom_event
|
||
|
popd # TmpDir
|
||
|
rm -rf $TmpDir
|
||
|
rlPhaseEnd
|
||
|
rlJournalPrintText
|
||
|
rlJournalEnd
|