3 . "$(dirname "$0")/testlib.sh"
5 begin_test "commit, delete, then push"
9 reponame="$(basename "$0" ".sh")"
10 setup_remote_repo "$reponame"
11 clone_repo "$reponame" repo
15 deleted_oid=$(calc_oid "deleted\n")
16 echo "deleted" > deleted.dat
17 git add deleted.dat .gitattributes
18 git commit -m "add deleted file"
20 git lfs push origin master --dry-run | grep "push ee31ef227442936872744b50d3297385c08b40ffc7baeaf34a39e6d81d6cd9ee => deleted.dat"
22 assert_pointer "master" "deleted.dat" "$deleted_oid" 8
24 added_oid=$(calc_oid "added\n")
25 echo "added" > added.dat
27 git commit -m "add file"
29 git lfs push origin master --dry-run | tee dryrun.log
30 grep "push ee31ef227442936872744b50d3297385c08b40ffc7baeaf34a39e6d81d6cd9ee => deleted.dat" dryrun.log
31 grep "push 3428719b7688c78a0cc8ba4b9e80b4e464c815fbccfd4b20695a15ffcefc22af => added.dat" dryrun.log
34 git commit -m "did not need deleted.dat after all"
36 git lfs push origin master --dry-run 2>&1 | tee dryrun.log
37 grep "push ee31ef227442936872744b50d3297385c08b40ffc7baeaf34a39e6d81d6cd9ee => deleted.dat" dryrun.log
38 grep "push 3428719b7688c78a0cc8ba4b9e80b4e464c815fbccfd4b20695a15ffcefc22af => added.dat" dryrun.log
41 git push origin master 2>&1 > push.log || {
46 grep "(2 of 2 files)" push.log | cat push.log
48 assert_server_object "$reponame" "$deleted_oid"
49 assert_server_object "$reponame" "$added_oid"