X-Git-Url: https://git.cameronkatri.com/cgit.git/blobdiff_plain/08352c7a02f057f6cbaf817ca7e53c53be590a62..60a930044d57faae4fcb84cba9d85310b0c767a7:/tests/t0108-patch.sh diff --git a/tests/t0108-patch.sh b/tests/t0108-patch.sh index 6ee70b3..013d680 100755 --- a/tests/t0108-patch.sh +++ b/tests/t0108-patch.sh @@ -1,39 +1,62 @@ #!/bin/sh +test_description='Check content on patch page' . ./setup.sh -prepare_tests "Check content on patch page" +test_expect_success 'generate foo/patch' ' + cgit_query "url=foo/patch" >tmp +' + +test_expect_success 'find `From:` line' ' + grep "^From: " tmp +' + +test_expect_success 'find `Date:` line' ' + grep "^Date: " tmp +' + +test_expect_success 'find `Subject:` line' ' + grep "^Subject: commit 5" tmp +' -run_test 'generate foo/patch' ' - cgit_query "url=foo/patch" >trash/tmp +test_expect_success 'find `cgit` signature' ' + tail -2 tmp | head -1 | grep "^cgit" ' -run_test 'find `From:` line' ' - grep -e "^From: " trash/tmp +test_expect_success 'compare with output of git-format-patch(1)' ' + CGIT_VERSION=$(sed -n "s/CGIT_VERSION = //p" ../../VERSION) && + git --git-dir="$PWD/repos/foo/.git" format-patch --subject-prefix="" --signature="cgit $CGIT_VERSION" --stdout HEAD^ >tmp2 && + strip_headers tmp_ && + test_cmp tmp_ tmp2 ' -run_test 'find `Date:` line' ' - grep -e "^Date: " trash/tmp +test_expect_success 'find initial commit' ' + root=$(git --git-dir="$PWD/repos/foo/.git" rev-list --max-parents=0 HEAD) ' -run_test 'find `Subject:` line' ' - grep -e "^Subject: commit 5" 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 -e "^cgit" +test_expect_success 'find `cgit` signature' ' + tail -2 tmp | head -1 | grep "^cgit" ' -run_test 'find initial commit' ' - root=$(git --git-dir="$PWD/trash/repos/foo/.git" rev-list HEAD | tail -1) +test_expect_success 'generate patches for multiple commits' ' + id=$(git --git-dir="$PWD/repos/foo/.git" rev-parse HEAD) && + id2=$(git --git-dir="$PWD/repos/foo/.git" rev-parse HEAD~3) && + cgit_query "url=foo/patch&id=$id&id2=$id2" >tmp ' -run_test 'generate patch for initial commit' ' - cgit_query "url=foo/patch&id=$root" >trash/tmp +test_expect_success 'find `cgit` signature' ' + tail -2 tmp | head -1 | grep "^cgit" ' -run_test 'find `cgit` signature' ' - tail -1 trash/tmp | grep -e "^cgit" +test_expect_success 'compare with output of git-format-patch(1)' ' + CGIT_VERSION=$(sed -n "s/CGIT_VERSION = //p" ../../VERSION) && + git --git-dir="$PWD/repos/foo/.git" format-patch -N --subject-prefix="" --signature="cgit $CGIT_VERSION" --stdout HEAD~3..HEAD >tmp2 && + strip_headers tmp_ && + test_cmp tmp_ tmp2 ' -tests_done +test_done