 e80967b287
			
		
	
	e80967b287
	
	
	
		
			
			When p4d runs on a case-folding OS, git-p4 can end up getting very confused. This adds failing tests to demonstrate the problem. Signed-off-by: Luke Diamand <luke@diamand.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			184 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			184 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| #
 | |
| # Library code for git p4 tests
 | |
| #
 | |
| 
 | |
| # p4 tests never use the top-level repo; always build/clone into
 | |
| # a subdirectory called "$git"
 | |
| TEST_NO_CREATE_REPO=NoThanks
 | |
| 
 | |
| . ./test-lib.sh
 | |
| 
 | |
| if ! test_have_prereq PYTHON
 | |
| then
 | |
| 	skip_all='skipping git p4 tests; python not available'
 | |
| 	test_done
 | |
| fi
 | |
| ( p4 -h && p4d -h ) >/dev/null 2>&1 || {
 | |
| 	skip_all='skipping git p4 tests; no p4 or p4d'
 | |
| 	test_done
 | |
| }
 | |
| 
 | |
| # On cygwin, the NT version of Perforce can be used.  When giving
 | |
| # it paths, either on the command-line or in client specifications,
 | |
| # be sure to use the native windows form.
 | |
| #
 | |
| # Older versions of perforce were available compiled natively for
 | |
| # cygwin.  Those do not accept native windows paths, so make sure
 | |
| # not to convert for them.
 | |
| native_path() {
 | |
| 	path="$1" &&
 | |
| 	if test_have_prereq CYGWIN && ! p4 -V | grep -q CYGWIN
 | |
| 	then
 | |
| 		path=$(cygpath --windows "$path")
 | |
| 	else
 | |
| 		path=$(test-path-utils real_path "$path")
 | |
| 	fi &&
 | |
| 	echo "$path"
 | |
| }
 | |
| 
 | |
| # Try to pick a unique port: guess a large number, then hope
 | |
| # no more than one of each test is running.
 | |
| #
 | |
| # This does not handle the case where somebody else is running the
 | |
| # same tests and has chosen the same ports.
 | |
| testid=${this_test#t}
 | |
| git_p4_test_start=9800
 | |
| P4DPORT=$((10669 + ($testid - $git_p4_test_start)))
 | |
| 
 | |
| P4PORT=localhost:$P4DPORT
 | |
| P4CLIENT=client
 | |
| P4USER=author
 | |
| P4EDITOR=true
 | |
| unset P4CHARSET
 | |
| export P4PORT P4CLIENT P4USER P4EDITOR P4CHARSET
 | |
| 
 | |
| db="$TRASH_DIRECTORY/db"
 | |
| cli="$TRASH_DIRECTORY/cli"
 | |
| git="$TRASH_DIRECTORY/git"
 | |
| pidfile="$TRASH_DIRECTORY/p4d.pid"
 | |
| 
 | |
| # git p4 submit generates a temp file, which will
 | |
| # not get cleaned up if the submission fails.  Don't
 | |
| # clutter up /tmp on the test machine.
 | |
| TMPDIR="$TRASH_DIRECTORY"
 | |
| export TMPDIR
 | |
| 
 | |
| start_p4d() {
 | |
| 	mkdir -p "$db" "$cli" "$git" &&
 | |
| 	rm -f "$pidfile" &&
 | |
| 	(
 | |
| 		cd "$db" &&
 | |
| 		{
 | |
| 			p4d -q -p $P4DPORT "$@" &
 | |
| 			echo $! >"$pidfile"
 | |
| 		}
 | |
| 	) &&
 | |
| 
 | |
| 	# This gives p4d a long time to start up, as it can be
 | |
| 	# quite slow depending on the machine.  Set this environment
 | |
| 	# variable to something smaller to fail faster in, say,
 | |
| 	# an automated test setup.  If the p4d process dies, that
 | |
| 	# will be caught with the "kill -0" check below.
 | |
| 	i=${P4D_START_PATIENCE:-300}
 | |
| 	pid=$(cat "$pidfile")
 | |
| 	ready=
 | |
| 	while test $i -gt 0
 | |
| 	do
 | |
| 		# succeed when p4 client commands start to work
 | |
| 		if p4 info >/dev/null 2>&1
 | |
| 		then
 | |
| 			ready=true
 | |
| 			break
 | |
| 		fi
 | |
| 		# fail if p4d died
 | |
| 		kill -0 $pid 2>/dev/null || break
 | |
| 		echo waiting for p4d to start
 | |
| 		sleep 1
 | |
| 		i=$(( $i - 1 ))
 | |
| 	done
 | |
| 
 | |
| 	if test -z "$ready"
 | |
| 	then
 | |
| 		# p4d failed to start
 | |
| 		return 1
 | |
| 	fi
 | |
| 
 | |
| 	# build a p4 user so author@example.com has an entry
 | |
| 	p4_add_user author
 | |
| 
 | |
| 	# build a client
 | |
| 	client_view "//depot/... //client/..." &&
 | |
| 
 | |
| 	return 0
 | |
| }
 | |
| 
 | |
| p4_add_user() {
 | |
| 	name=$1 &&
 | |
| 	p4 user -f -i <<-EOF
 | |
| 	User: $name
 | |
| 	Email: $name@example.com
 | |
| 	FullName: Dr. $name
 | |
| 	EOF
 | |
| }
 | |
| 
 | |
| kill_p4d() {
 | |
| 	pid=$(cat "$pidfile")
 | |
| 	# it had better exist for the first kill
 | |
| 	kill $pid &&
 | |
| 	for i in 1 2 3 4 5 ; do
 | |
| 		kill $pid >/dev/null 2>&1 || break
 | |
| 		sleep 1
 | |
| 	done &&
 | |
| 	# complain if it would not die
 | |
| 	test_must_fail kill $pid >/dev/null 2>&1 &&
 | |
| 	rm -rf "$db" "$cli" "$pidfile"
 | |
| }
 | |
| 
 | |
| cleanup_git() {
 | |
| 	rm -rf "$git" &&
 | |
| 	mkdir "$git"
 | |
| }
 | |
| 
 | |
| marshal_dump() {
 | |
| 	what=$1 &&
 | |
| 	line=${2:-1} &&
 | |
| 	cat >"$TRASH_DIRECTORY/marshal-dump.py" <<-EOF &&
 | |
| 	import marshal
 | |
| 	import sys
 | |
| 	for i in range($line):
 | |
| 	    d = marshal.load(sys.stdin)
 | |
| 	print d['$what']
 | |
| 	EOF
 | |
| 	"$PYTHON_PATH" "$TRASH_DIRECTORY/marshal-dump.py"
 | |
| }
 | |
| 
 | |
| #
 | |
| # Construct a client with this list of View lines
 | |
| #
 | |
| client_view() {
 | |
| 	(
 | |
| 		cat <<-EOF &&
 | |
| 		Client: $P4CLIENT
 | |
| 		Description: $P4CLIENT
 | |
| 		Root: $cli
 | |
| 		AltRoots: $(native_path "$cli")
 | |
| 		LineEnd: unix
 | |
| 		View:
 | |
| 		EOF
 | |
| 		printf "\t%s\n" "$@"
 | |
| 	) | p4 client -i
 | |
| }
 | |
| 
 | |
| is_cli_file_writeable() {
 | |
| 	# cygwin version of p4 does not set read-only attr,
 | |
| 	# will be marked 444 but -w is true
 | |
| 	file="$1" &&
 | |
| 	if test_have_prereq CYGWIN && p4 -V | grep -q CYGWIN
 | |
| 	then
 | |
| 		stat=$(stat --format=%a "$file") &&
 | |
| 		test $stat = 644
 | |
| 	else
 | |
| 		test -w "$file"
 | |
| 	fi
 | |
| }
 |