From: Karl Hasselström Date: Thu, 18 May 2006 20:36:41 +0000 (+0100) Subject: Tests for branch names with slashes X-Git-Tag: v0.14.3~492 X-Git-Url: https://git.distorted.org.uk/~mdw/stgit/commitdiff_plain/16dcfb85fbcbb4a961ed18f8e69d3cc2387c33df Tests for branch names with slashes Test a number of operations on a repository that has branch names containing slashes (that is, branches living in a subdirectory of .git/refs/heads). Signed-off-by: Karl Hasselström --- diff --git a/t/t0001-subdir-branches.sh b/t/t0001-subdir-branches.sh new file mode 100644 index 0000000..e464436 --- /dev/null +++ b/t/t0001-subdir-branches.sh @@ -0,0 +1,59 @@ +#!/bin/sh +# +# Copyright (c) 2006 Karl Hasselström +# + +test_description='Branch names containing slashes + +Test a number of operations on a repository that has branch names +containing slashes (that is, branches living in a subdirectory of +.git/refs/heads).' + +. ./test-lib.sh + +test_expect_success 'Create a patch' \ + 'stg init && + echo "foo" > foo.txt && + stg add foo.txt && + stg new foo -m "Add foo.txt" && + stg refresh' + +test_expect_success 'Old and new id with non-slashy branch' \ + 'stg id foo && + stg id foo// && + stg id foo/ && + stg id foo//top && + stg id foo/top && + stg id foo@master && + stg id foo@master//top && + stg id foo@master/top' + +test_expect_success 'Clone branch to slashier name' \ + 'stg branch --clone x/y/z' + +test_expect_success 'Try new form of id with slashy branch' \ + 'stg id foo && + stg id foo// && + stg id foo//top && + stg id foo@x/y/z && + stg id foo@x/y/z//top' + +test_expect_failure 'Try old id with slashy branch' \ + 'stg id foo/ || + stg id foo/top || + stg id foo@x/y/z/top' + +test_expect_success 'Create patch in slashy branch' \ + 'echo "bar" >> foo.txt && + stg new bar -m "Add another line" && + stg refresh' + +test_expect_success 'Rename branches' \ + 'stg branch --rename master goo/gaa && + test ! -e .git/refs/heads/master && + stg branch --rename goo/gaa x1/x2/x3/x4 && + test ! -e .git/refs/heads/goo && + stg branch --rename x1/x2/x3/x4 servant && + test ! -e .git/refs/heads/x1' + +test_done