#!/bin/sh setglobal test_description = ''git archive attribute tests'' source ./test-lib.sh setglobal SUBSTFORMAT = ''%H (%h)%n'' proc test_expect_exists { test_expect_success " $1 exists" "test -e $1" } proc test_expect_missing { test_expect_success " $1 does not exist" "test ! -e $1" } test_expect_success 'setup' ' echo ignored >ignored && echo ignored export-ignore >>.git/info/attributes && git add ignored && echo ignored by tree >ignored-by-tree && echo ignored-by-tree export-ignore >.gitattributes && git add ignored-by-tree .gitattributes && echo ignored by worktree >ignored-by-worktree && echo ignored-by-worktree export-ignore >.gitattributes && git add ignored-by-worktree && printf "A\$Format:%s\$O" "$SUBSTFORMAT" >nosubstfile && printf "A\$Format:%s\$O" "$SUBSTFORMAT" >substfile1 && printf "A not substituted O" >substfile2 && echo "substfile?" export-subst >>.git/info/attributes && git add nosubstfile substfile1 substfile2 && git commit -m. && git clone --bare . bare && cp .git/info/attributes bare/info/attributes ' test_expect_success 'git archive' ' git archive HEAD >archive.tar && (mkdir archive && cd archive && "$TAR" xf -) worktree.tar && (mkdir worktree && cd worktree && "$TAR" xf -) worktree.tar && (mkdir worktree2 && cd worktree2 && "$TAR" xf -) bare-archive.tar && test_cmp_bin archive.tar bare-archive.tar ' test_expect_success 'git archive with worktree attributes, bare' ' (cd bare && git archive --worktree-attributes HEAD) >bare-worktree.tar && (mkdir bare-worktree && cd bare-worktree && "$TAR" xf -) substfile1.expected && test_cmp nosubstfile archive/nosubstfile && test_cmp substfile1.expected archive/substfile1 && test_cmp substfile2 archive/substfile2 ' test_done