|  | #!/bin/sh | 
|  |  | 
|  | test_description='git init' | 
|  |  | 
|  | . ./test-lib.sh | 
|  |  | 
|  | check_config () { | 
|  | if test -d "$1" && test -f "$1/config" && test -d "$1/refs" | 
|  | then | 
|  | : happy | 
|  | else | 
|  | echo "expected a directory $1, a file $1/config and $1/refs" | 
|  | return 1 | 
|  | fi | 
|  | bare=$(GIT_CONFIG="$1/config" git config --bool core.bare) | 
|  | worktree=$(GIT_CONFIG="$1/config" git config core.worktree) || | 
|  | worktree=unset | 
|  |  | 
|  | test "$bare" = "$2" && test "$worktree" = "$3" || { | 
|  | echo "expected bare=$2 worktree=$3" | 
|  | echo "     got bare=$bare worktree=$worktree" | 
|  | return 1 | 
|  | } | 
|  | } | 
|  |  | 
|  | test_expect_success 'plain' ' | 
|  | ( | 
|  | sane_unset GIT_DIR GIT_WORK_TREE && | 
|  | mkdir plain && | 
|  | cd plain && | 
|  | git init | 
|  | ) && | 
|  | check_config plain/.git false unset | 
|  | ' | 
|  |  | 
|  | test_expect_success 'plain nested in bare' ' | 
|  | ( | 
|  | sane_unset GIT_DIR GIT_WORK_TREE && | 
|  | git init --bare bare-ancestor.git && | 
|  | cd bare-ancestor.git && | 
|  | mkdir plain-nested && | 
|  | cd plain-nested && | 
|  | git init | 
|  | ) && | 
|  | check_config bare-ancestor.git/plain-nested/.git false unset | 
|  | ' | 
|  |  | 
|  | test_expect_success 'plain through aliased command, outside any git repo' ' | 
|  | ( | 
|  | sane_unset GIT_DIR GIT_WORK_TREE && | 
|  | HOME=$(pwd)/alias-config && | 
|  | export HOME && | 
|  | mkdir alias-config && | 
|  | echo "[alias] aliasedinit = init" >alias-config/.gitconfig && | 
|  |  | 
|  | GIT_CEILING_DIRECTORIES=$(pwd) && | 
|  | export GIT_CEILING_DIRECTORIES && | 
|  |  | 
|  | mkdir plain-aliased && | 
|  | cd plain-aliased && | 
|  | git aliasedinit | 
|  | ) && | 
|  | check_config plain-aliased/.git false unset | 
|  | ' | 
|  |  | 
|  | test_expect_failure 'plain nested through aliased command' ' | 
|  | ( | 
|  | sane_unset GIT_DIR GIT_WORK_TREE && | 
|  | git init plain-ancestor-aliased && | 
|  | cd plain-ancestor-aliased && | 
|  | echo "[alias] aliasedinit = init" >>.git/config && | 
|  | mkdir plain-nested && | 
|  | cd plain-nested && | 
|  | git aliasedinit | 
|  | ) && | 
|  | check_config plain-ancestor-aliased/plain-nested/.git false unset | 
|  | ' | 
|  |  | 
|  | test_expect_failure 'plain nested in bare through aliased command' ' | 
|  | ( | 
|  | sane_unset GIT_DIR GIT_WORK_TREE && | 
|  | git init --bare bare-ancestor-aliased.git && | 
|  | cd bare-ancestor-aliased.git && | 
|  | echo "[alias] aliasedinit = init" >>config && | 
|  | mkdir plain-nested && | 
|  | cd plain-nested && | 
|  | git aliasedinit | 
|  | ) && | 
|  | check_config bare-ancestor-aliased.git/plain-nested/.git false unset | 
|  | ' | 
|  |  | 
|  | test_expect_success 'plain with GIT_WORK_TREE' ' | 
|  | if ( | 
|  | sane_unset GIT_DIR && | 
|  | mkdir plain-wt && | 
|  | cd plain-wt && | 
|  | GIT_WORK_TREE=$(pwd) git init | 
|  | ) | 
|  | then | 
|  | echo Should have failed -- GIT_WORK_TREE should not be used | 
|  | false | 
|  | fi | 
|  | ' | 
|  |  | 
|  | test_expect_success 'plain bare' ' | 
|  | ( | 
|  | sane_unset GIT_DIR GIT_WORK_TREE GIT_CONFIG && | 
|  | mkdir plain-bare-1 && | 
|  | cd plain-bare-1 && | 
|  | git --bare init | 
|  | ) && | 
|  | check_config plain-bare-1 true unset | 
|  | ' | 
|  |  | 
|  | test_expect_success 'plain bare with GIT_WORK_TREE' ' | 
|  | if ( | 
|  | sane_unset GIT_DIR GIT_CONFIG && | 
|  | mkdir plain-bare-2 && | 
|  | cd plain-bare-2 && | 
|  | GIT_WORK_TREE=$(pwd) git --bare init | 
|  | ) | 
|  | then | 
|  | echo Should have failed -- GIT_WORK_TREE should not be used | 
|  | false | 
|  | fi | 
|  | ' | 
|  |  | 
|  | test_expect_success 'GIT_DIR bare' ' | 
|  |  | 
|  | ( | 
|  | sane_unset GIT_CONFIG && | 
|  | mkdir git-dir-bare.git && | 
|  | GIT_DIR=git-dir-bare.git git init | 
|  | ) && | 
|  | check_config git-dir-bare.git true unset | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init --bare' ' | 
|  |  | 
|  | ( | 
|  | sane_unset GIT_DIR GIT_WORK_TREE GIT_CONFIG && | 
|  | mkdir init-bare.git && | 
|  | cd init-bare.git && | 
|  | git init --bare | 
|  | ) && | 
|  | check_config init-bare.git true unset | 
|  | ' | 
|  |  | 
|  | test_expect_success 'GIT_DIR non-bare' ' | 
|  |  | 
|  | ( | 
|  | sane_unset GIT_CONFIG && | 
|  | mkdir non-bare && | 
|  | cd non-bare && | 
|  | GIT_DIR=.git git init | 
|  | ) && | 
|  | check_config non-bare/.git false unset | 
|  | ' | 
|  |  | 
|  | test_expect_success 'GIT_DIR & GIT_WORK_TREE (1)' ' | 
|  |  | 
|  | ( | 
|  | sane_unset GIT_CONFIG && | 
|  | mkdir git-dir-wt-1.git && | 
|  | GIT_WORK_TREE=$(pwd) GIT_DIR=git-dir-wt-1.git git init | 
|  | ) && | 
|  | check_config git-dir-wt-1.git false "$(pwd)" | 
|  | ' | 
|  |  | 
|  | test_expect_success 'GIT_DIR & GIT_WORK_TREE (2)' ' | 
|  |  | 
|  | if ( | 
|  | sane_unset GIT_CONFIG && | 
|  | mkdir git-dir-wt-2.git && | 
|  | GIT_WORK_TREE=$(pwd) GIT_DIR=git-dir-wt-2.git git --bare init | 
|  | ) | 
|  | then | 
|  | echo Should have failed -- --bare should not be used | 
|  | false | 
|  | fi | 
|  | ' | 
|  |  | 
|  | test_expect_success 'reinit' ' | 
|  |  | 
|  | ( | 
|  | sane_unset GIT_CONFIG GIT_WORK_TREE GIT_CONFIG && | 
|  |  | 
|  | mkdir again && | 
|  | cd again && | 
|  | git init >out1 2>err1 && | 
|  | git init >out2 2>err2 | 
|  | ) && | 
|  | test_i18ngrep "Initialized empty" again/out1 && | 
|  | test_i18ngrep "Reinitialized existing" again/out2 && | 
|  | >again/empty && | 
|  | test_i18ncmp again/empty again/err1 && | 
|  | test_i18ncmp again/empty again/err2 | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init with --template' ' | 
|  | mkdir template-source && | 
|  | echo content >template-source/file && | 
|  | ( | 
|  | mkdir template-custom && | 
|  | cd template-custom && | 
|  | git init --template=../template-source | 
|  | ) && | 
|  | test_cmp template-source/file template-custom/.git/file | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init with --template (blank)' ' | 
|  | ( | 
|  | mkdir template-plain && | 
|  | cd template-plain && | 
|  | git init | 
|  | ) && | 
|  | test -f template-plain/.git/info/exclude && | 
|  | ( | 
|  | mkdir template-blank && | 
|  | cd template-blank && | 
|  | git init --template= | 
|  | ) && | 
|  | ! test -f template-blank/.git/info/exclude | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init with init.templatedir set' ' | 
|  | mkdir templatedir-source && | 
|  | echo Content >templatedir-source/file && | 
|  | ( | 
|  | test_config="${HOME}/.gitconfig" && | 
|  | git config -f "$test_config"  init.templatedir "${HOME}/templatedir-source" && | 
|  | mkdir templatedir-set && | 
|  | cd templatedir-set && | 
|  | sane_unset GIT_TEMPLATE_DIR && | 
|  | NO_SET_GIT_TEMPLATE_DIR=t && | 
|  | export NO_SET_GIT_TEMPLATE_DIR && | 
|  | git init | 
|  | ) && | 
|  | test_cmp templatedir-source/file templatedir-set/.git/file | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init --bare/--shared overrides system/global config' ' | 
|  | ( | 
|  | test_config="$HOME"/.gitconfig && | 
|  | git config -f "$test_config" core.bare false && | 
|  | git config -f "$test_config" core.sharedRepository 0640 && | 
|  | mkdir init-bare-shared-override && | 
|  | cd init-bare-shared-override && | 
|  | git init --bare --shared=0666 | 
|  | ) && | 
|  | check_config init-bare-shared-override true unset && | 
|  | test x0666 = \ | 
|  | x`git config -f init-bare-shared-override/config core.sharedRepository` | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init honors global core.sharedRepository' ' | 
|  | ( | 
|  | test_config="$HOME"/.gitconfig && | 
|  | git config -f "$test_config" core.sharedRepository 0666 && | 
|  | mkdir shared-honor-global && | 
|  | cd shared-honor-global && | 
|  | git init | 
|  | ) && | 
|  | test x0666 = \ | 
|  | x`git config -f shared-honor-global/.git/config core.sharedRepository` | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init rejects insanely long --template' ' | 
|  | ( | 
|  | insane=$(printf "x%09999dx" 1) && | 
|  | mkdir test && | 
|  | cd test && | 
|  | test_must_fail git init --template=$insane | 
|  | ) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init creates a new directory' ' | 
|  | rm -fr newdir && | 
|  | ( | 
|  | git init newdir && | 
|  | test -d newdir/.git/refs | 
|  | ) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init creates a new bare directory' ' | 
|  | rm -fr newdir && | 
|  | ( | 
|  | git init --bare newdir && | 
|  | test -d newdir/refs | 
|  | ) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init recreates a directory' ' | 
|  | rm -fr newdir && | 
|  | ( | 
|  | mkdir newdir && | 
|  | git init newdir && | 
|  | test -d newdir/.git/refs | 
|  | ) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init recreates a new bare directory' ' | 
|  | rm -fr newdir && | 
|  | ( | 
|  | mkdir newdir && | 
|  | git init --bare newdir && | 
|  | test -d newdir/refs | 
|  | ) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init creates a new deep directory' ' | 
|  | rm -fr newdir && | 
|  | git init newdir/a/b/c && | 
|  | test -d newdir/a/b/c/.git/refs | 
|  | ' | 
|  |  | 
|  | test_expect_success POSIXPERM 'init creates a new deep directory (umask vs. shared)' ' | 
|  | rm -fr newdir && | 
|  | ( | 
|  | # Leading directories should honor umask while | 
|  | # the repository itself should follow "shared" | 
|  | umask 002 && | 
|  | git init --bare --shared=0660 newdir/a/b/c && | 
|  | test -d newdir/a/b/c/refs && | 
|  | ls -ld newdir/a newdir/a/b > lsab.out && | 
|  | ! grep -v "^drwxrw[sx]r-x" lsab.out && | 
|  | ls -ld newdir/a/b/c > lsc.out && | 
|  | ! grep -v "^drwxrw[sx]---" lsc.out | 
|  | ) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init notices EEXIST (1)' ' | 
|  | rm -fr newdir && | 
|  | ( | 
|  | >newdir && | 
|  | test_must_fail git init newdir && | 
|  | test -f newdir | 
|  | ) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init notices EEXIST (2)' ' | 
|  | rm -fr newdir && | 
|  | ( | 
|  | mkdir newdir && | 
|  | >newdir/a | 
|  | test_must_fail git init newdir/a/b && | 
|  | test -f newdir/a | 
|  | ) | 
|  | ' | 
|  |  | 
|  | test_expect_success POSIXPERM,SANITY 'init notices EPERM' ' | 
|  | rm -fr newdir && | 
|  | ( | 
|  | mkdir newdir && | 
|  | chmod -w newdir && | 
|  | test_must_fail git init newdir/a/b | 
|  | ) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init creates a new bare directory with global --bare' ' | 
|  | rm -rf newdir && | 
|  | git --bare init newdir && | 
|  | test -d newdir/refs | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init prefers command line to GIT_DIR' ' | 
|  | rm -rf newdir && | 
|  | mkdir otherdir && | 
|  | GIT_DIR=otherdir git --bare init newdir && | 
|  | test -d newdir/refs && | 
|  | ! test -d otherdir/refs | 
|  | ' | 
|  |  | 
|  | test_expect_success 'init with separate gitdir' ' | 
|  | rm -rf newdir && | 
|  | git init --separate-git-dir realgitdir newdir && | 
|  | echo "gitdir: `pwd`/realgitdir" >expected && | 
|  | test_cmp expected newdir/.git && | 
|  | test -d realgitdir/refs | 
|  | ' | 
|  |  | 
|  | test_expect_success 're-init on .git file' ' | 
|  | ( cd newdir && git init ) | 
|  | ' | 
|  |  | 
|  | test_expect_success 're-init to update git link' ' | 
|  | ( | 
|  | cd newdir && | 
|  | git init --separate-git-dir ../surrealgitdir | 
|  | ) && | 
|  | echo "gitdir: `pwd`/surrealgitdir" >expected && | 
|  | test_cmp expected newdir/.git && | 
|  | test -d surrealgitdir/refs && | 
|  | ! test -d realgitdir/refs | 
|  | ' | 
|  |  | 
|  | test_expect_success 're-init to move gitdir' ' | 
|  | rm -rf newdir realgitdir surrealgitdir && | 
|  | git init newdir && | 
|  | ( | 
|  | cd newdir && | 
|  | git init --separate-git-dir ../realgitdir | 
|  | ) && | 
|  | echo "gitdir: `pwd`/realgitdir" >expected && | 
|  | test_cmp expected newdir/.git && | 
|  | test -d realgitdir/refs | 
|  | ' | 
|  |  | 
|  | test_expect_success SYMLINKS 're-init to move gitdir symlink' ' | 
|  | rm -rf newdir realgitdir && | 
|  | git init newdir && | 
|  | ( | 
|  | cd newdir && | 
|  | mv .git here && | 
|  | ln -s here .git && | 
|  | git init --separate-git-dir ../realgitdir | 
|  | ) && | 
|  | echo "gitdir: `pwd`/realgitdir" >expected && | 
|  | test_cmp expected newdir/.git && | 
|  | test -d realgitdir/refs && | 
|  | ! test -d newdir/here | 
|  | ' | 
|  |  | 
|  | test_done |