2015-07-30 02:37:31 +00:00
|
|
|
#!/usr/bin/env bash
|
2015-06-20 16:10:54 +00:00
|
|
|
|
|
|
|
. "test/testlib.sh"
|
|
|
|
|
|
|
|
begin_test "fetch"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
|
|
|
|
reponame="$(basename "$0" ".sh")"
|
|
|
|
setup_remote_repo "$reponame"
|
|
|
|
|
|
|
|
clone_repo "$reponame" clone
|
|
|
|
|
|
|
|
clone_repo "$reponame" repo
|
|
|
|
|
|
|
|
git lfs track "*.dat" 2>&1 | tee track.log
|
|
|
|
grep "Tracking \*.dat" track.log
|
|
|
|
|
|
|
|
contents="a"
|
|
|
|
contents_oid=$(printf "$contents" | shasum -a 256 | cut -f 1 -d " ")
|
|
|
|
|
|
|
|
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
|
|
|
|
grep "(1 of 1 files)" push.log
|
|
|
|
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
|
|
|
|
b="b"
|
|
|
|
b_oid=$(printf "$b" | shasum -a 256 | cut -f 1 -d " ")
|
|
|
|
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
|
|
|
|
|
|
|
# change to the clone's working directory
|
|
|
|
cd ../clone
|
|
|
|
|
|
|
|
git pull 2>&1 | grep "Downloading a.dat (1 B)"
|
|
|
|
|
|
|
|
[ "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
|
|
|
|
|
|
|
|
|
|
|
# Remove the working directory and lfs files
|
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
git lfs fetch 2>&1 | grep "(1 of 1 files)"
|
2015-08-13 16:22:29 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
2015-06-20 16:10:54 +00:00
|
|
|
|
2015-08-13 16:22:29 +00:00
|
|
|
# test with just remote specified
|
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
git lfs fetch origin 2>&1 | grep "(1 of 1 files)"
|
2015-08-06 10:44:38 +00:00
|
|
|
assert_local_object "$contents_oid" 1
|
2015-06-20 16:10:54 +00:00
|
|
|
|
|
|
|
git checkout newbranch
|
|
|
|
git checkout master
|
|
|
|
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
|
2015-08-06 13:56:57 +00:00
|
|
|
|
2015-08-07 17:18:39 +00:00
|
|
|
# Test include / exclude filters supplied in gitconfig
|
2015-08-06 13:56:57 +00:00
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
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"
|
2015-07-29 15:34:15 +00:00
|
|
|
|
2015-08-06 13:56:57 +00:00
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
git config --unset "lfs.fetchinclude"
|
|
|
|
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
|
|
|
|
|
|
|
|
rm -rf .git/lfs/objects
|
|
|
|
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
|
|
|
|
|
|
|
|
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"
|
2015-08-07 17:18:39 +00:00
|
|
|
|
|
|
|
# Test include / exclude filters supplied on the command line
|
|
|
|
git config --unset "lfs.fetchinclude"
|
|
|
|
git config --unset "lfs.fetchexclude"
|
|
|
|
rm -rf .git/lfs/objects
|
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"
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
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"
|
2015-06-20 16:10:54 +00:00
|
|
|
)
|
|
|
|
end_test
|
2015-08-24 16:54:56 +00:00
|
|
|
|
|
|
|
begin_test "fetch-recent"
|
|
|
|
(
|
|
|
|
set -e
|
|
|
|
|
|
|
|
reponame="fetch-recent"
|
|
|
|
setup_remote_repo "$reponame"
|
|
|
|
|
|
|
|
clone_repo "$reponame" "$reponame"
|
|
|
|
|
2015-08-25 15:57:28 +00:00
|
|
|
git lfs track "*.dat" 2>&1 | tee track.log
|
|
|
|
grep "Tracking \*.dat" track.log
|
2015-08-24 16:54:56 +00:00
|
|
|
|
2015-08-25 15:57:28 +00:00
|
|
|
# generate content we'll use
|
|
|
|
content1="filecontent1"
|
|
|
|
content2="filecontent2"
|
|
|
|
content3="filecontent3"
|
|
|
|
content4="filecontent4"
|
|
|
|
oid1=$(printf "$content1" | shasum -a 256 | cut -f 1 -d " ")
|
|
|
|
oid2=$(printf "$content2" | shasum -a 256 | cut -f 1 -d " ")
|
|
|
|
oid3=$(printf "$content3" | shasum -a 256 | cut -f 1 -d " ")
|
|
|
|
oid4=$(printf "$content4" | shasum -a 256 | cut -f 1 -d " ")
|
|
|
|
|
|
|
|
echo "[
|
|
|
|
{
|
|
|
|
\"CommitDate\":\"$(get_date -6m)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file1.dat\",\"Size\":22}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"CommitDate\":\"$(get_date -3m)\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file1.dat\",\"Size\":${#content1}, \"Data\":\"$content1\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"CommitDate\":\"$(get_date -1m)\",
|
|
|
|
\"NewBranch\":\"other_branch\",
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file1.dat\",\"Size\":${#content4}, \"Data\":\"$content4\"}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
\"CommitDate\":\"$(get_date -1m)\",
|
|
|
|
\"ParentBranches\":[\"master\"],
|
|
|
|
\"Files\":[
|
|
|
|
{\"Filename\":\"file1.dat\",\"Size\":${#content2}, \"Data\":\"$content2\"},
|
|
|
|
{\"Filename\":\"file2.dat\",\"Size\":${#content3}, \"Data\":\"$content3\"}]
|
|
|
|
}
|
|
|
|
]" | lfstest-testutils addcommits
|
|
|
|
|
|
|
|
git push origin master:master other_branch:other_branch
|
|
|
|
assert_server_object "$reponame" "$oid1"
|
|
|
|
assert_server_object "$reponame" "$oid2"
|
|
|
|
assert_server_object "$reponame" "$oid3"
|
|
|
|
assert_server_object "$reponame" "$oid4"
|
|
|
|
|
|
|
|
# rm -rf .git/lfs/objects
|
|
|
|
|
|
|
|
# # fetch normally, should just get the last state for file1/2
|
|
|
|
# git lfs fetch origin master
|
|
|
|
# assert_local_object "$oid2" "${#content2}"
|
|
|
|
# assert_local_object "$oid3" "${#content3}"
|
2015-08-24 16:54:56 +00:00
|
|
|
|
|
|
|
)
|
|
|
|
end_test
|