Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
git2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
git2
Commits
534b70af
Unverified
Commit
534b70af
authored
Jun 07, 2018
by
Patrick Steinhardt
Committed by
GitHub
Jun 07, 2018
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #4558 from tiennou/travis/war-on-leaks
travis: war on leaks
parents
20306d36
61eaaadf
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
131 additions
and
86 deletions
+131
-86
.travis.yml
+4
-6
libgit2_clar.supp
+25
-0
script/cibuild.sh
+5
-80
script/cileaks.sh
+15
-0
script/citest.sh
+82
-0
No files found.
.travis.yml
View file @
534b70af
...
...
@@ -17,8 +17,8 @@ env:
-
secure
:
"
YnhS+8n6B+uoyaYfaJ3Lei7cSJqHDPiKJCKFIF2c87YDfmCvAJke8QtE7IzjYDs7UFkTCM4ox+ph2bERUrxZbSCyEkHdjIZpKuMJfYWja/jgMqTMxdyOH9y8JLFbZsSXDIXDwqBlC6vVyl1fP90M35wuWcNTs6tctfVWVofEFbs="
-
GITTEST_INVASIVE_FS_SIZE=1
matrix
:
-
OPTIONS="-DTHREADSAFE=ON -DENABLE_TRACE=ON -DCMAKE_BUILD_TYPE=Release
-DENABLE_WERROR=ON
"
-
OPTIONS="-DTHREADSAFE=OFF -DBUILD_EXAMPLES=ON
-DENABLE_WERROR=ON
"
-
OPTIONS="-DTHREADSAFE=ON -DENABLE_TRACE=ON -DCMAKE_BUILD_TYPE=Release"
-
OPTIONS="-DTHREADSAFE=OFF -DBUILD_EXAMPLES=ON"
dist
:
trusty
sudo
:
false
...
...
@@ -74,10 +74,8 @@ install:
# Run the Build script and tests
script
:
-
script/cibuild.sh
# Run Tests
after_success
:
-
if [ "$TRAVIS_OS_NAME" = "linux" -a -n "$VALGRIND" ]; then valgrind --leak-check=full --show-reachable=yes --suppressions=./libgit2_clar.supp _build/libgit2_clar -ionline; fi
-
script/citest.sh
-
script/cileaks.sh
# Only watch the development and master branches
branches
:
...
...
libgit2_clar.supp
View file @
534b70af
...
...
@@ -47,3 +47,28 @@
...
fun:__check_pf
}
{
ignore-curl-global-init
Memcheck:Leak
...
fun:curl_global_init
}
{
ignore-libssh2-gcrypt-leak
Memcheck:Leak
...
fun:gcry_control
obj:*libssh2.so*
}
{
ignore-noai6ai_cached-double-free
Memcheck:Free
fun:free
fun:__libc_freeres
...
fun:exit
...
}
script/cibuild.sh
View file @
534b70af
...
...
@@ -2,10 +2,9 @@
set
-x
if
[
-n
"
$COVERITY
"
]
;
then
./script/coverity.sh
;
exit
$?
;
if
[
-n
"
$COVERITY
"
]
;
then
./script/coverity.sh
exit
$?
fi
if
[
"
$TRAVIS_OS_NAME
"
=
"osx"
]
;
then
...
...
@@ -21,82 +20,8 @@ if [ "$TRAVIS_OS_NAME" = "osx" ]; then
mount
-t
hfs
$device
$CLAR_TMP
fi
# Should 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
$?
# Run this early so we know it's ready by the time we need it
java
-jar
poxyproxy.jar
-d
--port
8080
--credentials
foo:bar &
mkdir _build
cd
_build
# shellcheck disable=SC2086
cmake ..
-DBUILD_EXAMPLES
=
ON
-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
# Set up sshd
mkdir ~/sshd/
cat
>
~/sshd/sshd_config
<<-
EOF
Port 2222
ListenAddress 0.0.0.0
Protocol 2
HostKey
${
HOME
}
/sshd/id_rsa
PidFile
${
HOME
}
/sshd/pid
RSAAuthentication yes
PasswordAuthentication yes
PubkeyAuthentication yes
ChallengeResponseAuthentication no
# Required here as sshd will simply close connection otherwise
UsePAM no
EOF
ssh-keygen
-t
rsa
-f
~/sshd/id_rsa
-N
""
-q
/usr/sbin/sshd
-f
~/sshd/sshd_config
# Set up keys
ssh-keygen
-t
rsa
-f
~/.ssh/id_rsa
-N
""
-q
cat
~/.ssh/id_rsa.pub
>>
~/.ssh/authorized_keys
while
read
algorithm key comment
;
do
echo
"[localhost]:2222
$algorithm
$key
"
>>
~/.ssh/known_hosts
done
<~/sshd/id_rsa.pub
# Get the fingerprint for localhost and remove the colons so we can parse it as
# a hex number. The Mac version is newer so it has a different output format.
if
[
"
$TRAVIS_OS_NAME
"
=
"osx"
]
;
then
export
GITTEST_REMOTE_SSH_FINGERPRINT
=
$(
ssh-keygen
-E
md5
-F
'[localhost]:2222'
-l
| tail
-n
1 | cut
-d
' '
-f
3 | cut
-d
:
-f2-
| tr
-d
:
)
else
export
GITTEST_REMOTE_SSH_FINGERPRINT
=
$(
ssh-keygen
-F
'[localhost]:2222'
-l
| tail
-n
1 | cut
-d
' '
-f
2 | tr
-d
':'
)
fi
# Use the SSH server
export
GITTEST_REMOTE_URL
=
"ssh://localhost:2222/
$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
=
""
ctest
-V
-R
libgit2_clar-ssh
||
exit
$?
# Use the proxy we started at the beginning
export
GITTEST_REMOTE_PROXY_URL
=
"localhost:8080"
export
GITTEST_REMOTE_PROXY_USER
=
"foo"
export
GITTEST_REMOTE_PROXY_PASS
=
"bar"
ctest
-V
-R
libgit2_clar-proxy_credentials
||
exit
$?
kill
$(
cat
"
$HOME
/sshd/pid"
)
cmake ..
-DBUILD_EXAMPLES
=
ON
-DENABLE_WERROR
=
ON
-DCMAKE_INSTALL_PREFIX
=
../_install
$OPTIONS
||
exit
$?
cmake
--build
.
--target
install
||
exit
$?
script/cileaks.sh
0 → 100755
View file @
534b70af
#!/bin/sh
set
-x
# If this platform doesn't support test execution, bail out now
if
[
-n
"
$SKIP_TESTS
"
]
;
then
exit
$?
fi
if
[
-n
"
$VALGRIND
"
-a
-e
"
$(
which valgrind
)
"
]
;
then
valgrind
--leak-check
=
full
--show-reachable
=
yes
--error-exitcode
=
125
--num-callers
=
50
--suppressions
=
./libgit2_clar.supp _build/libgit2_clar
$@
-ionline
-xbuf
::oom
elif
[
-n
"
$LEAKS
"
-a
-e
"
$(
which leaks
)
"
]
;
then
MallocStackLogging
=
1
MallocScribble
=
1 leaks
-atExit
--
_build/libgit2_clar
-ionline
fi
script/citest.sh
0 → 100755
View file @
534b70af
#!/bin/sh
set
-x
# If this platform doesn't support test execution, bail out now
if
[
-n
"
$SKIP_TESTS
"
]
;
then
exit
$?
fi
if
[
!
-d
_build
]
;
then
echo
"no _build dir found; you should run cibuild.sh first"
exit
1
fi
cd
_build
# Should 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
$?
# Run this early so we know it's ready by the time we need it
java
-jar
poxyproxy.jar
-d
--port
8080
--credentials
foo:bar &
# 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
# Set up sshd
mkdir ~/sshd/
cat
>
~/sshd/sshd_config
<<-
EOF
Port 2222
ListenAddress 0.0.0.0
Protocol 2
HostKey
${
HOME
}
/sshd/id_rsa
PidFile
${
HOME
}
/sshd/pid
RSAAuthentication yes
PasswordAuthentication yes
PubkeyAuthentication yes
ChallengeResponseAuthentication no
# Required here as sshd will simply close connection otherwise
UsePAM no
EOF
ssh-keygen
-t
rsa
-f
~/sshd/id_rsa
-N
""
-q
/usr/sbin/sshd
-f
~/sshd/sshd_config
# Set up keys
ssh-keygen
-t
rsa
-f
~/.ssh/id_rsa
-N
""
-q
cat
~/.ssh/id_rsa.pub
>>
~/.ssh/authorized_keys
while
read
algorithm key comment
;
do
echo
"[localhost]:2222
$algorithm
$key
"
>>
~/.ssh/known_hosts
done
<~/sshd/id_rsa.pub
# Get the fingerprint for localhost and remove the colons so we can parse it as
# a hex number. The Mac version is newer so it has a different output format.
if
[
"
$TRAVIS_OS_NAME
"
=
"osx"
]
;
then
export
GITTEST_REMOTE_SSH_FINGERPRINT
=
$(
ssh-keygen
-E
md5
-F
'[localhost]:2222'
-l
| tail
-n
1 | cut
-d
' '
-f
3 | cut
-d
:
-f2-
| tr
-d
:
)
else
export
GITTEST_REMOTE_SSH_FINGERPRINT
=
$(
ssh-keygen
-F
'[localhost]:2222'
-l
| tail
-n
1 | cut
-d
' '
-f
2 | tr
-d
':'
)
fi
# Use the SSH server
export
GITTEST_REMOTE_URL
=
"ssh://localhost:2222/
$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
=
""
ctest
-V
-R
libgit2_clar-ssh
||
exit
$?
# Use the proxy we started at the beginning
export
GITTEST_REMOTE_PROXY_URL
=
"localhost:8080"
export
GITTEST_REMOTE_PROXY_USER
=
"foo"
export
GITTEST_REMOTE_PROXY_PASS
=
"bar"
ctest
-V
-R
libgit2_clar-proxy_credentials
||
exit
$?
kill
$(
cat
"
$HOME
/sshd/pid"
)
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment