diff options
Diffstat (limited to 'src/spdk/autobuild.sh')
-rwxr-xr-x | src/spdk/autobuild.sh | 140 |
1 files changed, 140 insertions, 0 deletions
diff --git a/src/spdk/autobuild.sh b/src/spdk/autobuild.sh new file mode 100755 index 00000000..270e6763 --- /dev/null +++ b/src/spdk/autobuild.sh @@ -0,0 +1,140 @@ +#!/usr/bin/env bash + +set -e + +rootdir=$(readlink -f $(dirname $0)) +source "$rootdir/test/common/autotest_common.sh" + +out=$PWD + +umask 022 + +cd $rootdir + +date -u +git describe --tags + +./configure $config_params + +# Print some test system info out for the log +echo "** START ** Info for Hostname: $HOSTNAME" +uname -a +$MAKE cc_version +$MAKE cxx_version +echo "** END ** Info for Hostname: $HOSTNAME" + +timing_enter autobuild + +timing_enter check_format +if [ $SPDK_RUN_CHECK_FORMAT -eq 1 ]; then + ./scripts/check_format.sh +fi +timing_exit check_format + +$MAKE $MAKEFLAGS clean +if [ $SPDK_BUILD_SHARED_OBJECT -eq 1 ]; then + ./configure $config_params --with-shared + $MAKE $MAKEFLAGS + $MAKE $MAKEFLAGS clean + report_test_completion "shared_object_build" +fi + +scanbuild='' +make_timing_label='make' +if [ $SPDK_RUN_SCANBUILD -eq 1 ] && hash scan-build; then + scanbuild="scan-build -o $out/scan-build-tmp --status-bugs" + make_timing_label='scanbuild_make' + report_test_completion "scanbuild" + +fi + +if [ $SPDK_RUN_VALGRIND -eq 1 ]; then + report_test_completion "valgrind" +fi + +if [ $SPDK_RUN_ASAN -eq 1 ]; then + report_test_completion "asan" +fi + +if [ $SPDK_RUN_UBSAN -eq 1 ]; then + report_test_completion "ubsan" +fi + +echo $scanbuild + +timing_enter "$make_timing_label" +fail=0 +./configure $config_params +time $scanbuild $MAKE $MAKEFLAGS || fail=1 +if [ $fail -eq 1 ]; then + if [ -d $out/scan-build-tmp ]; then + scanoutput=$(ls -1 $out/scan-build-tmp/) + mv $out/scan-build-tmp/$scanoutput $out/scan-build + rm -rf $out/scan-build-tmp + chmod -R a+rX $out/scan-build + fi + exit 1 +else + rm -rf $out/scan-build-tmp +fi +timing_exit "$make_timing_label" + +# Check for generated files that are not listed in .gitignore +timing_enter generated_files_check +if [ `git status --porcelain --ignore-submodules | wc -l` -ne 0 ]; then + echo "Generated files missing from .gitignore:" + git status --porcelain + exit 1 +fi +timing_exit generated_files_check + +# Check that header file dependencies are working correctly by +# capturing a binary's stat data before and after touching a +# header file and re-making. +timing_enter dependency_check +STAT1=`stat examples/nvme/identify/identify` +sleep 1 +touch lib/nvme/nvme_internal.h +$MAKE $MAKEFLAGS +STAT2=`stat examples/nvme/identify/identify` + +if [ "$STAT1" == "$STAT2" ]; then + echo "Header dependency check failed" + exit 1 +fi +timing_exit dependency_check + +# Test 'make install' +timing_enter make_install +rm -rf /tmp/spdk +mkdir /tmp/spdk +$MAKE $MAKEFLAGS install DESTDIR=/tmp/spdk prefix=/usr +ls -lR /tmp/spdk +rm -rf /tmp/spdk +timing_exit make_install + +timing_enter doxygen +if [ $SPDK_BUILD_DOC -eq 1 ] && hash doxygen; then + $MAKE -C "$rootdir"/doc --no-print-directory $MAKEFLAGS &> "$out"/doxygen.log + if [ -s "$out"/doxygen.log ]; then + cat "$out"/doxygen.log + echo "Doxygen errors found!" + exit 1 + fi + if hash pdflatex 2>/dev/null; then + $MAKE -C "$rootdir"/doc/output/latex --no-print-directory $MAKEFLAGS &>> "$out"/doxygen.log + fi + mkdir -p "$out"/doc + mv "$rootdir"/doc/output/html "$out"/doc + if [ -f "$rootdir"/doc/output/latex/refman.pdf ]; then + mv "$rootdir"/doc/output/latex/refman.pdf "$out"/doc/spdk.pdf + fi + $MAKE -C "$rootdir"/doc --no-print-directory $MAKEFLAGS clean &>> "$out"/doxygen.log + if [ -s "$out"/doxygen.log ]; then + rm "$out"/doxygen.log + fi + rm -rf "$rootdir"/doc/output +fi +timing_exit doxygen + +timing_exit autobuild |