diff options
author | Luke Diamand <luke@diamand.org> | 2016-12-17 02:00:40 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2016-12-18 22:19:40 +0100 |
commit | df8a9e86db13f2b8becfde8ed69f80127ba14e20 (patch) | |
tree | e6c685df0e2a41ec41c00f53f237d77e8ee27b2b /t/t9830-git-p4-symlink-dir.sh | |
parent | Git 2.11 (diff) | |
download | git-df8a9e86db13f2b8becfde8ed69f80127ba14e20.tar.xz git-df8a9e86db13f2b8becfde8ed69f80127ba14e20.zip |
git-p4: avoid crash adding symlinked directory
When submitting to P4, if git-p4 came across a symlinked
directory, then during the generation of the submit diff, it would
try to open it as a normal file and fail.
Spot symlinks (of any type) and output a description of the symlink
instead.
Add a test case.
Signed-off-by: Luke Diamand <luke@diamand.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rwxr-xr-x | t/t9830-git-p4-symlink-dir.sh | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/t/t9830-git-p4-symlink-dir.sh b/t/t9830-git-p4-symlink-dir.sh new file mode 100755 index 0000000000..3dc528bb1e --- /dev/null +++ b/t/t9830-git-p4-symlink-dir.sh @@ -0,0 +1,43 @@ +#!/bin/sh + +test_description='git p4 symlinked directories' + +. ./lib-git-p4.sh + +test_expect_success 'start p4d' ' + start_p4d +' + +test_expect_success 'symlinked directory' ' + ( + cd "$cli" && + : >first_file.t && + p4 add first_file.t && + p4 submit -d "first change" + ) && + git p4 clone --dest "$git" //depot && + ( + cd "$git" && + mkdir -p some/sub/directory && + mkdir -p other/subdir2 && + : > other/subdir2/file.t && + (cd some/sub/directory && ln -s ../../../other/subdir2 .) && + git add some other && + git commit -m "symlinks" && + git config git-p4.skipSubmitEdit true && + git p4 submit -v + ) && + ( + cd "$cli" && + p4 sync && + test -L some/sub/directory/subdir2 + test_path_is_file some/sub/directory/subdir2/file.t + ) + +' + +test_expect_success 'kill p4d' ' + kill_p4d +' + +test_done |