mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-03 04:01:41 +00:00
77 lines
2.4 KiB
Bash
Executable File
77 lines
2.4 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
if [ -n "$COVERITY" ];
|
|
then
|
|
./script/coverity.sh;
|
|
exit $?;
|
|
fi
|
|
|
|
mkdir _build
|
|
cd _build
|
|
# shellcheck disable=SC2086
|
|
cmake .. -DCMAKE_INSTALL_PREFIX=../_install $OPTIONS || exit $?
|
|
make -j2 install || exit $?
|
|
|
|
# If this platform doesn't support test execution, bail out now
|
|
if [ -n "$SKIP_TESTS" ];
|
|
then
|
|
exit $?;
|
|
fi
|
|
|
|
# Create a test repo which we can use for the online::push tests
|
|
mkdir "$HOME"/_temp
|
|
git init --bare "$HOME"/_temp/test.git
|
|
git daemon --listen=localhost --export-all --enable=receive-pack --base-path="$HOME"/_temp "$HOME"/_temp 2>/dev/null &
|
|
export GITTEST_REMOTE_URL="git://localhost/test.git"
|
|
|
|
# Run the test suite
|
|
ctest -V -R libgit2_clar || exit $?
|
|
|
|
# Now that we've tested the raw git protocol, let's set up ssh to we
|
|
# can do the push tests over it
|
|
|
|
killall git-daemon
|
|
|
|
if [ "$TRAVIS_OS_NAME" = "osx" ]; then
|
|
echo 'PasswordAuthentication yes' | sudo tee -a /etc/sshd_config
|
|
fi
|
|
|
|
ssh-keygen -t rsa -f ~/.ssh/id_rsa -N "" -q
|
|
cat ~/.ssh/id_rsa.pub >>~/.ssh/authorized_keys
|
|
ssh-keyscan -t rsa localhost >>~/.ssh/known_hosts
|
|
|
|
# Get the fingerprint for localhost and remove the colons so we can parse it as a hex number
|
|
export GITTEST_REMOTE_SSH_FINGERPRINT=$(ssh-keygen -F localhost -l | tail -n 1 | cut -d ' ' -f 2 | tr -d ':')
|
|
|
|
export GITTEST_REMOTE_URL="ssh://localhost/$HOME/_temp/test.git"
|
|
export GITTEST_REMOTE_USER=$USER
|
|
export GITTEST_REMOTE_SSH_KEY="$HOME/.ssh/id_rsa"
|
|
export GITTEST_REMOTE_SSH_PUBKEY="$HOME/.ssh/id_rsa.pub"
|
|
export GITTEST_REMOTE_SSH_PASSPHRASE=""
|
|
|
|
|
|
# Can we ask Travis to cache this file?
|
|
curl -L https://github.com/ethomson/poxyproxy/releases/download/v0.1.0/poxyproxy-0.1.0.jar >poxyproxy.jar || exit $?
|
|
|
|
if [ -e ./libgit2_clar ]; then
|
|
./libgit2_clar -sonline::push -sonline::clone::ssh_cert &&
|
|
./libgit2_clar -sonline::clone::ssh_with_paths || exit $?
|
|
if [ "$TRAVIS_OS_NAME" = "linux" ]; then
|
|
./libgit2_clar -sonline::clone::cred_callback || exit $?
|
|
fi
|
|
|
|
java -jar poxyproxy.jar -d --port 8080 --credentials foo:bar &
|
|
|
|
export GITTEST_REMOTE_PROXY_URL="http://foo:bar@localhost:8080/"
|
|
./libgit2_clar -sonline::clone::proxy_credentials_in_url
|
|
export GITTEST_REMOTE_PROXY_URL="http://localhost:8080/"
|
|
export GITTEST_REMOTE_PROXY_USER="foo"
|
|
export GITTEST_REMOTE_PROXY_PASS="bar"
|
|
./libgit2_clar -sonline::clone::proxy_credentials_request
|
|
|
|
fi
|
|
|
|
export GITTEST_REMOTE_URL="https://github.com/libgit2/non-existent"
|
|
export GITTEST_REMOTE_USER="libgit2test"
|
|
ctest -V -R libgit2_clar-cred_callback
|