git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v2 0/3] git-p4: updated locked file handling patch series
@ 2015-04-04  8:46 Luke Diamand
  2015-04-04  8:46 ` [PATCH v2 1/3] git-p4: fix small bug in locked test scripts Luke Diamand
                   ` (2 more replies)
  0 siblings, 3 replies; 4+ messages in thread
From: Luke Diamand @ 2015-04-04  8:46 UTC (permalink / raw)
  To: git
  Cc: Eric Sunshine, Pete Wyckoff, Junio C Hamano, Blair Holloway,
	Luke Diamand

Updated patch series for fixing git-p4 filetype detection when one or more
files have been locked automatically by p4 (fix provided by Blair),
incorporating comments from Eric:

 - squashes the actual fix and the test case change together
 - fixes typo

Luke

Holloway, Blair (1):
  git-p4: fix filetype detection on files opened exclusively

Luke Diamand (2):
  git-p4: fix small bug in locked test scripts
  git-p4: small fix for locked-file-move-test

 git-p4.py                |  2 +-
 t/t9816-git-p4-locked.sh | 10 +++++-----
 2 files changed, 6 insertions(+), 6 deletions(-)

-- 
2.3.4.48.g223ab37

^ permalink raw reply	[flat|nested] 4+ messages in thread

* [PATCH v2 1/3] git-p4: fix small bug in locked test scripts
  2015-04-04  8:46 [PATCH v2 0/3] git-p4: updated locked file handling patch series Luke Diamand
@ 2015-04-04  8:46 ` Luke Diamand
  2015-04-04  8:46 ` [PATCH v2 2/3] git-p4: small fix for locked-file-move-test Luke Diamand
  2015-04-04  8:46 ` [PATCH v2 3/3] git-p4: fix filetype detection on files opened exclusively Luke Diamand
  2 siblings, 0 replies; 4+ messages in thread
From: Luke Diamand @ 2015-04-04  8:46 UTC (permalink / raw)
  To: git
  Cc: Eric Sunshine, Pete Wyckoff, Junio C Hamano, Blair Holloway,
	Luke Diamand

Test script t9816-git-p4-locked.sh test #4 tests for
adding a file that is locked by Perforce automatically.
This is currently not supported by git-p4 and so is
expected to fail.

However, a small typo meant it always failed, even with
a fixed git-p4. Fix the typo to resolve this.

Signed-off-by: Luke Diamand <luke@diamand.org>
---
 t/t9816-git-p4-locked.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/t/t9816-git-p4-locked.sh b/t/t9816-git-p4-locked.sh
index e71e543..ce0eb22 100755
--- a/t/t9816-git-p4-locked.sh
+++ b/t/t9816-git-p4-locked.sh
@@ -41,7 +41,7 @@ test_expect_failure 'add with lock not taken' '
 	(
 		cd "$git" &&
 		echo line1 >>add-lock-not-taken &&
-		git add file2 &&
+		git add add-lock-not-taken &&
 		git commit -m "add add-lock-not-taken" &&
 		git config git-p4.skipSubmitEdit true &&
 		git p4 submit --verbose
-- 
2.3.4.48.g223ab37

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* [PATCH v2 2/3] git-p4: small fix for locked-file-move-test
  2015-04-04  8:46 [PATCH v2 0/3] git-p4: updated locked file handling patch series Luke Diamand
  2015-04-04  8:46 ` [PATCH v2 1/3] git-p4: fix small bug in locked test scripts Luke Diamand
@ 2015-04-04  8:46 ` Luke Diamand
  2015-04-04  8:46 ` [PATCH v2 3/3] git-p4: fix filetype detection on files opened exclusively Luke Diamand
  2 siblings, 0 replies; 4+ messages in thread
From: Luke Diamand @ 2015-04-04  8:46 UTC (permalink / raw)
  To: git
  Cc: Eric Sunshine, Pete Wyckoff, Junio C Hamano, Blair Holloway,
	Luke Diamand

The test for handling of failure when trying to move a file
that is locked by another client was not quite correct - it
failed early on because the target file in the move already
existed.

The test now fails because git-p4 does not properly detect
that p4 has rejected the move, and instead just crashes. At
present, git-p4 has no support for detecting that a file
has been locked and reporting it to the user, so this is
the expected outcome.

Signed-off-by: Luke Diamand <luke@diamand.org>
---
 t/t9816-git-p4-locked.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/t/t9816-git-p4-locked.sh b/t/t9816-git-p4-locked.sh
index ce0eb22..464f10b 100755
--- a/t/t9816-git-p4-locked.sh
+++ b/t/t9816-git-p4-locked.sh
@@ -130,8 +130,8 @@ test_expect_failure 'move with lock taken' '
 	git p4 clone --dest="$git" //depot &&
 	(
 		cd "$git" &&
-		git mv file1 file2 &&
-		git commit -m "mv file1 to file2" &&
+		git mv file1 file3 &&
+		git commit -m "mv file1 to file3" &&
 		git config git-p4.skipSubmitEdit true &&
 		git config git-p4.detectRenames true &&
 		git p4 submit --verbose
-- 
2.3.4.48.g223ab37

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* [PATCH v2 3/3] git-p4: fix filetype detection on files opened exclusively
  2015-04-04  8:46 [PATCH v2 0/3] git-p4: updated locked file handling patch series Luke Diamand
  2015-04-04  8:46 ` [PATCH v2 1/3] git-p4: fix small bug in locked test scripts Luke Diamand
  2015-04-04  8:46 ` [PATCH v2 2/3] git-p4: small fix for locked-file-move-test Luke Diamand
@ 2015-04-04  8:46 ` Luke Diamand
  2 siblings, 0 replies; 4+ messages in thread
From: Luke Diamand @ 2015-04-04  8:46 UTC (permalink / raw)
  To: git
  Cc: Eric Sunshine, Pete Wyckoff, Junio C Hamano, Blair Holloway,
	Blair Holloway, Luke Diamand

From: "Holloway, Blair" <Blair_Holloway@playstation.sony.com>

If a Perforce server is configured to automatically set +l (exclusive lock) on
add of certain file types, git p4 submit will fail during getP4OpenedType, as
the regex doesn't expect the trailing '*exclusive*' from p4 opened:

//depot/file.png#1 - add default change (binary+l) *exclusive*

Signed-off-by: Blair Holloway <blair_holloway@playstation.sony.com>
Acked-by: Luke Diamand <luke@diamand.org>
Signed-off-by: Luke Diamand <luke@diamand.org>
---
 git-p4.py                | 2 +-
 t/t9816-git-p4-locked.sh | 4 ++--
 2 files changed, 3 insertions(+), 3 deletions(-)

diff --git a/git-p4.py b/git-p4.py
index ff132b2..d43482a 100755
--- a/git-p4.py
+++ b/git-p4.py
@@ -368,7 +368,7 @@ def getP4OpenedType(file):
     # Returns the perforce file type for the given file.
 
     result = p4_read_pipe(["opened", wildcard_encode(file)])
-    match = re.match(".*\((.+)\)\r?$", result)
+    match = re.match(".*\((.+)\)( \*exclusive\*)?\r?$", result)
     if match:
         return match.group(1)
     else:
diff --git a/t/t9816-git-p4-locked.sh b/t/t9816-git-p4-locked.sh
index 464f10b..d048bd3 100755
--- a/t/t9816-git-p4-locked.sh
+++ b/t/t9816-git-p4-locked.sh
@@ -35,7 +35,7 @@ test_expect_success 'edit with lock not taken' '
 	)
 '
 
-test_expect_failure 'add with lock not taken' '
+test_expect_success 'add with lock not taken' '
 	test_when_finished cleanup_git &&
 	git p4 clone --dest="$git" //depot &&
 	(
@@ -107,7 +107,7 @@ test_expect_failure 'chmod with lock taken' '
 	)
 '
 
-test_expect_failure 'copy with lock taken' '
+test_expect_success 'copy with lock taken' '
 	lock_in_another_client &&
 	test_when_finished cleanup_git &&
 	test_when_finished "cd \"$cli\" && p4 revert file2 && rm -f file2" &&
-- 
2.3.4.48.g223ab37

^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2015-04-04  8:47 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-04-04  8:46 [PATCH v2 0/3] git-p4: updated locked file handling patch series Luke Diamand
2015-04-04  8:46 ` [PATCH v2 1/3] git-p4: fix small bug in locked test scripts Luke Diamand
2015-04-04  8:46 ` [PATCH v2 2/3] git-p4: small fix for locked-file-move-test Luke Diamand
2015-04-04  8:46 ` [PATCH v2 3/3] git-p4: fix filetype detection on files opened exclusively Luke Diamand

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).