Add pull test (failing initially)
This commit is contained in:
parent
cc6032a716
commit
096b6da385
79
test/test-pull.sh
Executable file
79
test/test-pull.sh
Executable file
@ -0,0 +1,79 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
. "test/testlib.sh"
|
||||||
|
|
||||||
|
begin_test "pull"
|
||||||
|
(
|
||||||
|
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)" ]
|
||||||
|
|
||||||
|
assert_pointer "master" "a.dat" "$contents_oid" 1
|
||||||
|
|
||||||
|
refute_server_object "$reponame" "$contents_oid"
|
||||||
|
|
||||||
|
git push origin master 2>&1 | tee push.log
|
||||||
|
grep "(1 of 1 files)" push.log
|
||||||
|
grep "master -> master" push.log
|
||||||
|
|
||||||
|
assert_server_object "$reponame" "$contents_oid"
|
||||||
|
|
||||||
|
# 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"
|
||||||
|
assert_pointer "newbranch" "b.dat" "$b_oid" 1
|
||||||
|
|
||||||
|
git push origin newbranch
|
||||||
|
assert_server_object "$reponame" "$b_oid"
|
||||||
|
|
||||||
|
# change to the clone's working directory
|
||||||
|
cd ../clone
|
||||||
|
|
||||||
|
git pull 2>&1 | grep "Downloading a.dat (1 B)"
|
||||||
|
|
||||||
|
[ "a" = "$(cat a.dat)" ]
|
||||||
|
|
||||||
|
assert_pointer "master" "a.dat" "$contents_oid" 1
|
||||||
|
|
||||||
|
|
||||||
|
# Remove the working directory and lfs files
|
||||||
|
rm a.dat
|
||||||
|
rm -rf .git/lfs/objects
|
||||||
|
|
||||||
|
git lfs pull 2>&1 | grep "(1 of 1 files)"
|
||||||
|
|
||||||
|
[ "a" = "$(cat a.dat)" ]
|
||||||
|
|
||||||
|
git checkout newbranch
|
||||||
|
git checkout master
|
||||||
|
rm -rf .git/lfs/objects
|
||||||
|
|
||||||
|
git lfs pull newbranch 2>&1 | grep "(2 of 2 files)"
|
||||||
|
)
|
||||||
|
end_test
|
Loading…
Reference in New Issue
Block a user