mirror of
https://github.com/clearml/dropbear
synced 2025-01-31 10:57:01 +00:00
3d12521735
* Add support for Ed25519 as a public key type Ed25519 is a elliptic curve signature scheme that offers better security than ECDSA and DSA and good performance. It may be used for both user and host keys. OpenSSH key import and fuzzer are not supported yet. Initially inspired by Peter Szabo. * Add curve25519 and ed25519 fuzzers * Add import and export of Ed25519 keys
68 lines
2.2 KiB
YAML
68 lines
2.2 KiB
YAML
language: c
|
|
|
|
git:
|
|
depth: 3
|
|
|
|
matrix:
|
|
include:
|
|
# subsequent matrix options use these first settings
|
|
- os: linux
|
|
compiler: gcc
|
|
env: WEXTRAFLAGS=-Werror
|
|
sudo: false
|
|
- env: MULTI=1 WEXTRAFLAGS=-Werror
|
|
# libtom has some warnings, so no WEXTRAFLAGS
|
|
- env: CONFIGURE_FLAGS=--enable-bundled-libtom WEXTRAFLAGS=""
|
|
- env: NOWRITEV=1 WEXTRAFLAGS=-Werror
|
|
# libtomcrypt 1.18.1 fixes clang problems, distro doesn't have that yet
|
|
- os: linux
|
|
compiler: clang
|
|
env: CONFIGURE_FLAGS=--enable-bundled-libtom WEXTRAFLAGS=""
|
|
- os: osx
|
|
compiler: clang
|
|
env: WEXTRAFLAGS=""
|
|
|
|
# Note: the fuzzing malloc wrapper doesn't replace free() in system libtomcrypt, so need bundled.
|
|
- env: DO_FUZZ=1 CONFIGURE_FLAGS="--enable-fuzz --disable-harden --enable-bundled-libtom" WEXTRAFLAGS="" LDFLAGS=-fsanitize=address EXTRACFLAGS=-fsanitize=address CXX=clang++
|
|
compiler: clang
|
|
# sanitizers need ptrace which is privileged https://github.com/travis-ci/travis-ci/issues/9033
|
|
sudo: required
|
|
|
|
# container-based builds
|
|
addons:
|
|
apt:
|
|
packages:
|
|
# packages list: https://github.com/travis-ci/apt-package-whitelist/blob/master/ubuntu-precise
|
|
- zlib1g-dev
|
|
- libtomcrypt-dev
|
|
- libtommath-dev
|
|
- mercurial
|
|
|
|
before_install:
|
|
- if [ "$CC" = "clang" ]; then WEXTRAFLAGS="$WEXTRAFLAGS -Wno-error=incompatible-library-redeclaration" ; fi # workaround
|
|
|
|
install:
|
|
- autoconf
|
|
- autoheader
|
|
- ./configure $CONFIGURE_FLAGS CFLAGS="-O2 -Wall -Wno-pointer-sign $WEXTRAFLAGS $EXTRACFLAGS" --prefix="$HOME/inst" || (cat config.log; exit 1)
|
|
- if [ "$NOWRITEV" = "1" ]; then sed -i -e s/HAVE_WRITEV/DONT_HAVE_WRITEV/ config.h ; fi
|
|
- make -j3
|
|
- test -z $DO_FUZZ || make fuzzstandalone
|
|
# avoid concurrent install, osx/freebsd is racey (https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=208093)
|
|
- make install
|
|
|
|
script:
|
|
- ~/inst/bin/dropbearkey -t rsa -f testrsa
|
|
- ~/inst/bin/dropbearkey -t dss -f testdss
|
|
- ~/inst/bin/dropbearkey -t ecdsa -f testec256 -s 256
|
|
- ~/inst/bin/dropbearkey -t ecdsa -f testec384 -s 384
|
|
- ~/inst/bin/dropbearkey -t ecdsa -f testec521 -s 521
|
|
- ~/inst/bin/dropbearkey -t ed25519 -f tested25519
|
|
- test -z $DO_FUZZ || ./fuzzers_test.sh
|
|
|
|
branches:
|
|
only:
|
|
- master
|
|
- coverity
|
|
|