2015-07-30 02:37:31 +00:00
|
|
|
#!/usr/bin/env bash
|
2015-06-20 16:10:54 +00:00
|
|
|
|
|
|
|
. "test/testlib.sh"
|
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
contents="a"
|
|
|
|
contents_oid=$(calc_oid "$contents")
|
|
|
|
b="b"
|
|
|
|
b_oid=$(calc_oid "$b")
|
|
|
|
reponame="$(basename "$0" ".sh")"
|
|
|
|
|
|
|
|
begin_test "init for fetch tests"
|
2015-06-20 16:10:54 +00:00
|
|
|
(
|
|
|
|
set -e
|
|
|
|
|
|
|
|
setup_remote_repo "$reponame"
|
|
|
|
|
|
|
|
clone_repo "$reponame" repo
|
|
|
|
|
|
|
|
git lfs track "*.dat" 2>&1 | tee track.log
|
2017-03-24 16:59:03 +00:00
|
|
|
grep "Tracking \"\*.dat\"" track.log
|
2015-06-20 16:10:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
printf "$contents" > a.dat
|
|
|
|
git add a.dat
|
|
|
|
git add .gitattributes
|
|
|
|
git commit -m "add a.dat" 2>&1 | tee commit.log
|
|
|
|
grep "master (root-commit)" commit.log
|
|
|
|
grep "2 files changed" commit.log
|
|
|
|
grep "create mode 100644 a.dat" commit.log
|
|
|
|
grep "create mode 100644 .gitattributes" commit.log
|
|
|
|
|
|
|
|
[ "a" = "$(cat a.dat)" ]
|
|
|
|
|
2015-08-06 10:44:38 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
2015-06-20 16:10:54 +00:00
|
|
|
|
2015-07-06 18:19:18 +00:00
|
|
|
refute_server_object "$reponame" "$contents_oid"
|
2015-06-20 16:10:54 +00:00
|
|
|
|
|
|
|
git push origin master 2>&1 | tee push.log
|
2018-01-06 02:01:50 +00:00
|
|
|
grep "Uploading LFS objects: 100% (1/1), 1 B" push.log
|
2015-06-20 16:10:54 +00:00
|
|
|
grep "master -> master" push.log
|
|
|
|
|
2015-07-06 18:19:18 +00:00
|
|
|
assert_server_object "$reponame" "$contents_oid"
|
2015-06-20 16:10:54 +00:00
|
|
|
|
|
|
|
# Add a file in a different branch
|
|
|
|
git checkout -b newbranch
|
|
|
|
printf "$b" > b.dat
|
|
|
|
git add b.dat
|
|
|
|
git commit -m "add b.dat"
|
2015-08-06 10:44:38 +00:00
|
|
|
assert_local_object "$b_oid" 1
|
2015-06-20 16:10:54 +00:00
|
|
|
|
|
|
|
git push origin newbranch
|
2015-07-06 18:19:18 +00:00
|
|
|
assert_server_object "$reponame" "$b_oid"
|
2015-06-20 16:10:54 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
# This clone is used for subsequent tests
|
|
|
|
clone_repo "$reponame" clone
|
|
|
|
)
|
|
|
|
end_test
|
2015-06-20 16:10:54 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2015-06-20 16:10:54 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2016-08-02 16:11:12 +00:00
|
|
|
|
2018-01-06 02:01:50 +00:00
|
|
|
git lfs fetch 2>&1 | grep "Downloading LFS objects: 100% (1/1), 1 B"
|
2015-08-13 16:22:29 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-06-20 16:10:54 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with remote"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2015-08-13 16:22:29 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2016-08-02 16:11:12 +00:00
|
|
|
|
2018-01-06 02:01:50 +00:00
|
|
|
git lfs fetch origin 2>&1 | grep "Downloading LFS objects: 100% (1/1), 1 B"
|
2015-08-06 10:44:38 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
2016-08-02 16:11:12 +00:00
|
|
|
refute_local_object "$b_oid" 1
|
|
|
|
)
|
|
|
|
end_test
|
|
|
|
|
|
|
|
begin_test "fetch with remote and branches"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2015-06-20 16:10:54 +00:00
|
|
|
|
|
|
|
git checkout newbranch
|
|
|
|
git checkout master
|
2016-08-02 16:11:12 +00:00
|
|
|
|
2015-06-20 16:10:54 +00:00
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
|
2015-08-13 16:22:29 +00:00
|
|
|
git lfs fetch origin master newbranch
|
2015-08-06 10:44:38 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
assert_local_object "$b_oid" 1
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-08-06 13:56:57 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with master commit sha1"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2016-06-24 09:00:53 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2016-08-02 16:11:12 +00:00
|
|
|
|
2016-06-24 09:00:53 +00:00
|
|
|
master_sha1=$(git rev-parse master)
|
|
|
|
git lfs fetch origin "$master_sha1"
|
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
refute_local_object "$b_oid" 1
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2016-06-24 09:00:53 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with newbranch commit sha1"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2016-06-23 08:59:38 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2016-08-02 16:11:12 +00:00
|
|
|
|
2016-06-23 08:59:38 +00:00
|
|
|
newbranch_sha1=$(git rev-parse newbranch)
|
|
|
|
git lfs fetch origin "$newbranch_sha1"
|
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
assert_local_object "$b_oid" 1
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2016-06-23 08:59:38 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with include filters in gitconfig"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2015-08-06 13:56:57 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2016-08-02 16:11:12 +00:00
|
|
|
|
2015-08-06 13:56:57 +00:00
|
|
|
git config "lfs.fetchinclude" "a*"
|
2015-08-13 16:22:29 +00:00
|
|
|
git lfs fetch origin master newbranch
|
2015-08-06 13:56:57 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
refute_local_object "$b_oid"
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-09-08 15:29:53 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with exclude filters in gitconfig"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
|
|
|
|
cd clone
|
2015-08-06 13:56:57 +00:00
|
|
|
git config --unset "lfs.fetchinclude"
|
2016-08-02 16:11:12 +00:00
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
|
2015-08-06 13:56:57 +00:00
|
|
|
git config "lfs.fetchexclude" "a*"
|
2015-08-13 16:22:29 +00:00
|
|
|
git lfs fetch origin master newbranch
|
2015-08-06 13:56:57 +00:00
|
|
|
refute_local_object "$contents_oid"
|
|
|
|
assert_local_object "$b_oid" 1
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-08-06 13:56:57 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with include/exclude filters in gitconfig"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2015-08-06 13:56:57 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2016-08-02 16:11:12 +00:00
|
|
|
git config --unset "lfs.fetchexclude"
|
|
|
|
|
2015-08-06 13:56:57 +00:00
|
|
|
git config "lfs.fetchinclude" "a*,b*"
|
|
|
|
git config "lfs.fetchexclude" "c*,d*"
|
2015-08-13 16:22:29 +00:00
|
|
|
git lfs fetch origin master newbranch
|
2015-08-06 13:56:57 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
assert_local_object "$b_oid" 1
|
2015-09-08 15:29:53 +00:00
|
|
|
|
2015-08-06 13:56:57 +00:00
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
git config "lfs.fetchinclude" "c*,d*"
|
|
|
|
git config "lfs.fetchexclude" "a*,b*"
|
2015-08-13 16:22:29 +00:00
|
|
|
git lfs fetch origin master newbranch
|
2015-08-06 13:56:57 +00:00
|
|
|
refute_local_object "$contents_oid"
|
|
|
|
refute_local_object "$b_oid"
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-08-07 17:18:39 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with include filter in cli"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2015-08-07 17:18:39 +00:00
|
|
|
git config --unset "lfs.fetchinclude"
|
|
|
|
git config --unset "lfs.fetchexclude"
|
|
|
|
rm -rf .git/lfs/objects
|
2016-08-02 16:11:12 +00:00
|
|
|
|
2015-08-13 16:22:29 +00:00
|
|
|
git lfs fetch --include="a*" origin master newbranch
|
2015-08-07 17:18:39 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
refute_local_object "$b_oid"
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-09-08 15:29:53 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with exclude filter in cli"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2015-08-07 17:18:39 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2015-08-13 16:22:29 +00:00
|
|
|
git lfs fetch --exclude="a*" origin master newbranch
|
2015-08-07 17:18:39 +00:00
|
|
|
refute_local_object "$contents_oid"
|
|
|
|
assert_local_object "$b_oid" 1
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-08-07 17:18:39 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with include/exclude filters in cli"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2015-08-07 17:18:39 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2015-08-13 16:22:29 +00:00
|
|
|
git lfs fetch -I "a*,b*" -X "c*,d*" origin master newbranch
|
2015-08-07 17:18:39 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
assert_local_object "$b_oid" 1
|
2015-09-08 15:29:53 +00:00
|
|
|
|
2015-08-07 17:18:39 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2015-08-13 16:22:29 +00:00
|
|
|
git lfs fetch --include="c*,d*" --exclude="a*,b*" origin master newbranch
|
2015-08-07 17:18:39 +00:00
|
|
|
refute_local_object "$contents_oid"
|
|
|
|
refute_local_object "$b_oid"
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-10-13 14:29:25 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with include filter overriding exclude filter"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
2016-08-01 22:47:41 +00:00
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
git config lfs.fetchexclude "b*"
|
|
|
|
git lfs fetch -I "b.dat" -X "" origin master newbranch
|
|
|
|
assert_local_object "$b_oid" "1"
|
2016-08-02 16:11:12 +00:00
|
|
|
)
|
|
|
|
end_test
|
2016-08-01 22:47:41 +00:00
|
|
|
|
2016-08-02 16:11:12 +00:00
|
|
|
begin_test "fetch with missing object"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd clone
|
|
|
|
git config --unset lfs.fetchexclude
|
2015-10-13 14:29:25 +00:00
|
|
|
rm -rf .git/lfs/objects
|
2016-08-02 16:11:12 +00:00
|
|
|
|
2015-10-13 14:29:25 +00:00
|
|
|
delete_server_object "$reponame" "$b_oid"
|
|
|
|
refute_server_object "$reponame" "$b_oid"
|
2016-08-02 16:11:12 +00:00
|
|
|
|
2015-10-13 14:29:25 +00:00
|
|
|
# should return non-zero, but should also download all the other valid files too
|
|
|
|
set +e
|
|
|
|
git lfs fetch origin master newbranch
|
|
|
|
fetch_exit=$?
|
|
|
|
set -e
|
|
|
|
[ "$fetch_exit" != "0" ]
|
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
refute_local_object "$b_oid"
|
2015-08-24 16:54:56 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-09-04 12:07:30 +00:00
|
|
|
|
|
|
|
begin_test "fetch-all"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
|
|
|
|
reponame="fetch-all"
|
|
|
|
setup_remote_repo "$reponame"
|
|
|
|
|
|
|
|
clone_repo "$reponame" "$reponame"
|
|
|
|
|
|
|
|
git lfs track "*.dat" 2>&1 | tee track.log
|
2017-03-24 16:59:03 +00:00
|
|
|
grep "Tracking \"\*.dat\"" track.log
|
2015-09-04 12:07:30 +00:00
|
|
|
|
|
|
|
NUMFILES=12
|
|
|
|
# generate content we'll use
|
|
|
|
for ((a=0; a < NUMFILES ; a++))
|
|
|
|
do
|
|
|
|
content[$a]="filecontent$a"
|
2015-09-21 17:50:22 +00:00
|
|
|
oid[$a]=$(calc_oid "${content[$a]}")
|
2015-09-04 12:07:30 +00:00
|
|
|
done
|
2015-09-08 15:29:53 +00:00
|
|
|
|
2015-09-04 12:07:30 +00:00
|
|
|
echo "[
|
|
|
|
{
|
|
|
|
\"CommitDate\":\"$(get_date -180d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file1.dat\",\"Size\":${#content[0]}, \"Data\":\"${content[0]}\"},
|
|
|
|
{\"Filename\":\"file2.dat\",\"Size\":${#content[1]}, \"Data\":\"${content[1]}\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"NewBranch\":\"branch1\",
|
|
|
|
\"CommitDate\":\"$(get_date -140d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file3.dat\",\"Size\":${#content[2]}, \"Data\":\"${content[2]}\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"ParentBranches\":[\"master\"],
|
|
|
|
\"CommitDate\":\"$(get_date -100d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file1.dat\",\"Size\":${#content[3]}, \"Data\":\"${content[3]}\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"NewBranch\":\"remote_branch_only\",
|
|
|
|
\"CommitDate\":\"$(get_date -80d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file2.dat\",\"Size\":${#content[4]}, \"Data\":\"${content[4]}\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"ParentBranches\":[\"master\"],
|
|
|
|
\"CommitDate\":\"$(get_date -75d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file4.dat\",\"Size\":${#content[5]}, \"Data\":\"${content[5]}\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"NewBranch\":\"tag_only\",
|
|
|
|
\"Tags\":[\"tag1\"],
|
|
|
|
\"CommitDate\":\"$(get_date -70d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file4.dat\",\"Size\":${#content[6]}, \"Data\":\"${content[6]}\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"ParentBranches\":[\"master\"],
|
|
|
|
\"CommitDate\":\"$(get_date -60d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file1.dat\",\"Size\":${#content[7]}, \"Data\":\"${content[7]}\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"NewBranch\":\"branch3\",
|
|
|
|
\"CommitDate\":\"$(get_date -50d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file4.dat\",\"Size\":${#content[8]}, \"Data\":\"${content[8]}\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"CommitDate\":\"$(get_date -40d)\",
|
|
|
|
\"ParentBranches\":[\"master\"],
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file1.dat\",\"Size\":${#content[9]}, \"Data\":\"${content[9]}\"},
|
|
|
|
{\"Filename\":\"file2.dat\",\"Size\":${#content[10]}, \"Data\":\"${content[10]}\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"ParentBranches\":[\"master\"],
|
|
|
|
\"CommitDate\":\"$(get_date -30d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file4.dat\",\"Size\":${#content[11]}, \"Data\":\"${content[11]}\"}]
|
|
|
|
}
|
|
|
|
]" | lfstest-testutils addcommits
|
|
|
|
|
2015-09-08 15:29:53 +00:00
|
|
|
git push origin master
|
|
|
|
git push origin branch1
|
2015-09-04 12:07:30 +00:00
|
|
|
git push origin branch3
|
2015-09-08 15:29:53 +00:00
|
|
|
git push origin remote_branch_only
|
2015-09-04 12:07:30 +00:00
|
|
|
git push origin tag_only
|
|
|
|
for ((a=0; a < NUMFILES ; a++))
|
|
|
|
do
|
|
|
|
assert_server_object "$reponame" "${oid[$a]}"
|
|
|
|
done
|
|
|
|
|
|
|
|
# delete remote_branch_only and make sure that objects are downloaded even
|
|
|
|
# though not checked out to a local branch (full backup always)
|
|
|
|
git branch -D remote_branch_only
|
|
|
|
|
|
|
|
# delete tag_only to make sure objects are downloaded when only reachable from tag
|
|
|
|
git branch -D tag_only
|
|
|
|
|
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
|
|
|
|
git lfs fetch --all origin
|
|
|
|
for ((a=0; a < NUMFILES ; a++))
|
|
|
|
do
|
|
|
|
assert_local_object "${oid[$a]}" "${#content[$a]}"
|
|
|
|
done
|
|
|
|
|
2016-06-16 16:15:11 +00:00
|
|
|
# Make a bare clone of the repository
|
|
|
|
cd ..
|
|
|
|
git clone --bare "$GITSERVER/$reponame" "$reponame-bare"
|
|
|
|
cd "$reponame-bare"
|
|
|
|
|
|
|
|
# Preform the same assertion as above, on the same data
|
|
|
|
git lfs fetch --all origin
|
2016-06-18 17:55:02 +00:00
|
|
|
for ((a=0; a < NUMFILES ; a++)); do
|
2016-06-16 16:15:11 +00:00
|
|
|
assert_local_object "${oid[$a]}" "${#content[$a]}"
|
|
|
|
done
|
2015-09-04 12:07:30 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-09-08 15:29:53 +00:00
|
|
|
|
|
|
|
begin_test "fetch: outside git repository"
|
|
|
|
(
|
2015-09-08 16:20:52 +00:00
|
|
|
set +e
|
|
|
|
git lfs fetch 2>&1 > fetch.log
|
|
|
|
res=$?
|
|
|
|
|
2015-09-08 15:29:53 +00:00
|
|
|
set -e
|
2015-09-08 20:12:51 +00:00
|
|
|
if [ "$res" = "0" ]; then
|
|
|
|
echo "Passes because $GIT_LFS_TEST_DIR is unset."
|
|
|
|
exit 0
|
|
|
|
fi
|
2015-09-08 16:20:52 +00:00
|
|
|
[ "$res" = "128" ]
|
|
|
|
grep "Not in a git repository" fetch.log
|
2015-09-08 15:29:53 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-10-06 16:27:36 +00:00
|
|
|
|
|
|
|
begin_test "fetch with no origin remote"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
|
|
|
|
reponame="fetch-no-remote"
|
|
|
|
setup_remote_repo "$reponame"
|
|
|
|
|
|
|
|
clone_repo "$reponame" no-remote-clone
|
|
|
|
|
|
|
|
clone_repo "$reponame" no-remote-repo
|
|
|
|
|
|
|
|
git lfs track "*.dat" 2>&1 | tee track.log
|
2017-03-24 16:59:03 +00:00
|
|
|
grep "Tracking \"\*.dat\"" track.log
|
2015-10-06 16:27:36 +00:00
|
|
|
|
|
|
|
contents="a"
|
|
|
|
contents_oid=$(calc_oid "$contents")
|
|
|
|
|
|
|
|
printf "$contents" > a.dat
|
|
|
|
git add a.dat
|
|
|
|
git add .gitattributes
|
|
|
|
git commit -m "add a.dat" 2>&1 | tee commit.log
|
|
|
|
grep "master (root-commit)" commit.log
|
|
|
|
grep "2 files changed" commit.log
|
|
|
|
grep "create mode 100644 a.dat" commit.log
|
|
|
|
grep "create mode 100644 .gitattributes" commit.log
|
|
|
|
|
|
|
|
[ "a" = "$(cat a.dat)" ]
|
|
|
|
|
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
|
|
|
|
refute_server_object "$reponame" "$contents_oid"
|
|
|
|
|
|
|
|
git push origin master 2>&1 | tee push.log
|
2018-01-06 02:01:50 +00:00
|
|
|
grep "Uploading LFS objects: 100% (1/1), 1 B" push.log
|
2015-10-06 16:27:36 +00:00
|
|
|
grep "master -> master" push.log
|
|
|
|
|
|
|
|
|
|
|
|
# change to the clone's working directory
|
|
|
|
cd ../no-remote-clone
|
|
|
|
|
|
|
|
# pull commits & lfs
|
2017-08-12 04:18:56 +00:00
|
|
|
git pull 2>&1
|
2015-10-06 16:27:36 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
|
|
|
|
# now checkout detached HEAD so we're not tracking anything on remote
|
|
|
|
git checkout --detach
|
|
|
|
|
|
|
|
# delete lfs
|
|
|
|
rm -rf .git/lfs
|
|
|
|
|
|
|
|
# rename remote from 'origin' to 'something'
|
|
|
|
git remote rename origin something
|
|
|
|
|
|
|
|
# fetch should still pick this remote as in the case of no tracked remote,
|
|
|
|
# and no origin, but only 1 remote, should pick the only one as default
|
|
|
|
git lfs fetch
|
|
|
|
assert_local_object "$contents_oid" 1
|
2015-11-09 17:46:29 +00:00
|
|
|
)
|
|
|
|
end_test
|
|
|
|
|
2015-10-15 15:35:26 +00:00
|
|
|
begin_test "fetch --prune"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
|
|
|
|
reponame="fetch_prune"
|
|
|
|
setup_remote_repo "remote_$reponame"
|
|
|
|
|
|
|
|
clone_repo "remote_$reponame" "clone_$reponame"
|
|
|
|
|
|
|
|
git lfs track "*.dat" 2>&1 | tee track.log
|
2017-03-24 16:59:03 +00:00
|
|
|
grep "Tracking \"\*.dat\"" track.log
|
2015-10-15 15:35:26 +00:00
|
|
|
|
|
|
|
content_head="HEAD content"
|
|
|
|
content_commit2="Content for commit 2 (prune)"
|
|
|
|
content_commit1="Content for commit 1 (prune)"
|
|
|
|
oid_head=$(calc_oid "$content_head")
|
|
|
|
oid_commit2=$(calc_oid "$content_commit2")
|
|
|
|
oid_commit1=$(calc_oid "$content_commit1")
|
|
|
|
|
|
|
|
echo "[
|
|
|
|
{
|
|
|
|
\"CommitDate\":\"$(get_date -50d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file.dat\",\"Size\":${#content_commit1}, \"Data\":\"$content_commit1\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"CommitDate\":\"$(get_date -35d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file.dat\",\"Size\":${#content_commit2}, \"Data\":\"$content_commit2\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"CommitDate\":\"$(get_date -25d)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file.dat\",\"Size\":${#content_head}, \"Data\":\"$content_head\"}]
|
|
|
|
}
|
|
|
|
]" | lfstest-testutils addcommits
|
2015-10-06 16:40:05 +00:00
|
|
|
|
2015-10-15 15:35:26 +00:00
|
|
|
# push all so no unpushed reason to not prune
|
|
|
|
git push origin master
|
|
|
|
|
|
|
|
# set no recents so max ability to prune
|
|
|
|
git config lfs.fetchrecentrefsdays 0
|
2015-11-09 17:46:29 +00:00
|
|
|
git config lfs.fetchrecentcommitsdays 0
|
2015-10-06 16:40:05 +00:00
|
|
|
|
2015-10-15 15:35:26 +00:00
|
|
|
# delete HEAD object to prove that we still download something
|
|
|
|
# also prune at the same time which will remove anything other than HEAD
|
|
|
|
delete_local_object "$oid_head"
|
|
|
|
git lfs fetch --prune
|
|
|
|
assert_local_object "$oid_head" "${#content_head}"
|
|
|
|
refute_local_object "$oid_commit1"
|
|
|
|
refute_local_object "$oid_commit2"
|
2015-10-06 16:27:36 +00:00
|
|
|
)
|
|
|
|
end_test
|
2016-02-03 20:06:05 +00:00
|
|
|
|
2016-08-15 21:11:05 +00:00
|
|
|
begin_test "fetch raw remote url"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
mkdir raw
|
|
|
|
cd raw
|
|
|
|
git init
|
|
|
|
git lfs install --local --skip-smudge
|
|
|
|
|
|
|
|
git remote add origin $GITSERVER/test-fetch
|
|
|
|
git pull origin master
|
|
|
|
|
|
|
|
# LFS object not downloaded, pointer in working directory
|
|
|
|
refute_local_object "$contents_oid"
|
2016-08-16 18:08:37 +00:00
|
|
|
grep "$content_oid" a.dat
|
2016-08-15 21:11:05 +00:00
|
|
|
|
|
|
|
git lfs fetch "$GITSERVER/test-fetch"
|
|
|
|
|
|
|
|
# LFS object downloaded, pointer still in working directory
|
|
|
|
assert_local_object "$contents_oid" 1
|
|
|
|
grep "$content_oid" a.dat
|
|
|
|
)
|
|
|
|
end_test
|
|
|
|
|
2016-02-03 20:06:05 +00:00
|
|
|
begin_test "fetch with invalid remote"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
cd repo
|
|
|
|
git lfs fetch not-a-remote 2>&1 | tee fetch.log
|
|
|
|
grep "Invalid remote name" fetch.log
|
|
|
|
)
|
|
|
|
end_test
|