 0d3beb71da
			
		
	
	0d3beb71da
	
	
	
		
			
			To prepare for the default value of `protocol.file.allow` to change to "user", ensure tests that rely on local submodules can initialize them over the file protocol. Tests that only need to interact with submodules in a limited capacity have individual Git commands annotated with the appropriate configuration via `-c`. Tests that interact with submodules a handful of times use `test_config_global` instead. Test scripts that rely on submodules throughout use a `git config --global` during a setup test towards the beginning of the script. Signed-off-by: Taylor Blau <me@ttaylorr.com>
		
			
				
	
	
		
			89 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| #
 | |
| # Copyright (c) 2012 Daniel Graña
 | |
| #
 | |
| 
 | |
| test_description='Test submodules on detached working tree
 | |
| 
 | |
| This test verifies that "git submodule" initialization, update and addition works
 | |
| on detached working trees
 | |
| '
 | |
| 
 | |
| TEST_NO_CREATE_REPO=1
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success 'setup' '
 | |
| 	git config --global protocol.file.allow always
 | |
| '
 | |
| 
 | |
| test_expect_success 'submodule on detached working tree' '
 | |
| 	git init --bare remote &&
 | |
| 	test_create_repo bundle1 &&
 | |
| 	(
 | |
| 		cd bundle1 &&
 | |
| 		test_commit "shoot" &&
 | |
| 		git rev-parse --verify HEAD >../expect
 | |
| 	) &&
 | |
| 	mkdir home &&
 | |
| 	(
 | |
| 		cd home &&
 | |
| 		GIT_WORK_TREE="$(pwd)" &&
 | |
| 		GIT_DIR="$(pwd)/.dotfiles" &&
 | |
| 		export GIT_WORK_TREE GIT_DIR &&
 | |
| 		git clone --bare ../remote .dotfiles &&
 | |
| 		git submodule add ../bundle1 .vim/bundle/sogood &&
 | |
| 		test_commit "sogood" &&
 | |
| 		(
 | |
| 			unset GIT_WORK_TREE GIT_DIR &&
 | |
| 			cd .vim/bundle/sogood &&
 | |
| 			git rev-parse --verify HEAD >actual &&
 | |
| 			test_cmp ../../../../expect actual
 | |
| 		) &&
 | |
| 		git push origin master
 | |
| 	) &&
 | |
| 	mkdir home2 &&
 | |
| 	(
 | |
| 		cd home2 &&
 | |
| 		git clone --bare ../remote .dotfiles &&
 | |
| 		GIT_WORK_TREE="$(pwd)" &&
 | |
| 		GIT_DIR="$(pwd)/.dotfiles" &&
 | |
| 		export GIT_WORK_TREE GIT_DIR &&
 | |
| 		git checkout master &&
 | |
| 		git submodule update --init &&
 | |
| 		(
 | |
| 			unset GIT_WORK_TREE GIT_DIR &&
 | |
| 			cd .vim/bundle/sogood &&
 | |
| 			git rev-parse --verify HEAD >actual &&
 | |
| 			test_cmp ../../../../expect actual
 | |
| 		)
 | |
| 	)
 | |
| '
 | |
| 
 | |
| test_expect_success 'submodule on detached working pointed by core.worktree' '
 | |
| 	mkdir home3 &&
 | |
| 	(
 | |
| 		cd home3 &&
 | |
| 		GIT_DIR="$(pwd)/.dotfiles" &&
 | |
| 		export GIT_DIR &&
 | |
| 		git clone --bare ../remote "$GIT_DIR" &&
 | |
| 		git config core.bare false &&
 | |
| 		git config core.worktree .. &&
 | |
| 		git checkout master &&
 | |
| 		git submodule add ../bundle1 .vim/bundle/dupe &&
 | |
| 		test_commit "dupe" &&
 | |
| 		git push origin master
 | |
| 	) &&
 | |
| 	(
 | |
| 		cd home &&
 | |
| 		GIT_DIR="$(pwd)/.dotfiles" &&
 | |
| 		export GIT_DIR &&
 | |
| 		git config core.bare false &&
 | |
| 		git config core.worktree .. &&
 | |
| 		git pull &&
 | |
| 		git submodule update --init &&
 | |
| 		test -f .vim/bundle/dupe/shoot.t
 | |
| 	)
 | |
| '
 | |
| 
 | |
| test_done
 |