git-lfs/test/test-credentials.sh

294 lines
6.8 KiB
Bash
Raw Normal View History

2015-08-04 17:13:46 +00:00
#!/usr/bin/env bash
. "test/testlib.sh"
begin_test "credentials without useHttpPath, with bad path password"
2015-08-04 17:13:46 +00:00
(
set -e
reponame="$(basename "$0" ".sh")"
setup_remote_repo "$reponame"
printf "path:wrong" > "$CREDSDIR/127.0.0.1--$reponame"
2015-08-04 17:55:44 +00:00
clone_repo "$reponame" without-path
git checkout -b without-path
git lfs track "*.dat" 2>&1 | tee track.log
grep "Tracking \*.dat" track.log
contents="a"
contents_oid=$(calc_oid "$contents")
2015-08-04 17:55:44 +00:00
printf "$contents" > a.dat
git add a.dat
git add .gitattributes
git commit -m "add a.dat"
git push origin without-path 2>&1 | tee push.log
grep "(1 of 1 files)" push.log
)
end_test
begin_test "credentials with useHttpPath, with wrong password"
(
set -e
reponame="$(basename "$0" ".sh")"
setup_remote_repo "$reponame"
printf "path:wrong" > "$CREDSDIR/127.0.0.1--$reponame"
clone_repo "$reponame" with-path-wrong-pass
git config credential.useHttpPath true
git checkout -b with-path-wrong-pass
git lfs track "*.dat" 2>&1 | tee track.log
grep "Tracking \*.dat" track.log
contents="a"
contents_oid=$(calc_oid "$contents")
2015-08-04 17:55:44 +00:00
printf "$contents" > a.dat
git add a.dat
git add .gitattributes
git commit -m "add a.dat"
git push origin with-path-wrong-pass 2>&1 | tee push.log
[ "0" = "$(grep -c "(1 of 1 files)" push.log)" ]
)
end_test
begin_test "credentials with useHttpPath, with correct password"
(
set -e
reponame="$(basename "$0" ".sh")"
setup_remote_repo "$reponame"
printf "path:$reponame" > "$CREDSDIR/127.0.0.1--$reponame"
2015-08-04 17:13:46 +00:00
2015-08-04 17:55:44 +00:00
clone_repo "$reponame" with-path-correct-pass
git config credential.useHttpPath true
git checkout -b with-path-correct-pass
2015-08-04 17:13:46 +00:00
git lfs track "*.dat" 2>&1 | tee track.log
grep "Tracking \*.dat" track.log
2015-11-18 00:19:23 +00:00
# creating new branch does not re-send any objects existing on other
# remote branches anymore, generate new object, different from prev tests
contents="b"
contents_oid=$(calc_oid "$contents")
2015-08-04 17:13:46 +00:00
printf "$contents" > b.dat
git add b.dat
2015-08-04 17:13:46 +00:00
git add .gitattributes
git commit -m "add b.dat"
2015-08-04 17:13:46 +00:00
2015-08-04 17:55:44 +00:00
git push origin with-path-correct-pass 2>&1 | tee push.log
2015-08-04 17:13:46 +00:00
grep "(1 of 1 files)" push.log
)
end_test
2015-08-28 19:38:56 +00:00
begin_test "git credential"
(
set -e
printf "git:server" > "$CREDSDIR/credential-test.com"
printf "git:path" > "$CREDSDIR/credential-test.com--some-path"
mkdir empty
cd empty
git init
echo "protocol=http
host=credential-test.com" | GIT_TERMINAL_PROMPT=0 git credential fill > cred.log
cat cred.log
expected="protocol=http
host=credential-test.com
username=git
password=server"
[ "$expected" = "$(cat cred.log)" ]
echo "protocol=http
host=credential-test.com
path=some/path" | GIT_TERMINAL_PROMPT=0 git credential fill > cred.log
cat cred.log
expected="protocol=http
host=credential-test.com
username=git
password=server"
[ "$expected" = "$(cat cred.log)" ]
git config credential.useHttpPath true
echo "protocol=http
host=credential-test.com
path=some/path" | GIT_TERMINAL_PROMPT=0 git credential fill > cred.log
cat cred.log
expected="protocol=http
host=credential-test.com
path=some/path
username=git
password=path"
[ "$expected" = "$(cat cred.log)" ]
)
end_test
2015-10-07 04:14:09 +00:00
2016-03-15 17:00:01 +00:00
if [[ $(uname) == *"MINGW"* ]]; then
NETRCFILE="$HOME/_netrc"
else
NETRCFILE="$HOME/.netrc"
fi
2015-10-07 04:14:09 +00:00
begin_test "credentials from netrc"
(
set -e
2016-03-15 17:00:01 +00:00
printf "machine localhost\nlogin netrcuser\npassword netrcpass\n" >> "$NETRCFILE"
2015-10-07 04:14:09 +00:00
echo $HOME
echo "GITSERVER $GITSERVER"
2016-03-15 17:00:01 +00:00
cat $NETRCFILE
2015-10-07 04:14:09 +00:00
2016-03-15 17:00:01 +00:00
# prevent prompts on Windows particularly
export SSH_ASKPASS=
2015-10-07 04:14:09 +00:00
reponame="netrctest"
setup_remote_repo "$reponame"
clone_repo "$reponame" repo
# Need a remote named "localhost" or 127.0.0.1 in netrc will interfere with the other auth
git remote add "netrc" "$(echo $GITSERVER | sed s/127.0.0.1/localhost/)/netrctest"
git lfs env
git lfs track "*.dat"
echo "push a" > a.dat
git add .gitattributes a.dat
git commit -m "add a.dat"
git lfs push netrc master 2>&1 | tee push.log
grep "(1 of 1 files)" push.log
)
end_test
2015-10-07 04:17:06 +00:00
begin_test "credentials from netrc with bad password"
(
set -e
2016-03-15 17:00:01 +00:00
printf "machine localhost\nlogin netrcuser\npassword badpass\n" >> "$NETRCFILE"
2015-10-07 04:17:06 +00:00
echo $HOME
echo "GITSERVER $GITSERVER"
2016-03-15 17:00:01 +00:00
cat $NETRCFILE
2015-10-07 04:17:06 +00:00
2016-03-15 17:00:01 +00:00
# prevent prompts on Windows particularly
export SSH_ASKPASS=
2015-10-07 04:17:06 +00:00
reponame="netrctest"
setup_remote_repo "$reponame"
clone_repo "$reponame" repo2
# Need a remote named "localhost" or 127.0.0.1 in netrc will interfere with the other auth
git remote add "netrc" "$(echo $GITSERVER | sed s/127.0.0.1/localhost/)/netrctest"
git lfs env
git lfs track "*.dat"
echo "push a" > a.dat
git add .gitattributes a.dat
git commit -m "add a.dat"
git push netrc master 2>&1 | tee push.log
[ "0" = "$(grep -c "(1 of 1 files)" push.log)" ]
)
end_test
begin_test "credentials from lfs.url"
(
set -e
reponame="requirecreds"
setup_remote_repo "$reponame"
clone_repo "$reponame" requirecreds-lfsurl
git lfs track "*.dat"
echo "push a" > a.dat
git add .gitattributes a.dat
git commit -m "add a.dat"
echo "bad push"
git lfs env
git lfs push origin master 2>&1 | tee push.log
grep "(0 of 1 files)" push.log
echo "good push"
gitserverhost=$(echo "$GITSERVER" | cut -d'/' -f3)
git config lfs.url http://requirecreds:pass@$gitserverhost/$reponame.git/info/lfs
git lfs env
git lfs push origin master 2>&1 | tee push.log
grep "(1 of 1 files)" push.log
echo "bad fetch"
rm -rf .git/lfs/objects
git config lfs.url http://$gitserverhost/$reponame.git/info/lfs
git lfs env
git lfs fetch --all 2>&1 | tee fetch.log
grep "(0 of 1 files)" fetch.log
echo "good fetch"
rm -rf .git/lfs/objects
git config lfs.url http://requirecreds:pass@$gitserverhost/$reponame.git/info/lfs
git lfs env
git lfs fetch --all 2>&1 | tee fetch.log
grep "(1 of 1 files)" fetch.log
)
end_test
begin_test "credentials from remote.origin.url"
(
set -e
reponame="requirecreds"
setup_remote_repo "$reponame"
clone_repo "$reponame" requirecreds-remoteurl
git lfs track "*.dat"
echo "push b" > b.dat
git add .gitattributes b.dat
git commit -m "add b.dat"
echo "bad push"
git lfs env
git lfs push origin master 2>&1 | tee push.log
grep "(0 of 1 files)" push.log
echo "good push"
gitserverhost=$(echo "$GITSERVER" | cut -d'/' -f3)
git config remote.origin.url http://requirecreds:pass@$gitserverhost/$reponame.git
git lfs env
git lfs push origin master 2>&1 | tee push.log
grep "(1 of 1 files)" push.log
echo "bad fetch"
rm -rf .git/lfs/objects
git config remote.origin.url http://$gitserverhost/$reponame.git
git lfs env
git lfs fetch --all 2>&1 | tee fetch.log
grep "(0 of 1 files)" fetch.log
echo "good fetch"
rm -rf .git/lfs/objects
git config remote.origin.url http://requirecreds:pass@$gitserverhost/$reponame.git
git lfs env
git lfs fetch --all 2>&1 | tee fetch.log
grep "(1 of 1 files)" fetch.log
)
end_test