Carefully excluding t1309, which sees independent development elsewhere at the time of writing, we transition above-mentioned tests to the default branch name `main`. This trick was performed via $ (cd t && sed -i -e 's/master/main/g' -e 's/MASTER/MAIN/g' \ -e 's/Master/Main/g' -e 's/naster/nain/g' -- t[01]*.sh && git checkout HEAD -- t1309\*) Note that t5533 contains a variation of the name `master` (`naster`) that we rename here, too. This allows us to define `GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main` for those tests. Helped-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com> Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			135 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
#!/bin/sh
 | 
						|
 | 
						|
test_description='.git file
 | 
						|
 | 
						|
Verify that plumbing commands work when .git is a file
 | 
						|
'
 | 
						|
GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
 | 
						|
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
 | 
						|
 | 
						|
. ./test-lib.sh
 | 
						|
 | 
						|
objpath() {
 | 
						|
	echo "$1" | sed -e 's|\(..\)|\1/|'
 | 
						|
}
 | 
						|
 | 
						|
test_expect_success 'initial setup' '
 | 
						|
	REAL="$(pwd)/.real" &&
 | 
						|
	mv .git "$REAL"
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'bad setup: invalid .git file format' '
 | 
						|
	echo "gitdir $REAL" >.git &&
 | 
						|
	test_must_fail git rev-parse 2>.err &&
 | 
						|
	test_i18ngrep "invalid gitfile format" .err
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'bad setup: invalid .git file path' '
 | 
						|
	echo "gitdir: $REAL.not" >.git &&
 | 
						|
	test_must_fail git rev-parse 2>.err &&
 | 
						|
	test_i18ngrep "not a git repository" .err
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'final setup + check rev-parse --git-dir' '
 | 
						|
	echo "gitdir: $REAL" >.git &&
 | 
						|
	test "$REAL" = "$(git rev-parse --git-dir)"
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'check hash-object' '
 | 
						|
	echo "foo" >bar &&
 | 
						|
	SHA=$(cat bar | git hash-object -w --stdin) &&
 | 
						|
	test_path_is_file "$REAL/objects/$(objpath $SHA)"
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'check cat-file' '
 | 
						|
	git cat-file blob $SHA >actual &&
 | 
						|
	test_cmp bar actual
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'check update-index' '
 | 
						|
	test_path_is_missing "$REAL/index" &&
 | 
						|
	rm -f "$REAL/objects/$(objpath $SHA)" &&
 | 
						|
	git update-index --add bar &&
 | 
						|
	test_path_is_file "$REAL/index" &&
 | 
						|
	test_path_is_file "$REAL/objects/$(objpath $SHA)"
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'check write-tree' '
 | 
						|
	SHA=$(git write-tree) &&
 | 
						|
	test_path_is_file "$REAL/objects/$(objpath $SHA)"
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'check commit-tree' '
 | 
						|
	SHA=$(echo "commit bar" | git commit-tree $SHA) &&
 | 
						|
	test_path_is_file "$REAL/objects/$(objpath $SHA)"
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'check rev-list' '
 | 
						|
	git update-ref "HEAD" "$SHA" &&
 | 
						|
	test "$SHA" = "$(git rev-list HEAD)"
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'setup_git_dir twice in subdir' '
 | 
						|
	git init sgd &&
 | 
						|
	(
 | 
						|
		cd sgd &&
 | 
						|
		git config alias.lsfi ls-files &&
 | 
						|
		mv .git .realgit &&
 | 
						|
		echo "gitdir: .realgit" >.git &&
 | 
						|
		mkdir subdir &&
 | 
						|
		cd subdir &&
 | 
						|
		>foo &&
 | 
						|
		git add foo &&
 | 
						|
		git lsfi >actual &&
 | 
						|
		echo foo >expected &&
 | 
						|
		test_cmp expected actual
 | 
						|
	)
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'enter_repo non-strict mode' '
 | 
						|
	test_create_repo enter_repo &&
 | 
						|
	(
 | 
						|
		cd enter_repo &&
 | 
						|
		test_tick &&
 | 
						|
		test_commit foo &&
 | 
						|
		mv .git .realgit &&
 | 
						|
		echo "gitdir: .realgit" >.git
 | 
						|
	) &&
 | 
						|
	head=$(git -C enter_repo rev-parse HEAD) &&
 | 
						|
	git ls-remote enter_repo >actual &&
 | 
						|
	cat >expected <<-EOF &&
 | 
						|
	$head	HEAD
 | 
						|
	$head	refs/heads/main
 | 
						|
	$head	refs/tags/foo
 | 
						|
	EOF
 | 
						|
	test_cmp expected actual
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'enter_repo linked checkout' '
 | 
						|
	(
 | 
						|
		cd enter_repo &&
 | 
						|
		git worktree add  ../foo refs/tags/foo
 | 
						|
	) &&
 | 
						|
	head=$(git -C enter_repo rev-parse HEAD) &&
 | 
						|
	git ls-remote foo >actual &&
 | 
						|
	cat >expected <<-EOF &&
 | 
						|
	$head	HEAD
 | 
						|
	$head	refs/heads/main
 | 
						|
	$head	refs/tags/foo
 | 
						|
	EOF
 | 
						|
	test_cmp expected actual
 | 
						|
'
 | 
						|
 | 
						|
test_expect_success 'enter_repo strict mode' '
 | 
						|
	head=$(git -C enter_repo rev-parse HEAD) &&
 | 
						|
	git ls-remote --upload-pack="git upload-pack --strict" foo/.git >actual &&
 | 
						|
	cat >expected <<-EOF &&
 | 
						|
	$head	HEAD
 | 
						|
	$head	refs/heads/main
 | 
						|
	$head	refs/tags/foo
 | 
						|
	EOF
 | 
						|
	test_cmp expected actual
 | 
						|
'
 | 
						|
 | 
						|
test_done
 |