Merge branch 'ld/git-p4-expanded-keywords'
* ld/git-p4-expanded-keywords: : Teach git-p4 to unexpand $RCS$-like keywords that are embedded in : tracked contents in order to reduce unnecessary merge conflicts. git-p4: add initial support for RCS keywords
This commit is contained in:
@ -483,6 +483,11 @@ git-p4.skipUserNameCheck::
|
|||||||
user map, 'git p4' exits. This option can be used to force
|
user map, 'git p4' exits. This option can be used to force
|
||||||
submission regardless.
|
submission regardless.
|
||||||
|
|
||||||
|
git-p4.attemptRCSCleanup:
|
||||||
|
If enabled, 'git p4 submit' will attempt to cleanup RCS keywords
|
||||||
|
($Header$, etc). These would otherwise cause merge conflicts and prevent
|
||||||
|
the submit going ahead. This option should be considered experimental at
|
||||||
|
present.
|
||||||
|
|
||||||
IMPLEMENTATION DETAILS
|
IMPLEMENTATION DETAILS
|
||||||
----------------------
|
----------------------
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
|
|
||||||
import optparse, sys, os, marshal, subprocess, shelve
|
import optparse, sys, os, marshal, subprocess, shelve
|
||||||
import tempfile, getopt, os.path, time, platform
|
import tempfile, getopt, os.path, time, platform
|
||||||
import re
|
import re, shutil
|
||||||
|
|
||||||
verbose = False
|
verbose = False
|
||||||
|
|
||||||
@ -186,6 +186,47 @@ def split_p4_type(p4type):
|
|||||||
mods = s[1]
|
mods = s[1]
|
||||||
return (base, mods)
|
return (base, mods)
|
||||||
|
|
||||||
|
#
|
||||||
|
# return the raw p4 type of a file (text, text+ko, etc)
|
||||||
|
#
|
||||||
|
def p4_type(file):
|
||||||
|
results = p4CmdList(["fstat", "-T", "headType", file])
|
||||||
|
return results[0]['headType']
|
||||||
|
|
||||||
|
#
|
||||||
|
# Given a type base and modifier, return a regexp matching
|
||||||
|
# the keywords that can be expanded in the file
|
||||||
|
#
|
||||||
|
def p4_keywords_regexp_for_type(base, type_mods):
|
||||||
|
if base in ("text", "unicode", "binary"):
|
||||||
|
kwords = None
|
||||||
|
if "ko" in type_mods:
|
||||||
|
kwords = 'Id|Header'
|
||||||
|
elif "k" in type_mods:
|
||||||
|
kwords = 'Id|Header|Author|Date|DateTime|Change|File|Revision'
|
||||||
|
else:
|
||||||
|
return None
|
||||||
|
pattern = r"""
|
||||||
|
\$ # Starts with a dollar, followed by...
|
||||||
|
(%s) # one of the keywords, followed by...
|
||||||
|
(:[^$]+)? # possibly an old expansion, followed by...
|
||||||
|
\$ # another dollar
|
||||||
|
""" % kwords
|
||||||
|
return pattern
|
||||||
|
else:
|
||||||
|
return None
|
||||||
|
|
||||||
|
#
|
||||||
|
# Given a file, return a regexp matching the possible
|
||||||
|
# RCS keywords that will be expanded, or None for files
|
||||||
|
# with kw expansion turned off.
|
||||||
|
#
|
||||||
|
def p4_keywords_regexp_for_file(file):
|
||||||
|
if not os.path.exists(file):
|
||||||
|
return None
|
||||||
|
else:
|
||||||
|
(type_base, type_mods) = split_p4_type(p4_type(file))
|
||||||
|
return p4_keywords_regexp_for_type(type_base, type_mods)
|
||||||
|
|
||||||
def setP4ExecBit(file, mode):
|
def setP4ExecBit(file, mode):
|
||||||
# Reopens an already open file and changes the execute bit to match
|
# Reopens an already open file and changes the execute bit to match
|
||||||
@ -753,6 +794,29 @@ class P4Submit(Command, P4UserMap):
|
|||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
def patchRCSKeywords(self, file, pattern):
|
||||||
|
# Attempt to zap the RCS keywords in a p4 controlled file matching the given pattern
|
||||||
|
(handle, outFileName) = tempfile.mkstemp(dir='.')
|
||||||
|
try:
|
||||||
|
outFile = os.fdopen(handle, "w+")
|
||||||
|
inFile = open(file, "r")
|
||||||
|
regexp = re.compile(pattern, re.VERBOSE)
|
||||||
|
for line in inFile.readlines():
|
||||||
|
line = regexp.sub(r'$\1$', line)
|
||||||
|
outFile.write(line)
|
||||||
|
inFile.close()
|
||||||
|
outFile.close()
|
||||||
|
# Forcibly overwrite the original file
|
||||||
|
os.unlink(file)
|
||||||
|
shutil.move(outFileName, file)
|
||||||
|
except:
|
||||||
|
# cleanup our temporary file
|
||||||
|
os.unlink(outFileName)
|
||||||
|
print "Failed to strip RCS keywords in %s" % file
|
||||||
|
raise
|
||||||
|
|
||||||
|
print "Patched up RCS keywords in %s" % file
|
||||||
|
|
||||||
def p4UserForCommit(self,id):
|
def p4UserForCommit(self,id):
|
||||||
# Return the tuple (perforce user,git email) for a given git commit id
|
# Return the tuple (perforce user,git email) for a given git commit id
|
||||||
self.getUserMapFromPerforceServer()
|
self.getUserMapFromPerforceServer()
|
||||||
@ -918,6 +982,7 @@ class P4Submit(Command, P4UserMap):
|
|||||||
filesToDelete = set()
|
filesToDelete = set()
|
||||||
editedFiles = set()
|
editedFiles = set()
|
||||||
filesToChangeExecBit = {}
|
filesToChangeExecBit = {}
|
||||||
|
|
||||||
for line in diff:
|
for line in diff:
|
||||||
diff = parseDiffTreeEntry(line)
|
diff = parseDiffTreeEntry(line)
|
||||||
modifier = diff['status']
|
modifier = diff['status']
|
||||||
@ -964,9 +1029,45 @@ class P4Submit(Command, P4UserMap):
|
|||||||
patchcmd = diffcmd + " | git apply "
|
patchcmd = diffcmd + " | git apply "
|
||||||
tryPatchCmd = patchcmd + "--check -"
|
tryPatchCmd = patchcmd + "--check -"
|
||||||
applyPatchCmd = patchcmd + "--check --apply -"
|
applyPatchCmd = patchcmd + "--check --apply -"
|
||||||
|
patch_succeeded = True
|
||||||
|
|
||||||
if os.system(tryPatchCmd) != 0:
|
if os.system(tryPatchCmd) != 0:
|
||||||
|
fixed_rcs_keywords = False
|
||||||
|
patch_succeeded = False
|
||||||
print "Unfortunately applying the change failed!"
|
print "Unfortunately applying the change failed!"
|
||||||
|
|
||||||
|
# Patch failed, maybe it's just RCS keyword woes. Look through
|
||||||
|
# the patch to see if that's possible.
|
||||||
|
if gitConfig("git-p4.attemptRCSCleanup","--bool") == "true":
|
||||||
|
file = None
|
||||||
|
pattern = None
|
||||||
|
kwfiles = {}
|
||||||
|
for file in editedFiles | filesToDelete:
|
||||||
|
# did this file's delta contain RCS keywords?
|
||||||
|
pattern = p4_keywords_regexp_for_file(file)
|
||||||
|
|
||||||
|
if pattern:
|
||||||
|
# this file is a possibility...look for RCS keywords.
|
||||||
|
regexp = re.compile(pattern, re.VERBOSE)
|
||||||
|
for line in read_pipe_lines(["git", "diff", "%s^..%s" % (id, id), file]):
|
||||||
|
if regexp.search(line):
|
||||||
|
if verbose:
|
||||||
|
print "got keyword match on %s in %s in %s" % (pattern, line, file)
|
||||||
|
kwfiles[file] = pattern
|
||||||
|
break
|
||||||
|
|
||||||
|
for file in kwfiles:
|
||||||
|
if verbose:
|
||||||
|
print "zapping %s with %s" % (line,pattern)
|
||||||
|
self.patchRCSKeywords(file, kwfiles[file])
|
||||||
|
fixed_rcs_keywords = True
|
||||||
|
|
||||||
|
if fixed_rcs_keywords:
|
||||||
|
print "Retrying the patch with RCS keywords cleaned up"
|
||||||
|
if os.system(tryPatchCmd) == 0:
|
||||||
|
patch_succeeded = True
|
||||||
|
|
||||||
|
if not patch_succeeded:
|
||||||
print "What do you want to do?"
|
print "What do you want to do?"
|
||||||
response = "x"
|
response = "x"
|
||||||
while response != "s" and response != "a" and response != "w":
|
while response != "s" and response != "a" and response != "w":
|
||||||
@ -1585,15 +1686,12 @@ class P4Sync(Command, P4UserMap):
|
|||||||
|
|
||||||
# Note that we do not try to de-mangle keywords on utf16 files,
|
# Note that we do not try to de-mangle keywords on utf16 files,
|
||||||
# even though in theory somebody may want that.
|
# even though in theory somebody may want that.
|
||||||
if type_base in ("text", "unicode", "binary"):
|
pattern = p4_keywords_regexp_for_type(type_base, type_mods)
|
||||||
if "ko" in type_mods:
|
if pattern:
|
||||||
text = ''.join(contents)
|
regexp = re.compile(pattern, re.VERBOSE)
|
||||||
text = re.sub(r'\$(Id|Header):[^$]*\$', r'$\1$', text)
|
text = ''.join(contents)
|
||||||
contents = [ text ]
|
text = regexp.sub(r'$\1$', text)
|
||||||
elif "k" in type_mods:
|
contents = [ text ]
|
||||||
text = ''.join(contents)
|
|
||||||
text = re.sub(r'\$(Id|Header|Author|Date|DateTime|Change|File|Revision):[^$]*\$', r'$\1$', text)
|
|
||||||
contents = [ text ]
|
|
||||||
|
|
||||||
self.gitStream.write("M %s inline %s\n" % (git_mode, relPath))
|
self.gitStream.write("M %s inline %s\n" % (git_mode, relPath))
|
||||||
|
|
||||||
|
388
t/t9810-git-p4-rcs.sh
Executable file
388
t/t9810-git-p4-rcs.sh
Executable file
@ -0,0 +1,388 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
test_description='git-p4 rcs keywords'
|
||||||
|
|
||||||
|
. ./lib-git-p4.sh
|
||||||
|
|
||||||
|
test_expect_success 'start p4d' '
|
||||||
|
start_p4d
|
||||||
|
'
|
||||||
|
|
||||||
|
#
|
||||||
|
# Make one file with keyword lines at the top, and
|
||||||
|
# enough plain text to be able to test modifications
|
||||||
|
# far away from the keywords.
|
||||||
|
#
|
||||||
|
test_expect_success 'init depot' '
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
cat <<-\EOF >filek &&
|
||||||
|
$Id$
|
||||||
|
/* $Revision$ */
|
||||||
|
# $Change$
|
||||||
|
line4
|
||||||
|
line5
|
||||||
|
line6
|
||||||
|
line7
|
||||||
|
line8
|
||||||
|
EOF
|
||||||
|
cp filek fileko &&
|
||||||
|
sed -i "s/Revision/Revision: do not scrub me/" fileko
|
||||||
|
cp fileko file_text &&
|
||||||
|
sed -i "s/Id/Id: do not scrub me/" file_text
|
||||||
|
p4 add -t text+k filek &&
|
||||||
|
p4 submit -d "filek" &&
|
||||||
|
p4 add -t text+ko fileko &&
|
||||||
|
p4 submit -d "fileko" &&
|
||||||
|
p4 add -t text file_text &&
|
||||||
|
p4 submit -d "file_text"
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
#
|
||||||
|
# Generate these in a function to make it easy to use single quote marks.
|
||||||
|
#
|
||||||
|
write_scrub_scripts () {
|
||||||
|
cat >"$TRASH_DIRECTORY/scrub_k.py" <<-\EOF &&
|
||||||
|
import re, sys
|
||||||
|
sys.stdout.write(re.sub(r'(?i)\$(Id|Header|Author|Date|DateTime|Change|File|Revision):[^$]*\$', r'$\1$', sys.stdin.read()))
|
||||||
|
EOF
|
||||||
|
cat >"$TRASH_DIRECTORY/scrub_ko.py" <<-\EOF
|
||||||
|
import re, sys
|
||||||
|
sys.stdout.write(re.sub(r'(?i)\$(Id|Header):[^$]*\$', r'$\1$', sys.stdin.read()))
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
test_expect_success 'scrub scripts' '
|
||||||
|
write_scrub_scripts
|
||||||
|
'
|
||||||
|
|
||||||
|
#
|
||||||
|
# Compare $cli/file to its scrubbed version, should be different.
|
||||||
|
# Compare scrubbed $cli/file to $git/file, should be same.
|
||||||
|
#
|
||||||
|
scrub_k_check () {
|
||||||
|
file="$1" &&
|
||||||
|
scrub="$TRASH_DIRECTORY/$file" &&
|
||||||
|
"$PYTHON_PATH" "$TRASH_DIRECTORY/scrub_k.py" <"$git/$file" >"$scrub" &&
|
||||||
|
! test_cmp "$cli/$file" "$scrub" &&
|
||||||
|
test_cmp "$git/$file" "$scrub" &&
|
||||||
|
rm "$scrub"
|
||||||
|
}
|
||||||
|
scrub_ko_check () {
|
||||||
|
file="$1" &&
|
||||||
|
scrub="$TRASH_DIRECTORY/$file" &&
|
||||||
|
"$PYTHON_PATH" "$TRASH_DIRECTORY/scrub_ko.py" <"$git/$file" >"$scrub" &&
|
||||||
|
! test_cmp "$cli/$file" "$scrub" &&
|
||||||
|
test_cmp "$git/$file" "$scrub" &&
|
||||||
|
rm "$scrub"
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Modify far away from keywords. If no RCS lines show up
|
||||||
|
# in the diff, there is no conflict.
|
||||||
|
#
|
||||||
|
test_expect_success 'edit far away from RCS lines' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
sed -i "s/^line7/line7 edit/" filek &&
|
||||||
|
git commit -m "filek line7 edit" filek &&
|
||||||
|
"$GITP4" submit &&
|
||||||
|
scrub_k_check filek
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
#
|
||||||
|
# Modify near the keywords. This will require RCS scrubbing.
|
||||||
|
#
|
||||||
|
test_expect_success 'edit near RCS lines' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
git config git-p4.attemptRCSCleanup true &&
|
||||||
|
sed -i "s/^line4/line4 edit/" filek &&
|
||||||
|
git commit -m "filek line4 edit" filek &&
|
||||||
|
"$GITP4" submit &&
|
||||||
|
scrub_k_check filek
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
#
|
||||||
|
# Modify the keywords themselves. This also will require RCS scrubbing.
|
||||||
|
#
|
||||||
|
test_expect_success 'edit keyword lines' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
git config git-p4.attemptRCSCleanup true &&
|
||||||
|
sed -i "/Revision/d" filek &&
|
||||||
|
git commit -m "filek remove Revision line" filek &&
|
||||||
|
"$GITP4" submit &&
|
||||||
|
scrub_k_check filek
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
#
|
||||||
|
# Scrubbing text+ko files should not alter all keywords, just Id, Header.
|
||||||
|
#
|
||||||
|
test_expect_success 'scrub ko files differently' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
git config git-p4.attemptRCSCleanup true &&
|
||||||
|
sed -i "s/^line4/line4 edit/" fileko &&
|
||||||
|
git commit -m "fileko line4 edit" fileko &&
|
||||||
|
"$GITP4" submit &&
|
||||||
|
scrub_ko_check fileko &&
|
||||||
|
! scrub_k_check fileko
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
# hack; git-p4 submit should do it on its own
|
||||||
|
test_expect_success 'cleanup after failure' '
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
p4 revert ...
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
#
|
||||||
|
# Do not scrub anything but +k or +ko files. Sneak a change into
|
||||||
|
# the cli file so that submit will get a conflict. Make sure that
|
||||||
|
# scrubbing doesn't make a mess of things.
|
||||||
|
#
|
||||||
|
# Assumes that git-p4 exits leaving the p4 file open, with the
|
||||||
|
# conflict-generating patch unapplied.
|
||||||
|
#
|
||||||
|
# This might happen only if the git repo is behind the p4 repo at
|
||||||
|
# submit time, and there is a conflict.
|
||||||
|
#
|
||||||
|
test_expect_success 'do not scrub plain text' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
git config git-p4.attemptRCSCleanup true &&
|
||||||
|
sed -i "s/^line4/line4 edit/" file_text &&
|
||||||
|
git commit -m "file_text line4 edit" file_text &&
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
p4 open file_text &&
|
||||||
|
sed -i "s/^line5/line5 p4 edit/" file_text &&
|
||||||
|
p4 submit -d "file5 p4 edit"
|
||||||
|
) &&
|
||||||
|
! "$GITP4" submit &&
|
||||||
|
(
|
||||||
|
# exepct something like:
|
||||||
|
# file_text - file(s) not opened on this client
|
||||||
|
# but not copious diff output
|
||||||
|
cd "$cli" &&
|
||||||
|
p4 diff file_text >wc &&
|
||||||
|
test_line_count = 1 wc
|
||||||
|
)
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
# hack; git-p4 submit should do it on its own
|
||||||
|
test_expect_success 'cleanup after failure 2' '
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
p4 revert ...
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
create_kw_file () {
|
||||||
|
cat <<\EOF >"$1"
|
||||||
|
/* A file
|
||||||
|
Id: $Id$
|
||||||
|
Revision: $Revision$
|
||||||
|
File: $File$
|
||||||
|
*/
|
||||||
|
int main(int argc, const char **argv) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
test_expect_success 'add kwfile' '
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
echo file1 >file1 &&
|
||||||
|
p4 add file1 &&
|
||||||
|
p4 submit -d "file 1" &&
|
||||||
|
create_kw_file kwfile1.c &&
|
||||||
|
p4 add kwfile1.c &&
|
||||||
|
p4 submit -d "Add rcw kw file" kwfile1.c
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
p4_append_to_file () {
|
||||||
|
f="$1" &&
|
||||||
|
p4 edit -t ktext "$f" &&
|
||||||
|
echo "/* $(date) */" >>"$f" &&
|
||||||
|
p4 submit -d "appending a line in p4"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Create some files with RCS keywords. If they get modified
|
||||||
|
# elsewhere then the version number gets bumped which then
|
||||||
|
# results in a merge conflict if we touch the RCS kw lines,
|
||||||
|
# even though the change itself would otherwise apply cleanly.
|
||||||
|
test_expect_success 'cope with rcs keyword expansion damage' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
git config git-p4.attemptRCSCleanup true &&
|
||||||
|
(cd ../cli && p4_append_to_file kwfile1.c) &&
|
||||||
|
old_lines=$(wc -l <kwfile1.c) &&
|
||||||
|
perl -n -i -e "print unless m/Revision:/" kwfile1.c &&
|
||||||
|
new_lines=$(wc -l <kwfile1.c) &&
|
||||||
|
test $new_lines = $(($old_lines - 1)) &&
|
||||||
|
|
||||||
|
git add kwfile1.c &&
|
||||||
|
git commit -m "Zap an RCS kw line" &&
|
||||||
|
"$GITP4" submit &&
|
||||||
|
"$GITP4" rebase &&
|
||||||
|
git diff p4/master &&
|
||||||
|
"$GITP4" commit &&
|
||||||
|
echo "try modifying in both" &&
|
||||||
|
cd "$cli" &&
|
||||||
|
p4 edit kwfile1.c &&
|
||||||
|
echo "line from p4" >>kwfile1.c &&
|
||||||
|
p4 submit -d "add a line in p4" kwfile1.c &&
|
||||||
|
cd "$git" &&
|
||||||
|
echo "line from git at the top" | cat - kwfile1.c >kwfile1.c.new &&
|
||||||
|
mv kwfile1.c.new kwfile1.c &&
|
||||||
|
git commit -m "Add line in git at the top" kwfile1.c &&
|
||||||
|
"$GITP4" rebase &&
|
||||||
|
"$GITP4" submit
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success 'cope with rcs keyword file deletion' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
echo "\$Revision\$" >kwdelfile.c &&
|
||||||
|
p4 add -t ktext kwdelfile.c &&
|
||||||
|
p4 submit -d "Add file to be deleted" &&
|
||||||
|
cat kwdelfile.c &&
|
||||||
|
grep 1 kwdelfile.c
|
||||||
|
) &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
grep Revision kwdelfile.c &&
|
||||||
|
git rm -f kwdelfile.c &&
|
||||||
|
git commit -m "Delete a file containing RCS keywords" &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
git config git-p4.attemptRCSCleanup true &&
|
||||||
|
"$GITP4" submit
|
||||||
|
) &&
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
p4 sync &&
|
||||||
|
! test -f kwdelfile.c
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
# If you add keywords in git of the form $Header$ then everything should
|
||||||
|
# work fine without any special handling.
|
||||||
|
test_expect_success 'Add keywords in git which match the default p4 values' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
echo "NewKW: \$Revision\$" >>kwfile1.c &&
|
||||||
|
git add kwfile1.c &&
|
||||||
|
git commit -m "Adding RCS keywords in git" &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
git config git-p4.attemptRCSCleanup true &&
|
||||||
|
"$GITP4" submit
|
||||||
|
) &&
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
p4 sync &&
|
||||||
|
test -f kwfile1.c &&
|
||||||
|
grep "NewKW.*Revision.*[0-9]" kwfile1.c
|
||||||
|
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
# If you add keywords in git of the form $Header:#1$ then things will fail
|
||||||
|
# unless git-p4 takes steps to scrub the *git* commit.
|
||||||
|
#
|
||||||
|
test_expect_failure 'Add keywords in git which do not match the default p4 values' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
echo "NewKW2: \$Revision:1\$" >>kwfile1.c &&
|
||||||
|
git add kwfile1.c &&
|
||||||
|
git commit -m "Adding RCS keywords in git" &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
git config git-p4.attemptRCSCleanup true &&
|
||||||
|
"$GITP4" submit
|
||||||
|
) &&
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
p4 sync &&
|
||||||
|
grep "NewKW2.*Revision.*[0-9]" kwfile1.c
|
||||||
|
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
# Check that the existing merge conflict handling still works.
|
||||||
|
# Modify kwfile1.c in git, and delete in p4. We should be able
|
||||||
|
# to skip the git commit.
|
||||||
|
#
|
||||||
|
test_expect_success 'merge conflict handling still works' '
|
||||||
|
test_when_finished cleanup_git &&
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
echo "Hello:\$Id\$" >merge2.c &&
|
||||||
|
echo "World" >>merge2.c &&
|
||||||
|
p4 add -t ktext merge2.c &&
|
||||||
|
p4 submit -d "add merge test file"
|
||||||
|
) &&
|
||||||
|
"$GITP4" clone --dest="$git" //depot &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
sed -e "/Hello/d" merge2.c >merge2.c.tmp &&
|
||||||
|
mv merge2.c.tmp merge2.c &&
|
||||||
|
git add merge2.c &&
|
||||||
|
git commit -m "Modifying merge2.c"
|
||||||
|
) &&
|
||||||
|
(
|
||||||
|
cd "$cli" &&
|
||||||
|
p4 delete merge2.c &&
|
||||||
|
p4 submit -d "remove merge test file"
|
||||||
|
) &&
|
||||||
|
(
|
||||||
|
cd "$git" &&
|
||||||
|
test -f merge2.c &&
|
||||||
|
git config git-p4.skipSubmitEdit true &&
|
||||||
|
git config git-p4.attemptRCSCleanup true &&
|
||||||
|
!(echo "s" | "$GITP4" submit) &&
|
||||||
|
git rebase --skip &&
|
||||||
|
! test -f merge2.c
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
|
||||||
|
test_expect_success 'kill p4d' '
|
||||||
|
kill_p4d
|
||||||
|
'
|
||||||
|
|
||||||
|
test_done
|
Reference in New Issue
Block a user