]> git.ipfire.org Git - thirdparty/git.git/blame - t/t1090-sparse-checkout-scope.sh
Merge branch 'pb/blame-funcname-range-userdiff'
[thirdparty/git.git] / t / t1090-sparse-checkout-scope.sh
CommitLineData
7d782416
DT
1#!/bin/sh
2
3test_description='sparse checkout scope tests'
4
06d53148 5GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
334afbc7
JS
6export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
7
7d782416
DT
8. ./test-lib.sh
9
10test_expect_success 'setup' '
11 echo "initial" >a &&
12 echo "initial" >b &&
13 echo "initial" >c &&
14 git add a b c &&
15 git commit -m "initial commit"
16'
17
18test_expect_success 'create feature branch' '
19 git checkout -b feature &&
20 echo "modified" >b &&
21 echo "modified" >c &&
22 git add b c &&
23 git commit -m "modification"
24'
25
06d53148 26test_expect_success 'perform sparse checkout of main' '
7d782416
DT
27 git config --local --bool core.sparsecheckout true &&
28 echo "!/*" >.git/info/sparse-checkout &&
29 echo "/a" >>.git/info/sparse-checkout &&
30 echo "/c" >>.git/info/sparse-checkout &&
06d53148 31 git checkout main &&
7d782416
DT
32 test_path_is_file a &&
33 test_path_is_missing b &&
34 test_path_is_file c
35'
36
06d53148 37test_expect_success 'merge feature branch into sparse checkout of main' '
7d782416
DT
38 git merge feature &&
39 test_path_is_file a &&
40 test_path_is_missing b &&
41 test_path_is_file c &&
42 test "$(cat c)" = "modified"
43'
44
06d53148 45test_expect_success 'return to full checkout of main' '
7d782416
DT
46 git checkout feature &&
47 echo "/*" >.git/info/sparse-checkout &&
06d53148 48 git checkout main &&
7d782416
DT
49 test_path_is_file a &&
50 test_path_is_file b &&
51 test_path_is_file c &&
52 test "$(cat b)" = "modified"
53'
54
2f215ff1
JT
55test_expect_success 'in partial clone, sparse checkout only fetches needed blobs' '
56 test_create_repo server &&
57 git clone "file://$(pwd)/server" client &&
58
59 test_config -C server uploadpack.allowfilter 1 &&
60 test_config -C server uploadpack.allowanysha1inwant 1 &&
61 echo a >server/a &&
62 echo bb >server/b &&
63 mkdir server/c &&
64 echo ccc >server/c/c &&
65 git -C server add a b c/c &&
66 git -C server commit -m message &&
67
68 test_config -C client core.sparsecheckout 1 &&
2f215ff1
JT
69 echo "!/*" >client/.git/info/sparse-checkout &&
70 echo "/a" >>client/.git/info/sparse-checkout &&
71 git -C client fetch --filter=blob:none origin &&
72 git -C client checkout FETCH_HEAD &&
73
74 git -C client rev-list HEAD \
75 --quiet --objects --missing=print >unsorted_actual &&
76 (
77 printf "?" &&
78 git hash-object server/b &&
79 printf "?" &&
80 git hash-object server/c/c
81 ) >unsorted_expect &&
82 sort unsorted_actual >actual &&
83 sort unsorted_expect >expect &&
84 test_cmp expect actual
85'
86
7d782416 87test_done