Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
6 changed files
with
305 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,99 @@ | ||
#!/bin/bash | ||
|
||
#Test api: /api/history output | ||
|
||
errorMsg() { | ||
echo "$*" 1>&2 | ||
} | ||
|
||
DIR=$(cd `dirname $0` && pwd) | ||
|
||
# accept url argument on commandline, if '-' use default | ||
url="$1" | ||
if [ "-" == "$1" ] ; then | ||
url='http://localhost:4440' | ||
fi | ||
shift | ||
|
||
proj="test" | ||
|
||
apiurl="${url}/api" | ||
VERSHEADER="X-RUNDECK-API-VERSION: 1.2" | ||
|
||
# curl opts to use a cookie jar, and follow redirects, showing only errors | ||
CURLOPTS="-s -S -L -c $DIR/cookies -b $DIR/cookies" | ||
CURL="curl $CURLOPTS" | ||
|
||
XMLSTARLET=xml | ||
|
||
# now submit req | ||
runurl="${apiurl}/history" | ||
|
||
echo "TEST: output from /api/history should be valid" | ||
|
||
params="project=${proj}" | ||
|
||
# get listing | ||
$CURL --header "$VERSHEADER" ${runurl}?${params} > $DIR/curl.out | ||
if [ 0 != $? ] ; then | ||
errorMsg "ERROR: failed query request" | ||
exit 2 | ||
fi | ||
|
||
sh $DIR/api-test-success.sh $DIR/curl.out || exit 2 | ||
|
||
#Check projects list | ||
itemcount=$($XMLSTARLET sel -T -t -v "/result/events/@count" $DIR/curl.out) | ||
if [ "" == "$itemcount" ] ; then | ||
errorMsg "FAIL: expected events count" | ||
exit 2 | ||
fi | ||
|
||
echo "OK" | ||
|
||
# use invalid dateTime format for "end" parameter | ||
|
||
echo "TEST: /api/history using bad \"end\" date format parameter" | ||
params="project=${proj}&end=asdf" | ||
|
||
sh $DIR/api-expect-error.sh "${runurl}" "${params}" "The parameter \"end\" did not have a valid time or dateTime format: asdf" || exit 2 | ||
echo "OK" | ||
|
||
|
||
# use invalid dateTime format for "begin" parameter | ||
|
||
echo "TEST: /api/history using bad \"begin\" date format parameter" | ||
params="project=${proj}&begin=asdf" | ||
|
||
sh $DIR/api-expect-error.sh "${runurl}" "${params}" "The parameter \"begin\" did not have a valid time or dateTime format: asdf" || exit 2 | ||
echo "OK" | ||
|
||
# use valid dateTime format for "end" parameter | ||
|
||
echo "TEST: /api/history using valid \"end\" date format parameter" | ||
params="project=${proj}&end=2011-02-04T21:38:02Z" | ||
|
||
$CURL --header "$VERSHEADER" ${runurl}?${params} > $DIR/curl.out | ||
if [ 0 != $? ] ; then | ||
errorMsg "ERROR: failed query request" | ||
exit 2 | ||
fi | ||
|
||
sh $DIR/api-test-success.sh $DIR/curl.out || exit 2 | ||
echo "OK" | ||
# use valid dateTime format for "begin" parameter | ||
|
||
echo "TEST: /api/history using valid \"begin\" date format parameter" | ||
params="project=${proj}&begin=2011-02-04T21:03:34Z" | ||
|
||
$CURL --header "$VERSHEADER" ${runurl}?${params} > $DIR/curl.out | ||
if [ 0 != $? ] ; then | ||
errorMsg "ERROR: failed query request" | ||
exit 2 | ||
fi | ||
|
||
sh $DIR/api-test-success.sh $DIR/curl.out || exit 2 | ||
echo "OK" | ||
|
||
#rm $DIR/curl.out | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
#!/bin/bash | ||
|
||
#Usage: | ||
# util-history.sh <project> [URL] [param=value [param=value] .. ] | ||
|
||
errorMsg() { | ||
echo "$*" 1>&2 | ||
} | ||
|
||
DIR=$(cd `dirname $0` && pwd) | ||
|
||
proj=$1 | ||
if [ "" == "$1" ] ; then | ||
proj="test" | ||
fi | ||
shift | ||
# accept url argument on commandline, if '-' use default | ||
url="$1" | ||
if [ "-" == "$1" ] ; then | ||
url='http://localhost:4440' | ||
fi | ||
shift | ||
apiurl="${url}/api" | ||
VERSHEADER="X-RUNDECK-API-VERSION: 1.2" | ||
|
||
# curl opts to use a cookie jar, and follow redirects, showing only errors | ||
CURLOPTS="-s -S -L -c $DIR/cookies -b $DIR/cookies" | ||
CURL="curl $CURLOPTS" | ||
|
||
if [ ! -f $DIR/cookies ] ; then | ||
# call rundecklogin.sh | ||
sh $DIR/rundecklogin.sh $url | ||
fi | ||
|
||
XMLSTARLET=xml | ||
|
||
# now submit req | ||
runurl="${apiurl}/history" | ||
|
||
echo "# Listing RunDeck Jobs for project ${proj}..." | ||
|
||
args="$*" | ||
params="project=${proj}&${args}" | ||
|
||
|
||
# get listing | ||
$CURL --header "$VERSHEADER" ${runurl}?${params} > $DIR/curl.out | ||
if [ 0 != $? ] ; then | ||
errorMsg "ERROR: failed query request" | ||
exit 2 | ||
fi | ||
|
||
#test curl.out for valid xml | ||
$XMLSTARLET val -w $DIR/curl.out > /dev/null 2>&1 | ||
if [ 0 != $? ] ; then | ||
errorMsg "ERROR: Response was not valid xml" | ||
exit 2 | ||
fi | ||
|
||
#test for expected /joblist element | ||
$XMLSTARLET el $DIR/curl.out | grep -e '^result' -q | ||
if [ 0 != $? ] ; then | ||
errorMsg "ERROR: Response did not contain expected result" | ||
exit 2 | ||
fi | ||
|
||
# job list query doesn't wrap result in common result wrapper | ||
#If <result error="true"> then an error occured. | ||
waserror=$($XMLSTARLET sel -T -t -v "/result/@error" $DIR/curl.out) | ||
if [ "true" == "$waserror" ] ; then | ||
errorMsg "Server reported an error: " | ||
$XMLSTARLET sel -T -t -v "/result/error/message" -n $DIR/curl.out | ||
exit 2 | ||
fi | ||
|
||
#Check projects list | ||
itemcount=$($XMLSTARLET sel -T -t -v "/result/events/@count" $DIR/curl.out) | ||
|
||
if [ "0" != "$itemcount" ] ; then | ||
#echo all on one line | ||
$XMLSTARLET sel -T -t -m "/result/events/event" -o "[" \ | ||
-v "date-ended" -o "] " \ | ||
-v "user" -o " : " -v "project" -o " [" \ | ||
-v "job/@id" -o "," -v "execution/@id" -o "] [" \ | ||
-v "node-summary/@succeeded" -o "/" \ | ||
-v "node-summary/@failed" -o "/" \ | ||
-v "node-summary/@total" -o "] " \ | ||
-v "title" -o " : " \ | ||
-v "normalize-space(summary)" \ | ||
-n $DIR/curl.out | ||
fi | ||
|
||
rm $DIR/curl.out |