From: David D. Kilzer Date: Tue, 5 Aug 2008 07:35:17 +0000 (-0700) Subject: Fix race condition in t9119-git-svn-info.sh X-Git-Tag: v1.6.0-rc2~17 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=d9042a0ac41ebd23e4dac00371a682d964eafee7;p=git.git Fix race condition in t9119-git-svn-info.sh Changed the ptouch bash function to use the "Text Last Updated" date reported by 'svn info' when changing the modified time (mtime) of the file/symlink/directory in the git working directory. Previously it used the mtime of the item in the svn working directory, which caused the race condition. [ew: swapped argument order of ptouch() to minimize diff] From: David D. Kilzer Signed-off-by: David D. Kilzer Acked-by: Eric Wong Signed-off-by: Junio C Hamano --- diff --git a/t/t9119-git-svn-info.sh b/t/t9119-git-svn-info.sh index cc6191159..964011eba 100755 --- a/t/t9119-git-svn-info.sh +++ b/t/t9119-git-svn-info.sh @@ -11,11 +11,18 @@ test_done ptouch() { perl -w -e ' use strict; + use POSIX qw(mktime); die "ptouch requires exactly 2 arguments" if @ARGV != 2; - die "$ARGV[0] does not exist" if ! -e $ARGV[0]; - my @s = stat $ARGV[0]; - utime $s[8], $s[9], $ARGV[1]; - ' "$1" "$2" + my $text_last_updated = shift @ARGV; + my $git_file = shift @ARGV; + die "\"$git_file\" does not exist" if ! -e $git_file; + if ($text_last_updated + =~ /(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/) { + my $mtime = mktime($6, $5, $4, $3, $2 - 1, $1 - 1900); + my $atime = $mtime; + utime $atime, $mtime, $git_file; + } + ' "`svn info $2 | grep '^Text Last Updated:'`" "$1" } test_expect_success 'setup repository and import' "