* [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