| #!/bin/sh |
| |
| test_description='git p4 wildcards' |
| |
| TEST_PASSES_SANITIZE_LEAK=true |
| . ./lib-git-p4.sh |
| |
| test_expect_success 'start p4d' ' |
| start_p4d |
| ' |
| |
| test_expect_success 'add p4 files with wildcards in the names' ' |
| ( |
| cd "$cli" && |
| printf "file2\nhas\nsome\nrandom\ntext\n" >file2 && |
| p4 add file2 && |
| echo file-wild-hash >file-wild#hash && |
| if test_have_prereq !MINGW,!CYGWIN |
| then |
| echo file-wild-star >file-wild\*star |
| fi && |
| echo file-wild-at >file-wild@at && |
| echo file-wild-percent >file-wild%percent && |
| p4 add -f file-wild* && |
| p4 submit -d "file wildcards" |
| ) |
| ' |
| |
| test_expect_success 'wildcard files git p4 clone' ' |
| git p4 clone --dest="$git" //depot && |
| test_when_finished cleanup_git && |
| ( |
| cd "$git" && |
| test -f file-wild#hash && |
| if test_have_prereq !MINGW,!CYGWIN |
| then |
| test -f file-wild\*star |
| fi && |
| test -f file-wild@at && |
| test -f file-wild%percent |
| ) |
| ' |
| |
| test_expect_success 'wildcard files submit back to p4, add' ' |
| test_when_finished cleanup_git && |
| git p4 clone --dest="$git" //depot && |
| ( |
| cd "$git" && |
| echo git-wild-hash >git-wild#hash && |
| if test_have_prereq !MINGW,!CYGWIN |
| then |
| echo git-wild-star >git-wild\*star |
| fi && |
| echo git-wild-at >git-wild@at && |
| echo git-wild-percent >git-wild%percent && |
| git add git-wild* && |
| git commit -m "add some wildcard filenames" && |
| git config git-p4.skipSubmitEdit true && |
| git p4 submit |
| ) && |
| ( |
| cd "$cli" && |
| test_path_is_file git-wild#hash && |
| if test_have_prereq !MINGW,!CYGWIN |
| then |
| test_path_is_file git-wild\*star |
| fi && |
| test_path_is_file git-wild@at && |
| test_path_is_file git-wild%percent |
| ) |
| ' |
| |
| test_expect_success 'wildcard files submit back to p4, modify' ' |
| test_when_finished cleanup_git && |
| git p4 clone --dest="$git" //depot && |
| ( |
| cd "$git" && |
| echo new-line >>git-wild#hash && |
| if test_have_prereq !MINGW,!CYGWIN |
| then |
| echo new-line >>git-wild\*star |
| fi && |
| echo new-line >>git-wild@at && |
| echo new-line >>git-wild%percent && |
| git add git-wild* && |
| git commit -m "modify the wildcard files" && |
| git config git-p4.skipSubmitEdit true && |
| git p4 submit |
| ) && |
| ( |
| cd "$cli" && |
| test_line_count = 2 git-wild#hash && |
| if test_have_prereq !MINGW,!CYGWIN |
| then |
| test_line_count = 2 git-wild\*star |
| fi && |
| test_line_count = 2 git-wild@at && |
| test_line_count = 2 git-wild%percent |
| ) |
| ' |
| |
| test_expect_success 'wildcard files submit back to p4, copy' ' |
| test_when_finished cleanup_git && |
| git p4 clone --dest="$git" //depot && |
| ( |
| cd "$git" && |
| cp file2 git-wild-cp#hash && |
| git add git-wild-cp#hash && |
| cp git-wild#hash file-wild-3 && |
| git add file-wild-3 && |
| git commit -m "wildcard copies" && |
| git config git-p4.detectCopies true && |
| git config git-p4.detectCopiesHarder true && |
| git config git-p4.skipSubmitEdit true && |
| git p4 submit |
| ) && |
| ( |
| cd "$cli" && |
| test_path_is_file git-wild-cp#hash && |
| test_path_is_file file-wild-3 |
| ) |
| ' |
| |
| test_expect_success 'wildcard files submit back to p4, rename' ' |
| test_when_finished cleanup_git && |
| git p4 clone --dest="$git" //depot && |
| ( |
| cd "$git" && |
| git mv git-wild@at file-wild-4 && |
| git mv file-wild-3 git-wild-cp%percent && |
| git commit -m "wildcard renames" && |
| git config git-p4.detectRenames true && |
| git config git-p4.skipSubmitEdit true && |
| git p4 submit |
| ) && |
| ( |
| cd "$cli" && |
| test_path_is_missing git-wild@at && |
| test_path_is_file git-wild-cp%percent |
| ) |
| ' |
| |
| test_expect_success 'wildcard files submit back to p4, delete' ' |
| test_when_finished cleanup_git && |
| git p4 clone --dest="$git" //depot && |
| ( |
| cd "$git" && |
| git rm git-wild* && |
| git commit -m "delete the wildcard files" && |
| git config git-p4.skipSubmitEdit true && |
| git p4 submit |
| ) && |
| ( |
| cd "$cli" && |
| test_path_is_missing git-wild#hash && |
| if test_have_prereq !MINGW,!CYGWIN |
| then |
| test_path_is_missing git-wild\*star |
| fi && |
| test_path_is_missing git-wild@at && |
| test_path_is_missing git-wild%percent |
| ) |
| ' |
| |
| test_expect_success 'p4 deleted a wildcard file' ' |
| ( |
| cd "$cli" && |
| echo "wild delete test" >wild@delete && |
| p4 add -f wild@delete && |
| p4 submit -d "add wild@delete" |
| ) && |
| test_when_finished cleanup_git && |
| git p4 clone --dest="$git" //depot && |
| ( |
| cd "$git" && |
| test_path_is_file wild@delete |
| ) && |
| ( |
| cd "$cli" && |
| # must use its encoded name |
| p4 delete wild%40delete && |
| p4 submit -d "delete wild@delete" |
| ) && |
| ( |
| cd "$git" && |
| git p4 sync && |
| git merge --ff-only p4/master && |
| test_path_is_missing wild@delete |
| ) |
| ' |
| |
| test_expect_success 'wildcard files requiring keyword scrub' ' |
| ( |
| cd "$cli" && |
| cat <<-\EOF >scrub@wild && |
| $Id$ |
| line2 |
| EOF |
| p4 add -t text+k -f scrub@wild && |
| p4 submit -d "scrub at wild" |
| ) && |
| test_when_finished cleanup_git && |
| git p4 clone --dest="$git" //depot && |
| ( |
| cd "$git" && |
| git config git-p4.skipSubmitEdit true && |
| git config git-p4.attemptRCSCleanup true && |
| sed "s/^line2/line2 edit/" <scrub@wild >scrub@wild.tmp && |
| mv -f scrub@wild.tmp scrub@wild && |
| git commit -m "scrub at wild line2 edit" scrub@wild && |
| git p4 submit |
| ) |
| ' |
| |
| test_done |