* lh/testsuite: Set commit date on snapshot contents Fix html error detected by test-suite Create initial testsuiteupstream
commit
a7cf406c80
@ -0,0 +1,2 @@ |
|||||||
|
trash |
||||||
|
test-output.log |
@ -0,0 +1,13 @@ |
|||||||
|
|
||||||
|
|
||||||
|
T = $(wildcard t[0-9][0-9][0-9][0-9]-*.sh)
|
||||||
|
|
||||||
|
all: $(T) |
||||||
|
|
||||||
|
$(T): |
||||||
|
@$@
|
||||||
|
|
||||||
|
clean: |
||||||
|
$(RM) -rf trash
|
||||||
|
|
||||||
|
.PHONY: $(T) clean |
@ -0,0 +1,108 @@ |
|||||||
|
# This file should be sourced by all test-scripts |
||||||
|
# |
||||||
|
# Main functions: |
||||||
|
# prepare_tests(description) - setup for testing, i.e. create repos+config |
||||||
|
# run_test(description, script) - run one test, i.e. eval script |
||||||
|
# |
||||||
|
# Helper functions |
||||||
|
# cgit_query(querystring) - call cgit with the specified querystring |
||||||
|
# cgit_url(url) - call cgit with the specified virtual url |
||||||
|
# |
||||||
|
# Example script: |
||||||
|
# |
||||||
|
# . setup.sh |
||||||
|
# prepare_tests "html validation" |
||||||
|
# run_test 'repo index' 'cgit_url "/" | tidy -e' |
||||||
|
# run_test 'repo summary' 'cgit_url "/foo" | tidy -e' |
||||||
|
|
||||||
|
|
||||||
|
mkrepo() { |
||||||
|
name=$1 |
||||||
|
count=$2 |
||||||
|
dir=$PWD |
||||||
|
test -d $name && return |
||||||
|
printf "Creating testrepo %s\n" $name |
||||||
|
mkdir -p $name |
||||||
|
cd $name |
||||||
|
git init |
||||||
|
for ((n=1; n<=count; n++)) |
||||||
|
do |
||||||
|
echo $n >file-$n |
||||||
|
git add file-$n |
||||||
|
git commit -m "commit $n" |
||||||
|
done |
||||||
|
cd $dir |
||||||
|
} |
||||||
|
|
||||||
|
setup_repos() |
||||||
|
{ |
||||||
|
rm -rf trash/cache |
||||||
|
mkdir -p trash/cache |
||||||
|
mkrepo trash/repos/foo 5 >/dev/null |
||||||
|
mkrepo trash/repos/bar 50 >/dev/null |
||||||
|
cat >trash/cgitrc <<EOF |
||||||
|
virtual-root=/ |
||||||
|
cache-root=$PWD/trash/cache |
||||||
|
|
||||||
|
nocache=0 |
||||||
|
snapshots=tar.gz tar.bz zip |
||||||
|
enable-log-filecount=1 |
||||||
|
enable-log-linecount=1 |
||||||
|
summary-log=5 |
||||||
|
summary-branches=5 |
||||||
|
summary-tags=5 |
||||||
|
|
||||||
|
repo.url=foo |
||||||
|
repo.path=$PWD/trash/repos/foo/.git |
||||||
|
repo.desc=the foo repo |
||||||
|
|
||||||
|
repo.url=bar |
||||||
|
repo.path=$PWD/trash/repos/bar/.git |
||||||
|
repo.desc=the bar repo |
||||||
|
EOF |
||||||
|
} |
||||||
|
|
||||||
|
prepare_tests() |
||||||
|
{ |
||||||
|
setup_repos |
||||||
|
test_count=0 |
||||||
|
test_failed=0 |
||||||
|
echo "$@" "($0)" |
||||||
|
} |
||||||
|
|
||||||
|
tests_done() |
||||||
|
{ |
||||||
|
printf "\n" |
||||||
|
if test $test_failed -gt 0 |
||||||
|
then |
||||||
|
printf "[%s of %s tests failed]\n" $test_failed $test_count |
||||||
|
false |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
run_test() |
||||||
|
{ |
||||||
|
desc=$1 |
||||||
|
script=$2 |
||||||
|
((test_count++)) |
||||||
|
eval "$2" >test-output.log |
||||||
|
res=$? |
||||||
|
if test $res = 0 |
||||||
|
then |
||||||
|
printf " %s: ok - %s\n" $test_count "$desc" |
||||||
|
else |
||||||
|
((test_failed++)) |
||||||
|
printf " %s: fail - %s\n" $test_count "$desc" |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
cgit_query() |
||||||
|
{ |
||||||
|
CGIT_CONFIG="$PWD/trash/cgitrc" QUERY_STRING="$1" "$PWD/../cgit" |
||||||
|
} |
||||||
|
|
||||||
|
cgit_url() |
||||||
|
{ |
||||||
|
CGIT_CONFIG="$PWD/trash/cgitrc" QUERY_STRING="url=$1" "$PWD/../cgit" |
||||||
|
} |
||||||
|
|
@ -0,0 +1,31 @@ |
|||||||
|
#!/bin/sh |
||||||
|
|
||||||
|
. ./setup.sh |
||||||
|
|
||||||
|
|
||||||
|
test_url() |
||||||
|
{ |
||||||
|
tidy_opt="-eq" |
||||||
|
test -z "$NO_TIDY_WARNINGS" || tidy_opt+=" --show-warnings no" |
||||||
|
cgit_url "$1" | sed -e "1,4d" >trash/tidy-$test_count |
||||||
|
tidy $tidy_opt trash/tidy-$test_count |
||||||
|
rc=$? |
||||||
|
if test $rc = 2 |
||||||
|
then |
||||||
|
false |
||||||
|
else |
||||||
|
: |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
prepare_tests 'Validate html with tidy' |
||||||
|
|
||||||
|
run_test 'index page' 'test_url ""' |
||||||
|
run_test 'foo' 'test_url "foo"' |
||||||
|
run_test 'foo/log' 'test_url "foo/log"' |
||||||
|
run_test 'foo/tree' 'test_url "foo/tree"' |
||||||
|
run_test 'foo/tree/file-1' 'test_url "foo/tree/file-1"' |
||||||
|
run_test 'foo/commit' 'test_url "foo/commit"' |
||||||
|
run_test 'foo/diff' 'test_url "foo/diff"' |
||||||
|
|
||||||
|
tests_done |
@ -0,0 +1,13 @@ |
|||||||
|
#!/bin/sh |
||||||
|
|
||||||
|
. ./setup.sh |
||||||
|
|
||||||
|
prepare_tests "Check content on index page" |
||||||
|
|
||||||
|
run_test 'generate index page' 'cgit_url "" >trash/tmp' |
||||||
|
run_test 'find foo repo' 'grep -e "foo" trash/tmp' |
||||||
|
run_test 'find bar repo' 'grep -e "bar" trash/tmp' |
||||||
|
run_test 'no tree-link' 'grep -ve "foo/tree" trash/tmp' |
||||||
|
run_test 'no log-link' 'grep -ve "foo/log" trash/tmp' |
||||||
|
|
||||||
|
tests_done |
@ -0,0 +1,20 @@ |
|||||||
|
#!/bin/sh |
||||||
|
|
||||||
|
. ./setup.sh |
||||||
|
|
||||||
|
prepare_tests "Check content on summary page" |
||||||
|
|
||||||
|
run_test 'generate foo summary' 'cgit_url "foo" >trash/tmp' |
||||||
|
run_test 'find commit 1' 'grep -e "commit 1" trash/tmp' |
||||||
|
run_test 'find commit 5' 'grep -e "commit 5" trash/tmp' |
||||||
|
run_test 'find branch master' 'grep -e "master" trash/tmp' |
||||||
|
run_test 'no tags' 'grep -ve "tags" trash/tmp' |
||||||
|
|
||||||
|
run_test 'generate bar summary' 'cgit_url "bar" >trash/tmp' |
||||||
|
run_test 'no commit 45' 'grep -ve "commit 45" trash/tmp' |
||||||
|
run_test 'find commit 46' 'grep -e "commit 46" trash/tmp' |
||||||
|
run_test 'find commit 50' 'grep -e "commit 50" trash/tmp' |
||||||
|
run_test 'find branch master' 'grep -e "master" trash/tmp' |
||||||
|
run_test 'no tags' 'grep -ve "tags" trash/tmp' |
||||||
|
|
||||||
|
tests_done |
@ -0,0 +1,15 @@ |
|||||||
|
#!/bin/sh |
||||||
|
|
||||||
|
. ./setup.sh |
||||||
|
|
||||||
|
prepare_tests "Check content on log page" |
||||||
|
|
||||||
|
run_test 'generate foo/log' 'cgit_url "foo/log" >trash/tmp' |
||||||
|
run_test 'find commit 1' 'grep -e "commit 1" trash/tmp' |
||||||
|
run_test 'find commit 5' 'grep -e "commit 5" trash/tmp' |
||||||
|
|
||||||
|
run_test 'generate bar/log' 'cgit_url "bar/log" >trash/tmp' |
||||||
|
run_test 'find commit 1' 'grep -e "commit 1" trash/tmp' |
||||||
|
run_test 'find commit 50' 'grep -e "commit 50" trash/tmp' |
||||||
|
|
||||||
|
tests_done |
@ -0,0 +1,21 @@ |
|||||||
|
#!/bin/sh |
||||||
|
|
||||||
|
. ./setup.sh |
||||||
|
|
||||||
|
prepare_tests "Check content on tree page" |
||||||
|
|
||||||
|
run_test 'generate bar/tree' 'cgit_url "bar/tree" >trash/tmp' |
||||||
|
run_test 'find file-1' 'grep -e "file-1" trash/tmp' |
||||||
|
run_test 'find file-50' 'grep -e "file-50" trash/tmp' |
||||||
|
|
||||||
|
run_test 'generate bar/tree/file-50' 'cgit_url "bar/tree/file-50" >trash/tmp' |
||||||
|
|
||||||
|
run_test 'find line 1' ' |
||||||
|
grep -e "<a id=.n1. name=.n1. href=.#n1.>1</a>" trash/tmp |
||||||
|
' |
||||||
|
|
||||||
|
run_test 'no line 2' ' |
||||||
|
grep -e "<a id=.n2. name=.n2. href=.#n2.>2</a>" trash/tmp |
||||||
|
' |
||||||
|
|
||||||
|
tests_done |
@ -0,0 +1,22 @@ |
|||||||
|
#!/bin/sh |
||||||
|
|
||||||
|
. ./setup.sh |
||||||
|
|
||||||
|
prepare_tests "Check content on commit page" |
||||||
|
|
||||||
|
run_test 'generate foo/commit' 'cgit_url "foo/commit" >trash/tmp' |
||||||
|
run_test 'find tree link' 'grep -e "<a href=./foo/tree/.>" trash/tmp' |
||||||
|
run_test 'find parent link' 'grep -E "<a href=./foo/commit/\?id=.+>" trash/tmp' |
||||||
|
|
||||||
|
run_test 'find commit subject' ' |
||||||
|
grep -e "<div class=.commit-subject.>commit 5</div>" trash/tmp |
||||||
|
' |
||||||
|
|
||||||
|
run_test 'find commit msg' 'grep -e "<div class=.commit-msg.></div>" trash/tmp' |
||||||
|
run_test 'find diffstat' 'grep -e "<table summary=.diffstat. class=.diffstat.>" trash/tmp' |
||||||
|
|
||||||
|
run_test 'find diff summary' ' |
||||||
|
grep -e "1 files changed, 1 insertions, 0 deletions" trash/tmp |
||||||
|
' |
||||||
|
|
||||||
|
tests_done |
@ -0,0 +1,20 @@ |
|||||||
|
#!/bin/sh |
||||||
|
|
||||||
|
. ./setup.sh |
||||||
|
|
||||||
|
prepare_tests "Check content on diff page" |
||||||
|
|
||||||
|
run_test 'generate foo/diff' 'cgit_url "foo/diff" >trash/tmp' |
||||||
|
run_test 'find diff header' 'grep -e "a/file-5 b/file-5" trash/tmp' |
||||||
|
run_test 'find blob link' 'grep -e "<a href=./foo/tree/file-5?id=" trash/tmp' |
||||||
|
run_test 'find added file' 'grep -e "new file mode 100644" trash/tmp' |
||||||
|
|
||||||
|
run_test 'find hunk header' ' |
||||||
|
grep -e "<div class=.hunk.>@@ -0,0 +1 @@</div>" trash/tmp |
||||||
|
' |
||||||
|
|
||||||
|
run_test 'find added line' ' |
||||||
|
grep -e "<div class=.add.>+5</div>" trash/tmp |
||||||
|
' |
||||||
|
|
||||||
|
tests_done |
@ -0,0 +1,36 @@ |
|||||||
|
#!/bin/sh |
||||||
|
|
||||||
|
. ./setup.sh |
||||||
|
|
||||||
|
prepare_tests "Verify snapshot" |
||||||
|
|
||||||
|
run_test 'get foo/snapshot/test.tar.gz' ' |
||||||
|
cgit_url "foo/snapshot/test.tar.gz" >trash/tmp |
||||||
|
' |
||||||
|
|
||||||
|
run_test 'check html headers' ' |
||||||
|
head -n 1 trash/tmp | |
||||||
|
grep -e "Content-Type: application/x-tar" && |
||||||
|
|
||||||
|
head -n 2 trash/tmp | |
||||||
|
grep -e "Content-Disposition: inline; filename=.test.tar.gz." |
||||||
|
' |
||||||
|
|
||||||
|
run_test 'strip off the header lines' ' |
||||||
|
tail -n +6 trash/tmp > trash/test.tar.gz |
||||||
|
' |
||||||
|
|
||||||
|
run_test 'verify gzip format' 'gunzip --test trash/test.tar.gz' |
||||||
|
run_test 'untar' 'tar -xf trash/test.tar.gz -C trash' |
||||||
|
|
||||||
|
run_test 'count files' ' |
||||||
|
c=$(ls -1 trash/foo/ | wc -l) && |
||||||
|
test $c = 5 |
||||||
|
' |
||||||
|
|
||||||
|
run_test 'verify untarred file-5' ' |
||||||
|
grep -e "^5$" trash/foo/file-5 && |
||||||
|
test $(cat trash/foo/file-5 | wc -l) = 1 |
||||||
|
' |
||||||
|
|
||||||
|
tests_done |
Loading…
Reference in new issue