diff options
| -rw-r--r-- | Makefile | 7 | ||||
| -rwxr-xr-x | tests/setup.sh | 130 | ||||
| -rwxr-xr-x | tests/t0001-validate-git-versions.sh | 28 | ||||
| -rwxr-xr-x | tests/t0010-validate-html.sh | 31 | ||||
| -rwxr-xr-x | tests/t0020-validate-cache.sh | 32 | ||||
| -rwxr-xr-x | tests/t0101-index.sh | 25 | ||||
| -rwxr-xr-x | tests/t0102-summary.sh | 35 | ||||
| -rwxr-xr-x | tests/t0103-log.sh | 33 | ||||
| -rwxr-xr-x | tests/t0104-tree.sh | 33 | ||||
| -rwxr-xr-x | tests/t0105-commit.sh | 41 | ||||
| -rwxr-xr-x | tests/t0106-diff.sh | 21 | ||||
| -rwxr-xr-x | tests/t0107-snapshot.sh | 77 | ||||
| -rwxr-xr-x | tests/t0108-patch.sh | 37 | 
13 files changed, 239 insertions, 291 deletions
| @@ -66,7 +66,10 @@ all:: cgit  cgit:  	$(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) -f ../cgit.mk ../cgit NO_CURL=1 -test: all +git: +	$(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) NO_CURL=1 + +test: all git  	$(QUIET_SUBDIR0)tests $(QUIET_SUBDIR1) all  install: all @@ -145,7 +148,7 @@ get-git:  tags:  	$(QUIET_TAGS)find . -name '*.[ch]' | xargs ctags -.PHONY: all cgit get-git +.PHONY: all cgit git get-git  .PHONY: clean clean-doc cleanall  .PHONY: doc doc-html doc-man doc-pdf  .PHONY: install install-doc install-html install-man install-pdf diff --git a/tests/setup.sh b/tests/setup.sh index e3c6c17..81e7220 100755 --- a/tests/setup.sh +++ b/tests/setup.sh @@ -15,46 +15,48 @@  # run_test 'repo index' 'cgit_url "/" | tidy -e'  # run_test 'repo summary' 'cgit_url "/foo" | tidy -e' -unset CDPATH +: ${TEST_DIRECTORY=$(pwd)/../git/t} +TEST_NO_CREATE_REPO=YesPlease +. "$TEST_DIRECTORY"/test-lib.sh + +# Prepend the directory containing cgit to PATH. +PATH="$(pwd)/../..:$PATH"  mkrepo() {  	name=$1  	count=$2 -	dir=$PWD -	test -d "$name" && return -	printf "Creating testrepo %s\n" "$name" -	mkdir -p "$name" -	cd "$name" -	git init -	n=1 -	while test $n -le $count -	do -		echo $n >file-$n -		git add file-$n -		git commit -m "commit $n" -		n=$(expr $n + 1) -	done -	if test "$3" = "testplus" -	then -		echo "hello" >a+b -		git add a+b -		git commit -m "add a+b" -		git branch "1+2" -	fi -	cd "$dir" +	test_create_repo "$name" +	( +		cd "$name" +		n=1 +		while test $n -le $count +		do +			echo $n >file-$n +			git add file-$n +			git commit -m "commit $n" +			n=$(expr $n + 1) +		done +		if test "$3" = "testplus" +		then +			echo "hello" >a+b +			git add a+b +			git commit -m "add a+b" +			git branch "1+2" +		fi +	)  }  setup_repos()  { -	rm -rf trash/cache -	mkdir -p trash/cache -	mkrepo trash/repos/foo 5 >/dev/null -	mkrepo trash/repos/bar 50 >/dev/null -	mkrepo trash/repos/foo+bar 10 testplus >/dev/null -	mkrepo "trash/repos/with space" 2 >/dev/null -	cat >trash/cgitrc <<EOF +	rm -rf cache +	mkdir -p cache +	mkrepo repos/foo 5 >/dev/null +	mkrepo repos/bar 50 >/dev/null +	mkrepo repos/foo+bar 10 testplus >/dev/null +	mkrepo "repos/with space" 2 >/dev/null +	cat >cgitrc <<EOF  virtual-root=/ -cache-root=$PWD/trash/cache +cache-root=$PWD/cache  cache-size=1021  snapshots=tar.gz tar.bz zip @@ -66,83 +68,33 @@ summary-tags=5  clone-url=git://example.org/\$CGIT_REPO_URL.git  repo.url=foo -repo.path=$PWD/trash/repos/foo/.git +repo.path=$PWD/repos/foo/.git  # Do not specify a description for this repo, as it then will be assigned  # the constant value "[no description]" (which actually used to cause a  # segfault).  repo.url=bar -repo.path=$PWD/trash/repos/bar/.git +repo.path=$PWD/repos/bar/.git  repo.desc=the bar repo  repo.url=foo+bar -repo.path=$PWD/trash/repos/foo+bar/.git +repo.path=$PWD/repos/foo+bar/.git  repo.desc=the foo+bar repo  repo.url=with space -repo.path=$PWD/trash/repos/with space/.git +repo.path=$PWD/repos/with space/.git  repo.desc=spaced repo  EOF  } -prepare_tests() -{ -	setup_repos -	rm -f test-output.log 2>/dev/null -	test_count=0 -	test_failed=0 -	echo "[$0]" "$@" >test-output.log -	echo "$@" "($0)" -} - -tests_done() -{ -	printf "\n" -	if test $test_failed -gt 0 -	then -		printf "test: *** %s failure(s), logfile=%s\n" \ -			$test_failed "$(pwd)/test-output.log" -		false -	fi -} - -run_test() -{ -	bug=0 -	if test "$1" = "BUG" -	then -		bug=1 -		shift -	fi -	desc=$1 -	script=$2 -	test_count=$(expr $test_count + 1) -	printf "\ntest %d: name='%s'\n" $test_count "$desc" >>test-output.log -	printf "test %d: eval='%s'\n" $test_count "$2" >>test-output.log -	eval "$2" >>test-output.log 2>>test-output.log -	res=$? -	printf "test %d: exitcode=%d\n" $test_count $res >>test-output.log -	if test $res = 0 -a $bug = 0 -	then -		printf " %2d) %-60s [ok]\n" $test_count "$desc" -	elif test $res = 0 -a $bug = 1 -	then -		printf " %2d) %-60s [BUG FIXED]\n" $test_count "$desc" -	elif test $bug = 1 -	then -		printf " %2d) %-60s [KNOWN BUG]\n" $test_count "$desc" -	else -		test_failed=$(expr $test_failed + 1) -		printf " %2d) %-60s [failed]\n" $test_count "$desc" -	fi -} -  cgit_query()  { -	CGIT_CONFIG="$PWD/trash/cgitrc" QUERY_STRING="$1" "$PWD/../cgit" +	CGIT_CONFIG="$PWD/cgitrc" QUERY_STRING="$1" cgit  }  cgit_url()  { -	CGIT_CONFIG="$PWD/trash/cgitrc" QUERY_STRING="url=$1" "$PWD/../cgit" +	CGIT_CONFIG="$PWD/cgitrc" QUERY_STRING="url=$1" cgit  } + +test -z "$CGIT_TEST_NO_CREATE_REPOS" && setup_repos diff --git a/tests/t0001-validate-git-versions.sh b/tests/t0001-validate-git-versions.sh index 3378358..754046e 100755 --- a/tests/t0001-validate-git-versions.sh +++ b/tests/t0001-validate-git-versions.sh @@ -1,36 +1,36 @@  #!/bin/sh +test_description='Check Git version is correct' +CGIT_TEST_NO_CREATE_REPOS=YesPlease  . ./setup.sh -prepare_tests 'Check Git version is correct' - -run_test 'extract Git version from Makefile' ' +test_expect_success 'extract Git version from Makefile' '  	sed -n -e "/^GIT_VER[ 	]*=/ {  		s/^GIT_VER[ 	]*=[ 	]*//  		p -	}" ../Makefile >trash/makefile_version +	}" ../../Makefile >makefile_version  ' -run_test 'test Git version matches Makefile' ' -	( cat ../git/GIT-VERSION-FILE || echo "No GIT-VERSION-FILE" ) | -	sed -e "s/GIT_VERSION[ 	]*=[ 	]*//" >trash/git_version && -	diff -u trash/git_version trash/makefile_version +test_expect_success 'test Git version matches Makefile' ' +	( cat ../../git/GIT-VERSION-FILE || echo "No GIT-VERSION-FILE" ) | +	sed -e "s/GIT_VERSION[ 	]*=[ 	]*//" >git_version && +	test_cmp git_version makefile_version  ' -run_test 'test submodule version matches Makefile' ' -	if ! test -e ../git/.git +test_expect_success 'test submodule version matches Makefile' ' +	if ! test -e ../../git/.git  	then  		echo "git/ is not a Git repository" >&2  	else  		( -			cd .. && +			cd ../.. &&  			sm_sha1=$(git ls-files --stage -- git |  				sed -e "s/^[0-9]* \\([0-9a-f]*\\) [0-9]	.*$/\\1/") &&  			cd git &&  			git describe --match "v[0-9]*" $sm_sha1 -		) | sed -e "s/^v//" >trash/sm_version && -		diff -u trash/sm_version trash/makefile_version +		) | sed -e "s/^v//" >sm_version && +		test_cmp sm_version makefile_version  	fi  ' -tests_done +test_done diff --git a/tests/t0010-validate-html.sh b/tests/t0010-validate-html.sh index 3fe4800..5bd0a25 100755 --- a/tests/t0010-validate-html.sh +++ b/tests/t0010-validate-html.sh @@ -1,5 +1,6 @@  #!/bin/sh +test_description='Validate html with tidy'  . ./setup.sh @@ -7,9 +8,9 @@ test_url()  {  	tidy_opt="-eq"  	test -z "$NO_TIDY_WARNINGS" || tidy_opt+=" --show-warnings no" -	cgit_url "$1" >trash/tidy-$test_count || return -	sed -ie "1,4d" trash/tidy-$test_count || return -	"$tidy" $tidy_opt trash/tidy-$test_count +	cgit_url "$1" >tidy-$test_count || return +	sed -ie "1,4d" tidy-$test_count || return +	"$tidy" $tidy_opt tidy-$test_count  	rc=$?  	# tidy returns with exitcode 1 on warnings, 2 on error @@ -21,21 +22,19 @@ test_url()  	fi  } -prepare_tests 'Validate html with tidy' - -tidy=`which tidy` +tidy=`which tidy 2>/dev/null`  test -n "$tidy" || { -	echo "Skipping tests: tidy not found" -	tests_done +	skip_all='Skipping html validation tests: tidy not found' +	test_done  	exit  } -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"' +test_expect_success 'index page' 'test_url ""' +test_expect_success 'foo' 'test_url "foo"' +test_expect_success 'foo/log' 'test_url "foo/log"' +test_expect_success 'foo/tree' 'test_url "foo/tree"' +test_expect_success 'foo/tree/file-1' 'test_url "foo/tree/file-1"' +test_expect_success 'foo/commit' 'test_url "foo/commit"' +test_expect_success 'foo/diff' 'test_url "foo/diff"' -tests_done +test_done diff --git a/tests/t0020-validate-cache.sh b/tests/t0020-validate-cache.sh index 53ec2eb..1910b47 100755 --- a/tests/t0020-validate-cache.sh +++ b/tests/t0020-validate-cache.sh @@ -1,13 +1,12 @@  #!/bin/sh +test_description='Validate cache'  . ./setup.sh -prepare_tests 'Validate cache' +test_expect_success 'verify cache-size=0' ' -run_test 'verify cache-size=0' ' - -	rm -f trash/cache/* && -	sed -i -e "s/cache-size=1021$/cache-size=0/" trash/cgitrc && +	rm -f cache/* && +	sed -i -e "s/cache-size=1021$/cache-size=0/" cgitrc &&  	cgit_url "" &&  	cgit_url "foo" &&  	cgit_url "foo/refs" && @@ -21,13 +20,14 @@ run_test 'verify cache-size=0' '  	cgit_url "bar/log" &&  	cgit_url "bar/diff" &&  	cgit_url "bar/patch" && -	test 0 -eq $(ls trash/cache | wc -l) +	ls cache >output && +	test_line_count = 0 output  ' -run_test 'verify cache-size=1' ' +test_expect_success 'verify cache-size=1' ' -	rm -f trash/cache/* && -	sed -i -e "s/cache-size=0$/cache-size=1/" trash/cgitrc && +	rm -f cache/* && +	sed -i -e "s/cache-size=0$/cache-size=1/" cgitrc &&  	cgit_url "" &&  	cgit_url "foo" &&  	cgit_url "foo/refs" && @@ -41,13 +41,14 @@ run_test 'verify cache-size=1' '  	cgit_url "bar/log" &&  	cgit_url "bar/diff" &&  	cgit_url "bar/patch" && -	test 1 -eq $(ls trash/cache | wc -l) +	ls cache >output && +	test_line_count = 1 output  ' -run_test 'verify cache-size=1021' ' +test_expect_success 'verify cache-size=1021' ' -	rm -f trash/cache/* && -	sed -i -e "s/cache-size=1$/cache-size=1021/" trash/cgitrc && +	rm -f cache/* && +	sed -i -e "s/cache-size=1$/cache-size=1021/" cgitrc &&  	cgit_url "" &&  	cgit_url "foo" &&  	cgit_url "foo/refs" && @@ -61,7 +62,8 @@ run_test 'verify cache-size=1021' '  	cgit_url "bar/log" &&  	cgit_url "bar/diff" &&  	cgit_url "bar/patch" && -	test 13 -eq $(ls trash/cache | wc -l) +	ls cache >output && +	test_line_count = 13 output  ' -tests_done +test_done diff --git a/tests/t0101-index.sh b/tests/t0101-index.sh index ab63aca..82ef9b0 100755 --- a/tests/t0101-index.sh +++ b/tests/t0101-index.sh @@ -1,18 +1,17 @@  #!/bin/sh +test_description='Check content on index page'  . ./setup.sh -prepare_tests "Check content on index page" +test_expect_success 'generate index page' 'cgit_url "" >tmp' +test_expect_success 'find foo repo' 'grep "foo" tmp' +test_expect_success 'find foo description' 'grep "\[no description\]" tmp' +test_expect_success 'find bar repo' 'grep "bar" tmp' +test_expect_success 'find bar description' 'grep "the bar repo" tmp' +test_expect_success 'find foo+bar repo' 'grep ">foo+bar<" tmp' +test_expect_success 'verify foo+bar link' 'grep "/foo+bar/" tmp' +test_expect_success 'verify "with%20space" link' 'grep "/with%20space/" tmp' +test_expect_success 'no tree-link' '! grep "foo/tree" tmp' +test_expect_success 'no log-link' '! grep "foo/log" tmp' -run_test 'generate index page' 'cgit_url "" >trash/tmp' -run_test 'find foo repo' 'grep "foo" trash/tmp' -run_test 'find foo description' 'grep "\[no description\]" trash/tmp' -run_test 'find bar repo' 'grep "bar" trash/tmp' -run_test 'find bar description' 'grep "the bar repo" trash/tmp' -run_test 'find foo+bar repo' 'grep ">foo+bar<" trash/tmp' -run_test 'verify foo+bar link' 'grep "/foo+bar/" trash/tmp' -run_test 'verify "with%20space" link' 'grep "/with%20space/" trash/tmp' -run_test 'no tree-link' '! grep "foo/tree" trash/tmp' -run_test 'no log-link' '! grep "foo/log" trash/tmp' - -tests_done +test_done diff --git a/tests/t0102-summary.sh b/tests/t0102-summary.sh index f778cb4..b8864cb 100755 --- a/tests/t0102-summary.sh +++ b/tests/t0102-summary.sh @@ -1,26 +1,25 @@  #!/bin/sh +test_description='Check content on summary page'  . ./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 "commit 1" trash/tmp' -run_test 'find commit 5' 'grep "commit 5" trash/tmp' -run_test 'find branch master' 'grep "master" trash/tmp' -run_test 'no tags' '! grep "tags" trash/tmp' -run_test 'clone-url expanded correctly' ' -	grep "git://example.org/foo.git" trash/tmp +test_expect_success 'generate foo summary' 'cgit_url "foo" >tmp' +test_expect_success 'find commit 1' 'grep "commit 1" tmp' +test_expect_success 'find commit 5' 'grep "commit 5" tmp' +test_expect_success 'find branch master' 'grep "master" tmp' +test_expect_success 'no tags' '! grep "tags" tmp' +test_expect_success 'clone-url expanded correctly' ' +	grep "git://example.org/foo.git" tmp  ' -run_test 'generate bar summary' 'cgit_url "bar" >trash/tmp' -run_test 'no commit 45' '! grep "commit 45" trash/tmp' -run_test 'find commit 46' 'grep "commit 46" trash/tmp' -run_test 'find commit 50' 'grep "commit 50" trash/tmp' -run_test 'find branch master' 'grep "master" trash/tmp' -run_test 'no tags' '! grep "tags" trash/tmp' -run_test 'clone-url expanded correctly' ' -	grep "git://example.org/bar.git" trash/tmp +test_expect_success 'generate bar summary' 'cgit_url "bar" >tmp' +test_expect_success 'no commit 45' '! grep "commit 45" tmp' +test_expect_success 'find commit 46' 'grep "commit 46" tmp' +test_expect_success 'find commit 50' 'grep "commit 50" tmp' +test_expect_success 'find branch master' 'grep "master" tmp' +test_expect_success 'no tags' '! grep "tags" tmp' +test_expect_success 'clone-url expanded correctly' ' +	grep "git://example.org/bar.git" tmp  ' -tests_done +test_done diff --git a/tests/t0103-log.sh b/tests/t0103-log.sh index 67fcba0..bdf1435 100755 --- a/tests/t0103-log.sh +++ b/tests/t0103-log.sh @@ -1,25 +1,24 @@  #!/bin/sh +test_description='Check content on log page'  . ./setup.sh -prepare_tests "Check content on log page" +test_expect_success 'generate foo/log' 'cgit_url "foo/log" >tmp' +test_expect_success 'find commit 1' 'grep "commit 1" tmp' +test_expect_success 'find commit 5' 'grep "commit 5" tmp' -run_test 'generate foo/log' 'cgit_url "foo/log" >trash/tmp' -run_test 'find commit 1' 'grep "commit 1" trash/tmp' -run_test 'find commit 5' 'grep "commit 5" trash/tmp' +test_expect_success 'generate bar/log' 'cgit_url "bar/log" >tmp' +test_expect_success 'find commit 1' 'grep "commit 1" tmp' +test_expect_success 'find commit 50' 'grep "commit 50" tmp' -run_test 'generate bar/log' 'cgit_url "bar/log" >trash/tmp' -run_test 'find commit 1' 'grep "commit 1" trash/tmp' -run_test 'find commit 50' 'grep "commit 50" trash/tmp' - -run_test 'generate "with%20space/log?qt=grep&q=commit+1"' ' -	cgit_url "with+space/log&qt=grep&q=commit+1" >trash/tmp +test_expect_success 'generate "with%20space/log?qt=grep&q=commit+1"' ' +	cgit_url "with+space/log&qt=grep&q=commit+1" >tmp  ' -run_test 'find commit 1' 'grep "commit 1" trash/tmp' -run_test 'find link with %20 in path' 'grep "/with%20space/log/?qt=grep" trash/tmp' -run_test 'find link with + in arg' 'grep "/log/?qt=grep&q=commit+1" trash/tmp' -run_test 'no links with space in path' '! grep "href=./with space/" trash/tmp' -run_test 'no links with space in arg' '! grep "q=commit 1" trash/tmp' -run_test 'commit 2 is not visible' '! grep "commit 2" trash/tmp' +test_expect_success 'find commit 1' 'grep "commit 1" tmp' +test_expect_success 'find link with %20 in path' 'grep "/with%20space/log/?qt=grep" tmp' +test_expect_success 'find link with + in arg' 'grep "/log/?qt=grep&q=commit+1" tmp' +test_expect_success 'no links with space in path' '! grep "href=./with space/" tmp' +test_expect_success 'no links with space in arg' '! grep "q=commit 1" tmp' +test_expect_success 'commit 2 is not visible' '! grep "commit 2" tmp' -tests_done +test_done diff --git a/tests/t0104-tree.sh b/tests/t0104-tree.sh index 7aa3b8d..100b026 100755 --- a/tests/t0104-tree.sh +++ b/tests/t0104-tree.sh @@ -1,33 +1,32 @@  #!/bin/sh +test_description='Check content on tree page'  . ./setup.sh -prepare_tests "Check content on tree page" +test_expect_success 'generate bar/tree' 'cgit_url "bar/tree" >tmp' +test_expect_success 'find file-1' 'grep "file-1" tmp' +test_expect_success 'find file-50' 'grep "file-50" tmp' -run_test 'generate bar/tree' 'cgit_url "bar/tree" >trash/tmp' -run_test 'find file-1' 'grep "file-1" trash/tmp' -run_test 'find file-50' 'grep "file-50" trash/tmp' +test_expect_success 'generate bar/tree/file-50' 'cgit_url "bar/tree/file-50" >tmp' -run_test 'generate bar/tree/file-50' 'cgit_url "bar/tree/file-50" >trash/tmp' - -run_test 'find line 1' ' -	grep "<a class=.no. id=.n1. name=.n1. href=.#n1.>1</a>" trash/tmp +test_expect_success 'find line 1' ' +	grep "<a class=.no. id=.n1. name=.n1. href=.#n1.>1</a>" tmp  ' -run_test 'no line 2' ' -	! grep "<a class=.no. id=.n2. name=.n2. href=.#n2.>2</a>" trash/tmp +test_expect_success 'no line 2' ' +	! grep "<a class=.no. id=.n2. name=.n2. href=.#n2.>2</a>" tmp  ' -run_test 'generate foo+bar/tree' 'cgit_url "foo%2bbar/tree" >trash/tmp' +test_expect_success 'generate foo+bar/tree' 'cgit_url "foo%2bbar/tree" >tmp' -run_test 'verify a+b link' ' -	grep "/foo+bar/tree/a+b" trash/tmp +test_expect_success 'verify a+b link' ' +	grep "/foo+bar/tree/a+b" tmp  ' -run_test 'generate foo+bar/tree?h=1+2' 'cgit_url "foo%2bbar/tree&h=1%2b2" >trash/tmp' +test_expect_success 'generate foo+bar/tree?h=1+2' 'cgit_url "foo%2bbar/tree&h=1%2b2" >tmp' -run_test 'verify a+b?h=1+2 link' ' -	grep "/foo+bar/tree/a+b?h=1%2b2" trash/tmp +test_expect_success 'verify a+b?h=1+2 link' ' +	grep "/foo+bar/tree/a+b?h=1%2b2" tmp  ' -tests_done +test_done diff --git a/tests/t0105-commit.sh b/tests/t0105-commit.sh index 31b554b..9cdf55c 100755 --- a/tests/t0105-commit.sh +++ b/tests/t0105-commit.sh @@ -1,37 +1,36 @@  #!/bin/sh +test_description='Check content on commit page'  . ./setup.sh -prepare_tests "Check content on commit page" +test_expect_success 'generate foo/commit' 'cgit_url "foo/commit" >tmp' +test_expect_success 'find tree link' 'grep "<a href=./foo/tree/.>" tmp' +test_expect_success 'find parent link' 'grep -E "<a href=./foo/commit/\?id=.+>" tmp' -run_test 'generate foo/commit' 'cgit_url "foo/commit" >trash/tmp' -run_test 'find tree link' 'grep "<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 "<div class=.commit-subject.>commit 5<" trash/tmp +test_expect_success 'find commit subject' ' +	grep "<div class=.commit-subject.>commit 5<" tmp  ' -run_test 'find commit msg' 'grep "<div class=.commit-msg.></div>" trash/tmp' -run_test 'find diffstat' 'grep "<table summary=.diffstat. class=.diffstat.>" trash/tmp' +test_expect_success 'find commit msg' 'grep "<div class=.commit-msg.></div>" tmp' +test_expect_success 'find diffstat' 'grep "<table summary=.diffstat. class=.diffstat.>" tmp' -run_test 'find diff summary' ' -	grep "1 files changed, 1 insertions, 0 deletions" trash/tmp +test_expect_success 'find diff summary' ' +	grep "1 files changed, 1 insertions, 0 deletions" tmp  ' -run_test 'get root commit' ' -	root=$(cd trash/repos/foo && git rev-list --reverse HEAD | head -1) && -	cgit_url "foo/commit&id=$root" >trash/tmp && -	grep "</html>" trash/tmp +test_expect_success 'get root commit' ' +	root=$(cd repos/foo && git rev-list --reverse HEAD | head -1) && +	cgit_url "foo/commit&id=$root" >tmp && +	grep "</html>" tmp  ' -run_test 'root commit contains diffstat' ' -	grep "<a href=./foo/diff/file-1.id=[0-9a-f]\{40\}.>file-1</a>" trash/tmp +test_expect_success 'root commit contains diffstat' ' +	grep "<a href=./foo/diff/file-1.id=[0-9a-f]\{40\}.>file-1</a>" tmp  ' -run_test 'root commit contains diff' ' -	grep ">diff --git a/file-1 b/file-1<" trash/tmp && -	grep "<div class=.add.>+1</div>" trash/tmp +test_expect_success 'root commit contains diff' ' +	grep ">diff --git a/file-1 b/file-1<" tmp && +	grep "<div class=.add.>+1</div>" tmp  ' -tests_done +test_done diff --git a/tests/t0106-diff.sh b/tests/t0106-diff.sh index eee0c8c..82b645e 100755 --- a/tests/t0106-diff.sh +++ b/tests/t0106-diff.sh @@ -1,20 +1,19 @@  #!/bin/sh +test_description='Check content on diff page'  . ./setup.sh -prepare_tests "Check content on diff page" +test_expect_success 'generate foo/diff' 'cgit_url "foo/diff" >tmp' +test_expect_success 'find diff header' 'grep "a/file-5 b/file-5" tmp' +test_expect_success 'find blob link' 'grep "<a href=./foo/tree/file-5?id=" tmp' +test_expect_success 'find added file' 'grep "new file mode 100644" tmp' -run_test 'generate foo/diff' 'cgit_url "foo/diff" >trash/tmp' -run_test 'find diff header' 'grep "a/file-5 b/file-5" trash/tmp' -run_test 'find blob link' 'grep "<a href=./foo/tree/file-5?id=" trash/tmp' -run_test 'find added file' 'grep "new file mode 100644" trash/tmp' - -run_test 'find hunk header' ' -	grep "<div class=.hunk.>@@ -0,0 +1 @@</div>" trash/tmp +test_expect_success 'find hunk header' ' +	grep "<div class=.hunk.>@@ -0,0 +1 @@</div>" tmp  ' -run_test 'find added line' ' -	grep "<div class=.add.>+5</div>" trash/tmp +test_expect_success 'find added line' ' +	grep "<div class=.add.>+5</div>" tmp  ' -tests_done +test_done diff --git a/tests/t0107-snapshot.sh b/tests/t0107-snapshot.sh index 132d2e9..4fbe45e 100755 --- a/tests/t0107-snapshot.sh +++ b/tests/t0107-snapshot.sh @@ -1,77 +1,76 @@  #!/bin/sh +test_description='Verify snapshot'  . ./setup.sh -prepare_tests "Verify snapshot" - -run_test 'get foo/snapshot/master.tar.gz' ' -	cgit_url "foo/snapshot/master.tar.gz" >trash/tmp +test_expect_success 'get foo/snapshot/master.tar.gz' ' +	cgit_url "foo/snapshot/master.tar.gz" >tmp  ' -run_test 'check html headers' ' -	head -n 1 trash/tmp | +test_expect_success 'check html headers' ' +	head -n 1 tmp |  	grep "Content-Type: application/x-gzip" && -	head -n 2 trash/tmp | +	head -n 2 tmp |  	grep "Content-Disposition: inline; filename=.master.tar.gz."  ' -run_test 'strip off the header lines' ' -	tail -n +6 trash/tmp > trash/master.tar.gz +test_expect_success 'strip off the header lines' ' +	tail -n +6 tmp > master.tar.gz  ' -run_test 'verify gzip format' ' -	gunzip --test trash/master.tar.gz +test_expect_success 'verify gzip format' ' +	gunzip --test master.tar.gz  ' -run_test 'untar' ' -	rm -rf trash/master && -	tar -xf trash/master.tar.gz -C trash +test_expect_success 'untar' ' +	rm -rf master && +	tar -xf master.tar.gz  ' -run_test 'count files' ' -	c=$(ls -1 trash/master/ | wc -l) && -	test $c = 5 +test_expect_success 'count files' ' +	ls master/ >output && +	test_line_count = 5 output  ' -run_test 'verify untarred file-5' ' -	grep "^5$" trash/master/file-5 && -	test $(cat trash/master/file-5 | wc -l) = 1 +test_expect_success 'verify untarred file-5' ' +	grep "^5$" master/file-5 && +	test_line_count = 1 master/file-5  ' -run_test 'get foo/snapshot/master.zip' ' -	cgit_url "foo/snapshot/master.zip" >trash/tmp +test_expect_success 'get foo/snapshot/master.zip' ' +	cgit_url "foo/snapshot/master.zip" >tmp  ' -run_test 'check HTML headers (zip)' ' -	head -n 1 trash/tmp | +test_expect_success 'check HTML headers (zip)' ' +	head -n 1 tmp |  	grep "Content-Type: application/x-zip" && -	head -n 2 trash/tmp | +	head -n 2 tmp |  	grep "Content-Disposition: inline; filename=.master.zip."  ' -run_test 'strip off the header lines (zip)' ' -	tail -n +6 trash/tmp >trash/master.zip +test_expect_success 'strip off the header lines (zip)' ' +	tail -n +6 tmp >master.zip  ' -run_test 'verify zip format' ' -	unzip -t trash/master.zip +test_expect_success 'verify zip format' ' +	unzip -t master.zip  ' -run_test 'unzip' ' -	rm -rf trash/master && -	unzip trash/master.zip -d trash +test_expect_success 'unzip' ' +	rm -rf master && +	unzip master.zip  ' -run_test 'count files (zip)' ' -	c=$(ls -1 trash/master/ | wc -l) && -	test $c = 5 +test_expect_success 'count files (zip)' ' +	ls master/ >output && +	test_line_count = 5 output  ' -run_test 'verify unzipped file-5' ' -	 grep "^5$" trash/master/file-5 && -	 test $(cat trash/master/file-5 | wc -l) = 1 +test_expect_success 'verify unzipped file-5' ' +	grep "^5$" master/file-5 && +	test_line_count = 1 master/file-5  ' -tests_done +test_done diff --git a/tests/t0108-patch.sh b/tests/t0108-patch.sh index f92f69c..3b5bae4 100755 --- a/tests/t0108-patch.sh +++ b/tests/t0108-patch.sh @@ -1,39 +1,38 @@  #!/bin/sh +test_description='Check content on patch page'  . ./setup.sh -prepare_tests "Check content on patch page" - -run_test 'generate foo/patch' ' -	cgit_query "url=foo/patch" >trash/tmp +test_expect_success 'generate foo/patch' ' +	cgit_query "url=foo/patch" >tmp  ' -run_test 'find `From:` line' ' -	grep "^From: " trash/tmp +test_expect_success 'find `From:` line' ' +	grep "^From: " tmp  ' -run_test 'find `Date:` line' ' -	grep "^Date: " trash/tmp +test_expect_success 'find `Date:` line' ' +	grep "^Date: " tmp  ' -run_test 'find `Subject:` line' ' -	grep "^Subject: commit 5" trash/tmp +test_expect_success 'find `Subject:` line' ' +	grep "^Subject: commit 5" tmp  ' -run_test 'find `cgit` signature' ' -	tail -1 trash/tmp | grep "^cgit" +test_expect_success 'find `cgit` signature' ' +	tail -1 tmp | grep "^cgit"  ' -run_test 'find initial commit' ' -	root=$(git --git-dir="$PWD/trash/repos/foo/.git" rev-list HEAD | tail -1) +test_expect_success 'find initial commit' ' +	root=$(git --git-dir="$PWD/repos/foo/.git" rev-list HEAD | tail -1)  ' -run_test 'generate patch for initial commit' ' -	cgit_query "url=foo/patch&id=$root" >trash/tmp +test_expect_success 'generate patch for initial commit' ' +	cgit_query "url=foo/patch&id=$root" >tmp  ' -run_test 'find `cgit` signature' ' -	tail -1 trash/tmp | grep "^cgit" +test_expect_success 'find `cgit` signature' ' +	tail -1 tmp | grep "^cgit"  ' -tests_done +test_done | 
