mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-05-29 03:36:07 +08:00
travis-ci enable tests under address sanitizier (#8095)
This commit is contained in:
+27
-15
@@ -7,6 +7,15 @@ git:
|
|||||||
depth: 2000
|
depth: 2000
|
||||||
submodules: false
|
submodules: false
|
||||||
|
|
||||||
|
env:
|
||||||
|
global:
|
||||||
|
# COVERITY KEY
|
||||||
|
- secure: "NyaJoCGjU0Xc90Y6bxVYWLgjrJX5HlZsm/SPxruZ6I7xkGo19fJIFzGegOHQFR32D4AiKjllfjTUNy+ncckWplind0QwxtF4/kxXrz9XBfiby6X8jLYXIekrB6Ay0mBLGbniDdh+lpWtcyop6Dmkt5bdJCJuKY2nv9ENnhhs07M="
|
||||||
|
# AWS KEY: $PX4_AWS_KEY
|
||||||
|
- secure: "XknnZHWBbpHbN4f3fuAVwUztdLIu8ej4keC3aQSDofo3uw8AFEzojfsQsN9u77ShWSIV4iYJWh9C9ALkCx7TocJ+xYjiboo10YhM9lH/8u+EXjYWG6GHS8ua0wkir+cViSxoLNaMtmcb/rPTicJecAGANxLsIHyBAgTL3fkbLSA="
|
||||||
|
# AWS SECRET: $PX4_AWS_SECRET
|
||||||
|
- secure: "h6oajlW68dWIr+wZhO58Dv6e68dZHrBLVA6lPXZmheFQBW6Xam1HuLGA0LOW6cL9TnrAsOZ8g4goB58eMQnMEijFZKi3mhRwZhd/Xjq/ZGJOWBUrLoQHZUw2dQk5ja5vmUlKEoQnFZjDuMjx8KfX5ZMNy8A3yssWZtJYHD8c+bk="
|
||||||
|
|
||||||
matrix:
|
matrix:
|
||||||
fast_finish: true
|
fast_finish: true
|
||||||
include:
|
include:
|
||||||
@@ -24,7 +33,12 @@ matrix:
|
|||||||
sudo: required
|
sudo: required
|
||||||
services:
|
services:
|
||||||
- docker
|
- docker
|
||||||
env: BUILD_TARGET=tests PX4_DOCKER_REPO=px4io/px4-dev-base:ubuntu17.10
|
env: BUILD_TARGET=tests_asan
|
||||||
|
- os: linux
|
||||||
|
sudo: required
|
||||||
|
services:
|
||||||
|
- docker
|
||||||
|
env: BUILD_TARGET=tests_coverage
|
||||||
- os: linux
|
- os: linux
|
||||||
sudo: required
|
sudo: required
|
||||||
services:
|
services:
|
||||||
@@ -50,12 +64,8 @@ matrix:
|
|||||||
sudo: required
|
sudo: required
|
||||||
env: BUILD_TARGET=coverity_scan
|
env: BUILD_TARGET=coverity_scan
|
||||||
allow_failures:
|
allow_failures:
|
||||||
- os: linux
|
- env: BUILD_TARGET=tests_asan
|
||||||
sudo: required
|
- env: BUILD_TARGET=tests_coverage
|
||||||
services:
|
|
||||||
- docker
|
|
||||||
env: BUILD_TARGET=tests_coverage
|
|
||||||
|
|
||||||
|
|
||||||
cache:
|
cache:
|
||||||
ccache: true
|
ccache: true
|
||||||
@@ -67,30 +77,32 @@ before_install:
|
|||||||
fi
|
fi
|
||||||
# use git:// to fetch instead of https://
|
# use git:// to fetch instead of https://
|
||||||
- git config --global url."git://".insteadOf https://
|
- git config --global url."git://".insteadOf https://
|
||||||
env:
|
|
||||||
global:
|
|
||||||
# COVERITY KEY
|
|
||||||
- secure: "NyaJoCGjU0Xc90Y6bxVYWLgjrJX5HlZsm/SPxruZ6I7xkGo19fJIFzGegOHQFR32D4AiKjllfjTUNy+ncckWplind0QwxtF4/kxXrz9XBfiby6X8jLYXIekrB6Ay0mBLGbniDdh+lpWtcyop6Dmkt5bdJCJuKY2nv9ENnhhs07M="
|
|
||||||
# AWS KEY: $PX4_AWS_KEY
|
|
||||||
- secure: "XknnZHWBbpHbN4f3fuAVwUztdLIu8ej4keC3aQSDofo3uw8AFEzojfsQsN9u77ShWSIV4iYJWh9C9ALkCx7TocJ+xYjiboo10YhM9lH/8u+EXjYWG6GHS8ua0wkir+cViSxoLNaMtmcb/rPTicJecAGANxLsIHyBAgTL3fkbLSA="
|
|
||||||
# AWS SECRET: $PX4_AWS_SECRET
|
|
||||||
- secure: "h6oajlW68dWIr+wZhO58Dv6e68dZHrBLVA6lPXZmheFQBW6Xam1HuLGA0LOW6cL9TnrAsOZ8g4goB58eMQnMEijFZKi3mhRwZhd/Xjq/ZGJOWBUrLoQHZUw2dQk5ja5vmUlKEoQnFZjDuMjx8KfX5ZMNy8A3yssWZtJYHD8c+bk="
|
|
||||||
|
|
||||||
script:
|
script:
|
||||||
- if [[ "${BUILD_TARGET}" = "coverity_scan" ]]; then
|
- if [[ "${BUILD_TARGET}" = "coverity_scan" ]]; then
|
||||||
echo "no script for coverity build";
|
echo "no script for coverity build";
|
||||||
|
|
||||||
elif [[ "${TRAVIS_BRANCH}" = "coverity" ]]; then
|
elif [[ "${TRAVIS_BRANCH}" = "coverity" ]]; then
|
||||||
echo "exit early for coverity build" && exit 0;
|
echo "exit early for coverity build" && exit 0;
|
||||||
|
|
||||||
elif [[ "${BUILD_TARGET}" = "check_format" ]]; then
|
elif [[ "${BUILD_TARGET}" = "check_format" ]]; then
|
||||||
./Tools/docker_run.sh 'make check_format';
|
./Tools/docker_run.sh 'make check_format';
|
||||||
|
|
||||||
elif [[ "${BUILD_TARGET}" = "tests" ]]; then
|
elif [[ "${BUILD_TARGET}" = "tests" ]]; then
|
||||||
./Tools/docker_run.sh 'make tests';
|
./Tools/docker_run.sh 'make tests';
|
||||||
|
|
||||||
elif [[ "${BUILD_TARGET}" = "tests_coverage" ]]; then
|
elif [[ "${BUILD_TARGET}" = "tests_coverage" ]]; then
|
||||||
./Tools/docker_run.sh 'make tests_coverage' && bash <(curl -s https://codecov.io/bash) -F unittests;
|
./Tools/docker_run.sh 'make tests_coverage' && bash <(curl -s https://codecov.io/bash) -F unittests;
|
||||||
|
|
||||||
|
elif [[ "${BUILD_TARGET}" = "tests_asan" ]]; then
|
||||||
|
./Tools/docker_run.sh 'PX4_ASAN=1 make tests';
|
||||||
|
|
||||||
elif [[ "${BUILD_TARGET}" = "px4_metadata" ]]; then
|
elif [[ "${BUILD_TARGET}" = "px4_metadata" ]]; then
|
||||||
./Tools/docker_run.sh 'make px4_metadata';
|
./Tools/docker_run.sh 'make px4_metadata';
|
||||||
|
|
||||||
elif [[ "${BUILD_TARGET}" = "clang-tidy" ]]; then
|
elif [[ "${BUILD_TARGET}" = "clang-tidy" ]]; then
|
||||||
./Tools/docker_run.sh 'make clang-tidy-quiet';
|
./Tools/docker_run.sh 'make clang-tidy-quiet';
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
after_success:
|
after_success:
|
||||||
|
|||||||
@@ -108,10 +108,10 @@ else
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
# additional config parameters passed to cmake
|
# additional config parameters passed to cmake
|
||||||
CMAKE_ARGS := -Wno-deprecated
|
CMAKE_ARGS += -Wno-deprecated
|
||||||
|
|
||||||
ifdef EXTERNAL_MODULES_LOCATION
|
ifdef EXTERNAL_MODULES_LOCATION
|
||||||
CMAKE_ARGS := -DEXTERNAL_MODULES_LOCATION:STRING=$(EXTERNAL_MODULES_LOCATION)
|
CMAKE_ARGS += -DEXTERNAL_MODULES_LOCATION:STRING=$(EXTERNAL_MODULES_LOCATION)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifdef PX4_CMAKE_BUILD_TYPE
|
ifdef PX4_CMAKE_BUILD_TYPE
|
||||||
@@ -296,7 +296,7 @@ format:
|
|||||||
.PHONY: tests tests_coverage
|
.PHONY: tests tests_coverage
|
||||||
|
|
||||||
tests:
|
tests:
|
||||||
$(MAKE) --no-print-directory posix_sitl_default test_results
|
$(MAKE) --no-print-directory posix_sitl_default test_results ASAN_OPTIONS="color=always"
|
||||||
|
|
||||||
tests_coverage:
|
tests_coverage:
|
||||||
@$(MAKE) --no-print-directory posix_sitl_default test_coverage_genhtml PX4_CMAKE_BUILD_TYPE=Coverage
|
@$(MAKE) --no-print-directory posix_sitl_default test_coverage_genhtml PX4_CMAKE_BUILD_TYPE=Coverage
|
||||||
|
|||||||
@@ -36,6 +36,16 @@ option(SANITIZE_MEMORY "Enable MemorySanitizer" Off)
|
|||||||
option(SANITIZE_THREAD "Enable ThreadSanitizer" Off)
|
option(SANITIZE_THREAD "Enable ThreadSanitizer" Off)
|
||||||
option(SANITIZE_UNDEFINED "Enable UndefinedBehaviorSanitizer" Off)
|
option(SANITIZE_UNDEFINED "Enable UndefinedBehaviorSanitizer" Off)
|
||||||
|
|
||||||
|
if(DEFINED ENV{PX4_ASAN})
|
||||||
|
set(SANITIZE_ADDRESS ON)
|
||||||
|
elseif(DEFINED ENV{PX4_MSAN})
|
||||||
|
set(SANITIZE_MEMORY ON)
|
||||||
|
elseif(DEFINED ENV{PX4_TSAN})
|
||||||
|
set(SANITIZE_THREAD ON)
|
||||||
|
elseif(DEFINED ENV{PX4_UBSAN})
|
||||||
|
set(SANITIZE_UNDEFINED ON)
|
||||||
|
endif()
|
||||||
|
|
||||||
if (SANITIZE_ADDRESS)
|
if (SANITIZE_ADDRESS)
|
||||||
message(STATUS "address sanitizer enabled")
|
message(STATUS "address sanitizer enabled")
|
||||||
|
|
||||||
@@ -48,6 +58,7 @@ if (SANITIZE_ADDRESS)
|
|||||||
-fsanitize=address
|
-fsanitize=address
|
||||||
#-fsanitize-address-use-after-scope
|
#-fsanitize-address-use-after-scope
|
||||||
)
|
)
|
||||||
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fsanitize=address" CACHE INTERNAL "" FORCE)
|
||||||
|
|
||||||
elseif(SANITIZE_MEMORY)
|
elseif(SANITIZE_MEMORY)
|
||||||
message(STATUS "thread sanitizer enabled")
|
message(STATUS "thread sanitizer enabled")
|
||||||
@@ -64,6 +75,7 @@ elseif(SANITIZE_THREAD)
|
|||||||
-g3
|
-g3
|
||||||
-fsanitize=thread
|
-fsanitize=thread
|
||||||
)
|
)
|
||||||
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fsanitize=thread" CACHE INTERNAL "" FORCE)
|
||||||
|
|
||||||
elseif(SANITIZE_UNDEFINED)
|
elseif(SANITIZE_UNDEFINED)
|
||||||
message(STATUS "undefined behaviour sanitizer enabled")
|
message(STATUS "undefined behaviour sanitizer enabled")
|
||||||
@@ -90,5 +102,6 @@ elseif(SANITIZE_UNDEFINED)
|
|||||||
-fsanitize=vla-bound
|
-fsanitize=vla-bound
|
||||||
-fsanitize=vptr
|
-fsanitize=vptr
|
||||||
)
|
)
|
||||||
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fsanitize=undefined" CACHE INTERNAL "" FORCE)
|
||||||
|
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
Reference in New Issue
Block a user