#!/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" || return 1 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 actual && test_cmp tree actual ' test_expect_success 'ls-tree piped to mktree (2)' ' git mktree actual && test_cmp tree.withsub actual ' test_expect_success 'ls-tree output in wrong order given to mktree (1)' ' perl -e "print reverse <>" actual && test_cmp tree actual ' test_expect_success 'ls-tree output in wrong order given to mktree (2)' ' perl -e "print reverse <>" actual && test_cmp tree.withsub actual ' test_expect_success 'allow missing object with --missing' ' git mktree --missing actual && test_cmp tree.missing actual ' test_expect_success 'mktree refuses to read ls-tree -r output (1)' ' test_must_fail git mktree