diff options
| -rw-r--r-- | Makefile | 5 | ||||
| -rw-r--r-- | tests/.gitignore | 2 | ||||
| -rw-r--r-- | tests/Makefile | 13 | ||||
| -rwxr-xr-x | tests/setup.sh | 108 | ||||
| -rwxr-xr-x | tests/t0010-validate-html.sh | 31 | ||||
| -rwxr-xr-x | tests/t0101-index.sh | 13 | ||||
| -rwxr-xr-x | tests/t0102-summary.sh | 20 | ||||
| -rwxr-xr-x | tests/t0103-log.sh | 15 | ||||
| -rwxr-xr-x | tests/t0104-tree.sh | 15 | ||||
| -rwxr-xr-x | tests/t0105-commit.sh | 22 | ||||
| -rwxr-xr-x | tests/t0106-diff.sh | 20 | ||||
| -rwxr-xr-x | tests/t0107-snapshot.sh | 36 | 
12 files changed, 299 insertions, 1 deletions
| @@ -24,7 +24,7 @@ ifdef NEEDS_LIBICONV | |||
| 24 | endif | 24 | endif | 
| 25 | 25 | ||
| 26 | 26 | ||
| 27 | .PHONY: all git install clean distclean emptycache force-version get-git | 27 | .PHONY: all git test install clean distclean emptycache force-version get-git | 
| 28 | 28 | ||
| 29 | all: cgit git | 29 | all: cgit git | 
| 30 | 30 | ||
| @@ -54,6 +54,9 @@ git: | |||
| 54 | cd git && $(MAKE) xdiff/lib.a | 54 | cd git && $(MAKE) xdiff/lib.a | 
| 55 | cd git && $(MAKE) libgit.a | 55 | cd git && $(MAKE) libgit.a | 
| 56 | 56 | ||
| 57 | test: all | ||
| 58 | $(MAKE) -C tests | ||
| 59 | |||
| 57 | install: all | 60 | install: all | 
| 58 | mkdir -p $(DESTDIR)$(CGIT_SCRIPT_PATH) | 61 | mkdir -p $(DESTDIR)$(CGIT_SCRIPT_PATH) | 
| 59 | install cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) | 62 | install cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) | 
| diff --git a/tests/.gitignore b/tests/.gitignore new file mode 100644 index 0000000..c1c1c0b --- /dev/null +++ b/tests/.gitignore | |||
| @@ -0,0 +1,2 @@ | |||
| 1 | trash | ||
| 2 | test-output.log | ||
| diff --git a/tests/Makefile b/tests/Makefile new file mode 100644 index 0000000..697e5a1 --- /dev/null +++ b/tests/Makefile | |||
| @@ -0,0 +1,13 @@ | |||
| 1 | |||
| 2 | |||
| 3 | T = $(wildcard t[0-9][0-9][0-9][0-9]-*.sh) | ||
| 4 | |||
| 5 | all: $(T) | ||
| 6 | |||
| 7 | $(T): | ||
| 8 | @$@ | ||
| 9 | |||
| 10 | clean: | ||
| 11 | $(RM) -rf trash | ||
| 12 | |||
| 13 | .PHONY: $(T) clean | ||
| diff --git a/tests/setup.sh b/tests/setup.sh new file mode 100755 index 0000000..51d5a75 --- /dev/null +++ b/tests/setup.sh | |||
| @@ -0,0 +1,108 @@ | |||
| 1 | # This file should be sourced by all test-scripts | ||
| 2 | # | ||
| 3 | # Main functions: | ||
| 4 | # prepare_tests(description) - setup for testing, i.e. create repos+config | ||
| 5 | # run_test(description, script) - run one test, i.e. eval script | ||
| 6 | # | ||
| 7 | # Helper functions | ||
| 8 | # cgit_query(querystring) - call cgit with the specified querystring | ||
| 9 | # cgit_url(url) - call cgit with the specified virtual url | ||
| 10 | # | ||
| 11 | # Example script: | ||
| 12 | # | ||
| 13 | # . setup.sh | ||
| 14 | # prepare_tests "html validation" | ||
| 15 | # run_test 'repo index' 'cgit_url "/" | tidy -e' | ||
| 16 | # run_test 'repo summary' 'cgit_url "/foo" | tidy -e' | ||
| 17 | |||
| 18 | |||
| 19 | mkrepo() { | ||
| 20 | name=$1 | ||
| 21 | count=$2 | ||
| 22 | dir=$PWD | ||
| 23 | test -d $name && return | ||
| 24 | printf "Creating testrepo %s\n" $name | ||
| 25 | mkdir -p $name | ||
| 26 | cd $name | ||
| 27 | git init | ||
| 28 | for ((n=1; n<=count; n++)) | ||
| 29 | do | ||
| 30 | echo $n >file-$n | ||
| 31 | git add file-$n | ||
| 32 | git commit -m "commit $n" | ||
| 33 | done | ||
| 34 | cd $dir | ||
| 35 | } | ||
| 36 | |||
| 37 | setup_repos() | ||
| 38 | { | ||
| 39 | rm -rf trash/cache | ||
| 40 | mkdir -p trash/cache | ||
| 41 | mkrepo trash/repos/foo 5 >/dev/null | ||
| 42 | mkrepo trash/repos/bar 50 >/dev/null | ||
| 43 | cat >trash/cgitrc <<EOF | ||
| 44 | virtual-root=/ | ||
| 45 | cache-root=$PWD/trash/cache | ||
| 46 | |||
| 47 | nocache=0 | ||
| 48 | snapshots=tar.gz tar.bz zip | ||
| 49 | enable-log-filecount=1 | ||
| 50 | enable-log-linecount=1 | ||
| 51 | summary-log=5 | ||
| 52 | summary-branches=5 | ||
| 53 | summary-tags=5 | ||
| 54 | |||
| 55 | repo.url=foo | ||
| 56 | repo.path=$PWD/trash/repos/foo/.git | ||
| 57 | repo.desc=the foo repo | ||
| 58 | |||
| 59 | repo.url=bar | ||
| 60 | repo.path=$PWD/trash/repos/bar/.git | ||
| 61 | repo.desc=the bar repo | ||
| 62 | EOF | ||
| 63 | } | ||
| 64 | |||
| 65 | prepare_tests() | ||
| 66 | { | ||
| 67 | setup_repos | ||
| 68 | test_count=0 | ||
| 69 | test_failed=0 | ||
| 70 | echo "$@" "($0)" | ||
| 71 | } | ||
| 72 | |||
| 73 | tests_done() | ||
| 74 | { | ||
| 75 | printf "\n" | ||
| 76 | if test $test_failed -gt 0 | ||
| 77 | then | ||
| 78 | printf "[%s of %s tests failed]\n" $test_failed $test_count | ||
| 79 | false | ||
| 80 | fi | ||
| 81 | } | ||
| 82 | |||
| 83 | run_test() | ||
| 84 | { | ||
| 85 | desc=$1 | ||
| 86 | script=$2 | ||
| 87 | ((test_count++)) | ||
| 88 | eval "$2" >test-output.log | ||
| 89 | res=$? | ||
| 90 | if test $res = 0 | ||
| 91 | then | ||
| 92 | printf " %s: ok - %s\n" $test_count "$desc" | ||
| 93 | else | ||
| 94 | ((test_failed++)) | ||
| 95 | printf " %s: fail - %s\n" $test_count "$desc" | ||
| 96 | fi | ||
| 97 | } | ||
| 98 | |||
| 99 | cgit_query() | ||
| 100 | { | ||
| 101 | CGIT_CONFIG="$PWD/trash/cgitrc" QUERY_STRING="$1" "$PWD/../cgit" | ||
| 102 | } | ||
| 103 | |||
| 104 | cgit_url() | ||
| 105 | { | ||
| 106 | CGIT_CONFIG="$PWD/trash/cgitrc" QUERY_STRING="url=$1" "$PWD/../cgit" | ||
| 107 | } | ||
| 108 | |||
| diff --git a/tests/t0010-validate-html.sh b/tests/t0010-validate-html.sh new file mode 100755 index 0000000..907a415 --- /dev/null +++ b/tests/t0010-validate-html.sh | |||
| @@ -0,0 +1,31 @@ | |||
| 1 | #!/bin/sh | ||
| 2 | |||
| 3 | . ./setup.sh | ||
| 4 | |||
| 5 | |||
| 6 | test_url() | ||
| 7 | { | ||
| 8 | tidy_opt="-eq" | ||
| 9 | test -z "$NO_TIDY_WARNINGS" || tidy_opt+=" --show-warnings no" | ||
| 10 | cgit_url "$1" | sed -e "1,4d" >trash/tidy-$test_count | ||
| 11 | tidy $tidy_opt trash/tidy-$test_count | ||
| 12 | rc=$? | ||
| 13 | if test $rc = 2 | ||
| 14 | then | ||
| 15 | false | ||
| 16 | else | ||
| 17 | : | ||
| 18 | fi | ||
| 19 | } | ||
| 20 | |||
| 21 | prepare_tests 'Validate html with tidy' | ||
| 22 | |||
| 23 | run_test 'index page' 'test_url ""' | ||
| 24 | run_test 'foo' 'test_url "foo"' | ||
| 25 | run_test 'foo/log' 'test_url "foo/log"' | ||
| 26 | run_test 'foo/tree' 'test_url "foo/tree"' | ||
| 27 | run_test 'foo/tree/file-1' 'test_url "foo/tree/file-1"' | ||
| 28 | run_test 'foo/commit' 'test_url "foo/commit"' | ||
| 29 | run_test 'foo/diff' 'test_url "foo/diff"' | ||
| 30 | |||
| 31 | tests_done | ||
| diff --git a/tests/t0101-index.sh b/tests/t0101-index.sh new file mode 100755 index 0000000..12ed00c --- /dev/null +++ b/tests/t0101-index.sh | |||
| @@ -0,0 +1,13 @@ | |||
| 1 | #!/bin/sh | ||
| 2 | |||
| 3 | . ./setup.sh | ||
| 4 | |||
| 5 | prepare_tests "Check content on index page" | ||
| 6 | |||
| 7 | run_test 'generate index page' 'cgit_url "" >trash/tmp' | ||
| 8 | run_test 'find foo repo' 'grep -e "foo" trash/tmp' | ||
| 9 | run_test 'find bar repo' 'grep -e "bar" trash/tmp' | ||
| 10 | run_test 'no tree-link' 'grep -ve "foo/tree" trash/tmp' | ||
