summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Rast <trast@student.ethz.ch>2009-02-19 11:13:42 (GMT)
committerJunio C Hamano <gitster@pobox.com>2009-02-20 08:02:48 (GMT)
commitb26d8d217d8d960cbd9ed1dbf6b3cccfd1a3a4db (patch)
treeeef53a92490500092fd0683e953c9a30a7ee5ef9
parentfcbc6efc7c56973e0a308012d2ae1b42c6b11a33 (diff)
downloadgit-b26d8d217d8d960cbd9ed1dbf6b3cccfd1a3a4db.zip
git-b26d8d217d8d960cbd9ed1dbf6b3cccfd1a3a4db.tar.gz
git-b26d8d217d8d960cbd9ed1dbf6b3cccfd1a3a4db.tar.bz2
Test git-patch-id
So far, git-patch-id was untested. Add some simple checks for output format and patch (in)equality. Signed-off-by: Thomas Rast <trast@student.ethz.ch> Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rwxr-xr-xt/t4203-patch-id.sh38
1 files changed, 38 insertions, 0 deletions
diff --git a/t/t4203-patch-id.sh b/t/t4203-patch-id.sh
new file mode 100755
index 0000000..04f7bae
--- /dev/null
+++ b/t/t4203-patch-id.sh
@@ -0,0 +1,38 @@
+#!/bin/sh
+
+test_description='git patch-id'
+
+. ./test-lib.sh
+
+test_expect_success 'setup' '
+ test_commit initial foo a &&
+ test_commit first foo b &&
+ git checkout -b same HEAD^ &&
+ test_commit same-msg foo b &&
+ git checkout -b notsame HEAD^ &&
+ test_commit notsame-msg foo c
+'
+
+test_expect_success 'patch-id output is well-formed' '
+ git log -p -1 | git patch-id > output &&
+ grep "^[a-f0-9]\{40\} $(git rev-parse HEAD)$" output
+'
+
+get_patch_id () {
+ git log -p -1 "$1" | git patch-id |
+ sed "s# .*##" > patch-id_"$1"
+}
+
+test_expect_success 'patch-id detects equality' '
+ get_patch_id master &&
+ get_patch_id same &&
+ test_cmp patch-id_master patch-id_same
+'
+
+test_expect_success 'patch-id detects inequality' '
+ get_patch_id master &&
+ get_patch_id notsame &&
+ ! test_cmp patch-id_master patch-id_notsame
+'
+
+test_done