summaryrefslogtreecommitdiff
path: root/cgit/tests/t0108-patch.sh
diff options
context:
space:
mode:
authorMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-02 18:41:43 +0300
committerMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-02 18:41:43 +0300
commit6bf7c5ce92ff6237c0b17c332873805018812b40 (patch)
tree18905aaed6af4be08f686f18aac1660f9606628d /cgit/tests/t0108-patch.sh
parentc93af47179aad2d3fae3bc756d058f3ff1a14ccf (diff)
parente94c3cd8bda6f9c2a6d0a613733c6eeddd1a406f (diff)
downloadProject-Tick-6bf7c5ce92ff6237c0b17c332873805018812b40.tar.gz
Project-Tick-6bf7c5ce92ff6237c0b17c332873805018812b40.zip
Add 'cgit/' from commit 'e94c3cd8bda6f9c2a6d0a613733c6eeddd1a406f'
git-subtree-dir: cgit git-subtree-mainline: c93af47179aad2d3fae3bc756d058f3ff1a14ccf git-subtree-split: e94c3cd8bda6f9c2a6d0a613733c6eeddd1a406f
Diffstat (limited to 'cgit/tests/t0108-patch.sh')
-rwxr-xr-xcgit/tests/t0108-patch.sh62
1 files changed, 62 insertions, 0 deletions
diff --git a/cgit/tests/t0108-patch.sh b/cgit/tests/t0108-patch.sh
new file mode 100755
index 0000000000..013d68024d
--- /dev/null
+++ b/cgit/tests/t0108-patch.sh
@@ -0,0 +1,62 @@
+#!/bin/sh
+
+test_description='Check content on patch page'
+. ./setup.sh
+
+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
+'
+
+test_expect_success 'find `cgit` signature' '
+ tail -2 tmp | head -1 | grep "^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 --subject-prefix="" --signature="cgit $CGIT_VERSION" --stdout HEAD^ >tmp2 &&
+ strip_headers <tmp >tmp_ &&
+ test_cmp tmp_ tmp2
+'
+
+test_expect_success 'find initial commit' '
+ root=$(git --git-dir="$PWD/repos/foo/.git" rev-list --max-parents=0 HEAD)
+'
+
+test_expect_success 'generate patch for initial commit' '
+ cgit_query "url=foo/patch&id=$root" >tmp
+'
+
+test_expect_success 'find `cgit` signature' '
+ tail -2 tmp | head -1 | grep "^cgit"
+'
+
+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
+'
+
+test_expect_success 'find `cgit` signature' '
+ tail -2 tmp | head -1 | grep "^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 >tmp_ &&
+ test_cmp tmp_ tmp2
+'
+
+test_done