t/t9812-git-p4-wildcards.sh

Summary

Maintainability
Test Coverage
#!/bin/sh

test_description='git p4 wildcards'

. ./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