grep: enable recurse-submodules to work on <tree> objects
[gitweb.git] / t / t9818-git-p4-block.sh
index 153b20afbd420f23e2379e2de1e3f4ea95eecd65..8840a183acfa907eb4659aa5b47ec5bcfbc10e61 100755 (executable)
@@ -8,18 +8,34 @@ test_expect_success 'start p4d' '
        start_p4d
 '
 
-test_expect_success 'Create a repo with ~100 changes' '
+create_restricted_group() {
+       p4 group -i <<-EOF
+       Group: restricted
+       MaxResults: 7
+       MaxScanRows: 40
+       Users: author
+       EOF
+}
+
+test_expect_success 'Create group with limited maxrows' '
+       create_restricted_group
+'
+
+test_expect_success 'Create a repo with many changes' '
        (
-               cd "$cli" &&
+               client_view "//depot/included/... //client/included/..." \
+                           "//depot/excluded/... //client/excluded/..." &&
+               mkdir -p "$cli/included" "$cli/excluded" &&
+               cd "$cli/included" &&
                >file.txt &&
                p4 add file.txt &&
                p4 submit -d "Add file.txt" &&
-               for i in $(test_seq 0 9)
+               for i in $(test_seq 0 5)
                do
                        >outer$i.txt &&
                        p4 add outer$i.txt &&
                        p4 submit -d "Adding outer$i.txt" &&
-                       for j in $(test_seq 0 9)
+                       for j in $(test_seq 0 5)
                        do
                                p4 edit file.txt &&
                                echo $i$j >file.txt &&
@@ -29,34 +45,99 @@ test_expect_success 'Create a repo with ~100 changes' '
        )
 '
 
+test_expect_success 'Default user cannot fetch changes' '
+       ! p4 changes -m 1 //depot/...
+'
+
 test_expect_success 'Clone the repo' '
-       git p4 clone --dest="$git" --changes-block-size=10 --verbose //depot@all
+       git p4 clone --dest="$git" --changes-block-size=7 --verbose //depot/included@all
 '
 
 test_expect_success 'All files are present' '
        echo file.txt >expected &&
        test_write_lines outer0.txt outer1.txt outer2.txt outer3.txt outer4.txt >>expected &&
-       test_write_lines outer5.txt outer6.txt outer7.txt outer8.txt outer9.txt >>expected &&
+       test_write_lines outer5.txt >>expected &&
        ls "$git" >current &&
        test_cmp expected current
 '
 
 test_expect_success 'file.txt is correct' '
-       echo 99 >expected &&
+       echo 55 >expected &&
        test_cmp expected "$git/file.txt"
 '
 
 test_expect_success 'Correct number of commits' '
        (cd "$git" && git log --oneline) >log &&
-       test_line_count = 111 log
+       wc -l log &&
+       test_line_count = 43 log
 '
 
 test_expect_success 'Previous version of file.txt is correct' '
        (cd "$git" && git checkout HEAD^^) &&
-       echo 97 >expected &&
+       echo 53 >expected &&
        test_cmp expected "$git/file.txt"
 '
 
+# Test git-p4 sync, with some files outside the client specification.
+
+p4_add_file() {
+       (cd "$cli" &&
+               >$1 &&
+               p4 add $1 &&
+               p4 submit -d "Added file $1" $1
+       )
+}
+
+test_expect_success 'Add some more files' '
+       for i in $(test_seq 0 10)
+       do
+               p4_add_file "included/x$i" &&
+               p4_add_file "excluded/x$i"
+       done &&
+       for i in $(test_seq 0 10)
+       do
+               p4_add_file "excluded/y$i"
+       done
+'
+
+# This should pick up the 10 new files in "included", but not be confused
+# by the additional files in "excluded"
+test_expect_success 'Syncing files' '
+       (
+               cd "$git" &&
+               git p4 sync --changes-block-size=7 &&
+               git checkout p4/master &&
+               ls -l x* > log &&
+               test_line_count = 11 log
+       )
+'
+
+# Handling of multiple depot paths:
+#    git p4 clone //depot/pathA //depot/pathB
+#
+test_expect_success 'Create a repo with multiple depot paths' '
+       client_view "//depot/pathA/... //client/pathA/..." \
+                   "//depot/pathB/... //client/pathB/..." &&
+       mkdir -p "$cli/pathA" "$cli/pathB" &&
+       for p in pathA pathB
+       do
+               for i in $(test_seq 1 10)
+               do
+                       p4_add_file "$p/file$p$i"
+               done
+       done
+'
+
+test_expect_success 'Clone repo with multiple depot paths' '
+       (
+               cd "$git" &&
+               git p4 clone --changes-block-size=4 //depot/pathA@all //depot/pathB@all \
+                       --destination=dest &&
+               ls -1 dest >log &&
+               test_line_count = 20 log
+       )
+'
+
 test_expect_success 'kill p4d' '
        kill_p4d
 '