]> git.cameronkatri.com Git - cgit.git/blobdiff - tests/t0108-patch.sh
t0108: Compare output with git-format-patch(1)
[cgit.git] / tests / t0108-patch.sh
index 6ee70b31f7546ceecf7ab9b1dca1359955f0b8f6..0a2ec2e11803763ed960cad868883532dea93a1f 100755 (executable)
@@ -1,39 +1,45 @@
 #!/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
+'
 
-run_test 'generate foo/patch' '
-       cgit_query "url=foo/patch" >trash/tmp
+test_expect_success 'find `From:` line' '
+       grep "^From: " tmp
 '
 
-run_test 'find `From:` line' '
-       grep -e "^From: " trash/tmp
+test_expect_success 'find `Date:` line' '
+       grep "^Date: " tmp
 '
 
-run_test 'find `Date:` line' '
-       grep -e "^Date: " trash/tmp
+test_expect_success 'find `Subject:` line' '
+       grep "^Subject: commit 5" tmp
 '
 
-run_test 'find `Subject:` line' '
-       grep -e "^Subject: commit 5" 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 -p --subject-prefix="" --signature="cgit $CGIT_VERSION" --stdout HEAD^ >tmp2
+       sed "1,5d" tmp >tmp_
+       cmp tmp_ tmp2
 '
 
-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 --max-parents=0 HEAD)
 '
 
-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 -e "^cgit"
+test_expect_success 'find `cgit` signature' '
+       tail -2 tmp | head -1 | grep "^cgit"
 '
 
-tests_done
+test_done