git-p4: commit time should be most recent p4 change time
When importing a repo, the time on the initial commit had been just "now". But this causes problems when trying to share among git-p4 repos that were created identically, although at different times. Instead, use the time in the top-most p4 change as the time for the git import commit. Signed-off-by: Pete Wyckoff <pw@padd.com> Acked-by: Luke Diamand <luke@diamand.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
eab30818a9
commit
4e2e6ce450
@ -1649,7 +1649,8 @@ class P4Sync(Command, P4UserMap):
|
||||
def importHeadRevision(self, revision):
|
||||
print "Doing initial import of %s from revision %s into %s" % (' '.join(self.depotPaths), revision, self.branch)
|
||||
|
||||
details = { "user" : "git perforce import user", "time" : int(time.time()) }
|
||||
details = {}
|
||||
details["user"] = "git perforce import user"
|
||||
details["desc"] = ("Initial import of %s from the state at revision %s\n"
|
||||
% (' '.join(self.depotPaths), revision))
|
||||
details["change"] = revision
|
||||
@ -1689,6 +1690,18 @@ class P4Sync(Command, P4UserMap):
|
||||
fileCnt = fileCnt + 1
|
||||
|
||||
details["change"] = newestRevision
|
||||
|
||||
# Use time from top-most change so that all git-p4 clones of
|
||||
# the same p4 repo have the same commit SHA1s.
|
||||
res = p4CmdList("describe -s %d" % newestRevision)
|
||||
newestTime = None
|
||||
for r in res:
|
||||
if r.has_key('time'):
|
||||
newestTime = int(r['time'])
|
||||
if newestTime is None:
|
||||
die("\"describe -s\" on newest change %d did not give a time")
|
||||
details["time"] = newestTime
|
||||
|
||||
self.updateOptionDict(details)
|
||||
try:
|
||||
self.commit(details, self.extractFilesFromCommit(details), self.branch, self.depotPaths)
|
||||
|
@ -249,6 +249,25 @@ test_expect_success 'not preserving user with mixed authorship' '
|
||||
p4_check_commit_author usernamefile3 alice
|
||||
'
|
||||
|
||||
marshal_dump() {
|
||||
what=$1
|
||||
python -c 'import marshal, sys; d = marshal.load(sys.stdin); print d["'$what'"]'
|
||||
}
|
||||
|
||||
# Sleep a bit so that the top-most p4 change did not happen "now". Then
|
||||
# import the repo and make sure that the initial import has the same time
|
||||
# as the top-most change.
|
||||
test_expect_success 'initial import time from top change time' '
|
||||
p4change=$(p4 -G changes -m 1 //depot/... | marshal_dump change) &&
|
||||
p4time=$(p4 -G changes -m 1 //depot/... | marshal_dump time) &&
|
||||
sleep 3 &&
|
||||
"$GITP4" clone --dest="$git" //depot &&
|
||||
test_when_finished cleanup_git &&
|
||||
cd "$git" &&
|
||||
gittime=$(git show -s --raw --pretty=format:%at HEAD) &&
|
||||
echo $p4time $gittime &&
|
||||
test $p4time = $gittime
|
||||
'
|
||||
|
||||
test_expect_success 'shutdown' '
|
||||
pid=`pgrep -f p4d` &&
|
||||
|
Loading…
Reference in New Issue
Block a user