git p4 test: translate windows paths for cygwin

Native windows binaries do not understand posix-like
path mapping offered by cygwin.  Convert paths to native
using "cygpath --windows" before presenting them to p4d.

This is done using the AltRoots mechanism of p4.  Both the
posix and windows forms are put in the client specification,
allowing p4 to find its location by native path even though
the environment reports a different PWD.

Shell operations in tests will use the normal form of $cli,
which will look like a posix path in cygwin, while p4 will
use AltRoots to match against the windows form of the working
directory.

This mechanism also handles the symlink issue that was fixed in
23bd0c9 (git p4 test: use real_path to resolve p4 client
symlinks, 2012-06-27).  Now that every p4 client view has
an AltRoots with the real_path in it, explicitly calculating
the real_path elsewhere is not necessary.

Thanks-to: Sebastian Schuberth <sschuberth@gmail.com>
Thanks-to: Johannes Sixt <j6t@kdbg.org>

fixup! git p4 test: translate windows paths for cygwin

Signed-off-by: Pete Wyckoff <pw@padd.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Pete Wyckoff 2013-01-26 22:11:11 -05:00 committed by Junio C Hamano
parent 6492a1041a
commit cfa96496bd
3 changed files with 26 additions and 3 deletions

View file

@ -8,7 +8,8 @@ TEST_NO_CREATE_REPO=NoThanks
. ./test-lib.sh . ./test-lib.sh
if ! test_have_prereq PYTHON; then if ! test_have_prereq PYTHON
then
skip_all='skipping git p4 tests; python not available' skip_all='skipping git p4 tests; python not available'
test_done test_done
fi fi
@ -17,6 +18,24 @@ fi
test_done 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 # Try to pick a unique port: guess a large number, then hope
# no more than one of each test is running. # no more than one of each test is running.
# #
@ -32,7 +51,7 @@ P4EDITOR=:
export P4PORT P4CLIENT P4EDITOR export P4PORT P4CLIENT P4EDITOR
db="$TRASH_DIRECTORY/db" db="$TRASH_DIRECTORY/db"
cli=$(test-path-utils real_path "$TRASH_DIRECTORY/cli") cli="$TRASH_DIRECTORY/cli"
git="$TRASH_DIRECTORY/git" git="$TRASH_DIRECTORY/git"
pidfile="$TRASH_DIRECTORY/p4d.pid" pidfile="$TRASH_DIRECTORY/p4d.pid"
@ -122,6 +141,7 @@ client_view() {
Client: $P4CLIENT Client: $P4CLIENT
Description: $P4CLIENT Description: $P4CLIENT
Root: $cli Root: $cli
AltRoots: $(native_path "$cli")
View: View:
EOF EOF
printf "\t%s\n" "$@" printf "\t%s\n" "$@"

View file

@ -215,7 +215,7 @@ test_expect_success 'clone --use-client-spec' '
test_must_fail git p4 clone --dest="$git" --use-client-spec test_must_fail git p4 clone --dest="$git" --use-client-spec
) && ) &&
# build a different client # build a different client
cli2=$(test-path-utils real_path "$TRASH_DIRECTORY/cli2") && cli2="$TRASH_DIRECTORY/cli2" &&
mkdir -p "$cli2" && mkdir -p "$cli2" &&
test_when_finished "rmdir \"$cli2\"" && test_when_finished "rmdir \"$cli2\"" &&
test_when_finished cleanup_git && test_when_finished cleanup_git &&

View file

@ -666,12 +666,14 @@ case $(uname -s) in
# backslashes in pathspec are converted to '/' # backslashes in pathspec are converted to '/'
# exec does not inherit the PID # exec does not inherit the PID
test_set_prereq MINGW test_set_prereq MINGW
test_set_prereq NOT_CYGWIN
test_set_prereq SED_STRIPS_CR test_set_prereq SED_STRIPS_CR
;; ;;
*CYGWIN*) *CYGWIN*)
test_set_prereq POSIXPERM test_set_prereq POSIXPERM
test_set_prereq EXECKEEPSPID test_set_prereq EXECKEEPSPID
test_set_prereq NOT_MINGW test_set_prereq NOT_MINGW
test_set_prereq CYGWIN
test_set_prereq SED_STRIPS_CR test_set_prereq SED_STRIPS_CR
;; ;;
*) *)
@ -679,6 +681,7 @@ case $(uname -s) in
test_set_prereq BSLASHPSPEC test_set_prereq BSLASHPSPEC
test_set_prereq EXECKEEPSPID test_set_prereq EXECKEEPSPID
test_set_prereq NOT_MINGW test_set_prereq NOT_MINGW
test_set_prereq NOT_CYGWIN
;; ;;
esac esac