Merge branch 'jc/mktree' into sb/opt-filename
* jc/mktree: mktree: validate entry type in input mktree --batch: build more than one tree object mktree --missing: updated usage message and man page mktree --missing: allow missing objects t1010: add mktree test mktree: do not barf on a submodule commit builtin-mktree.c: use a helper function to handle one line of input mktree: use parse-options build-in git-mktree
This commit is contained in:
71
t/t1010-mktree.sh
Executable file
71
t/t1010-mktree.sh
Executable file
@ -0,0 +1,71 @@
|
||||
#!/bin/sh
|
||||
|
||||
test_description='git mktree'
|
||||
|
||||
. ./test-lib.sh
|
||||
|
||||
test_expect_success setup '
|
||||
for d in a a. a0
|
||||
do
|
||||
mkdir "$d" && echo "$d/one" >"$d/one" &&
|
||||
git add "$d"
|
||||
done &&
|
||||
echo zero >one &&
|
||||
git update-index --add --info-only one &&
|
||||
git write-tree --missing-ok >tree.missing &&
|
||||
git ls-tree $(cat tree.missing) >top.missing &&
|
||||
git ls-tree -r $(cat tree.missing) >all.missing &&
|
||||
echo one >one &&
|
||||
git add one &&
|
||||
git write-tree >tree &&
|
||||
git ls-tree $(cat tree) >top &&
|
||||
git ls-tree -r $(cat tree) >all &&
|
||||
test_tick &&
|
||||
git commit -q -m one &&
|
||||
H=$(git rev-parse HEAD) &&
|
||||
git update-index --add --cacheinfo 160000 $H sub &&
|
||||
test_tick &&
|
||||
git commit -q -m two &&
|
||||
git rev-parse HEAD^{tree} >tree.withsub &&
|
||||
git ls-tree HEAD >top.withsub &&
|
||||
git ls-tree -r HEAD >all.withsub
|
||||
'
|
||||
|
||||
test_expect_success 'ls-tree piped to mktree (1)' '
|
||||
git mktree <top >actual &&
|
||||
test_cmp tree actual
|
||||
'
|
||||
|
||||
test_expect_success 'ls-tree piped to mktree (2)' '
|
||||
git mktree <top.withsub >actual &&
|
||||
test_cmp tree.withsub actual
|
||||
'
|
||||
|
||||
test_expect_success 'ls-tree output in wrong order given to mktree (1)' '
|
||||
perl -e "print reverse <>" <top |
|
||||
git mktree >actual &&
|
||||
test_cmp tree actual
|
||||
'
|
||||
|
||||
test_expect_success 'ls-tree output in wrong order given to mktree (2)' '
|
||||
perl -e "print reverse <>" <top.withsub |
|
||||
git mktree >actual &&
|
||||
test_cmp tree.withsub actual
|
||||
'
|
||||
|
||||
test_expect_success 'allow missing object with --missing' '
|
||||
git mktree --missing <top.missing >actual &&
|
||||
test_cmp tree.missing actual
|
||||
'
|
||||
|
||||
test_expect_failure 'mktree reads ls-tree -r output (1)' '
|
||||
git mktree <all >actual &&
|
||||
test_cmp tree actual
|
||||
'
|
||||
|
||||
test_expect_failure 'mktree reads ls-tree -r output (2)' '
|
||||
git mktree <all.withsub >actual &&
|
||||
test_cmp tree.withsub actual
|
||||
'
|
||||
|
||||
test_done
|
Reference in New Issue
Block a user