forked from Archive/PX4-Autopilot
gather test results
This commit is contained in:
parent
cddef87998
commit
97bc0f4486
|
@ -271,6 +271,7 @@ find_package(PythonInterp REQUIRED)
|
||||||
# cmake modules
|
# cmake modules
|
||||||
#
|
#
|
||||||
enable_testing()
|
enable_testing()
|
||||||
|
include(CTest)
|
||||||
|
|
||||||
#=============================================================================
|
#=============================================================================
|
||||||
# generate compile command database
|
# generate compile command database
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
## This file should be placed in the root directory of your project.
|
||||||
|
## Then modify the CMakeLists.txt file in the root directory of your
|
||||||
|
## project to incorporate the testing dashboard.
|
||||||
|
##
|
||||||
|
## # The following are required to submit to the CDash dashboard:
|
||||||
|
## ENABLE_TESTING()
|
||||||
|
## INCLUDE(CTest)
|
||||||
|
|
||||||
|
set(CTEST_PROJECT_NAME "PX4 Firmware")
|
||||||
|
set(CTEST_NIGHTLY_START_TIME "00:00:00 EST")
|
||||||
|
|
||||||
|
set(CTEST_DROP_METHOD "http")
|
||||||
|
set(CTEST_DROP_SITE "my.cdash.org")
|
||||||
|
set(CTEST_DROP_LOCATION "/submit.php?project=PX4+Firmware")
|
||||||
|
set(CTEST_DROP_SITE_CDASH TRUE)
|
12
Makefile
12
Makefile
|
@ -278,17 +278,17 @@ unittest: posix_sitl_default
|
||||||
$(call cmake-build,unittest,$(SRC_DIR)/unittests)
|
$(call cmake-build,unittest,$(SRC_DIR)/unittests)
|
||||||
@(cd build_unittest && ctest -j2 --output-on-failure)
|
@(cd build_unittest && ctest -j2 --output-on-failure)
|
||||||
|
|
||||||
run_tests_posix: posix_sitl_default
|
run_tests_posix:
|
||||||
@(cd build_posix_sitl_default/ && ctest --output-on-failure)
|
@$(call PX4_RUN,$(MAKE) --no-print-directory posix_sitl_default test_results_junit)
|
||||||
|
|
||||||
tests: unittest run_tests_posix
|
tests: unittest run_tests_posix
|
||||||
|
|
||||||
tests_coverage:
|
tests_coverage:
|
||||||
@(PX4_CODE_COVERAGE=1 CCACHE_DISABLE=1 ${MAKE} tests)
|
@$(call PX4_RUN,$(MAKE) --no-print-directory tests PX4_CODE_COVERAGE=1 CCACHE_DISABLE=1)
|
||||||
@(lcov --directory . --capture --quiet --output-file coverage.info)
|
@$(call PX4_RUN,lcov --directory . --capture --quiet --output-file coverage.info)
|
||||||
@(lcov --remove coverage.info '/usr/*' --quiet --output-file coverage.info)
|
@$(call PX4_RUN,lcov --remove coverage.info '/usr/*' --quiet --output-file coverage.info)
|
||||||
#@(lcov --list coverage.info)
|
#@(lcov --list coverage.info)
|
||||||
@(genhtml coverage.info --quiet --output-directory coverage-html)
|
@$(call PX4_RUN,genhtml coverage.info --quiet --output-directory coverage-html)
|
||||||
|
|
||||||
package_firmware:
|
package_firmware:
|
||||||
@zip --junk-paths Firmware.zip `find Binaries/. -name \*.px4`
|
@zip --junk-paths Firmware.zip `find Binaries/. -name \*.px4`
|
||||||
|
|
|
@ -0,0 +1,120 @@
|
||||||
|
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
|
||||||
|
<xsl:output method="xml" indent="yes"/>
|
||||||
|
<xsl:template match="/Site">
|
||||||
|
<xsl:variable name="Name"><xsl:value-of select="@Name"/></xsl:variable>
|
||||||
|
<xsl:variable name="Hostname"><xsl:value-of select="@Hostname"/></xsl:variable>
|
||||||
|
<xsl:variable name="TestCount"><xsl:value-of select="count(//TestList/Test)"/> </xsl:variable>
|
||||||
|
<xsl:variable name="ErrorCount"><xsl:value-of select="count(//TestList/Test[@Status='error'])"/> </xsl:variable>
|
||||||
|
<xsl:variable name="FailureCount"><xsl:value-of select="count(//Testing/Test[@Status='failed'])"/> </xsl:variable>
|
||||||
|
<testsuite name="{$Name}" hostname="{$Hostname}" errors="0" failures="{$FailureCount}" tests="{$TestCount}">
|
||||||
|
<xsl:variable name="BuildName"><xsl:value-of select="@BuildName"/></xsl:variable>
|
||||||
|
<xsl:variable name="BuildStamp"><xsl:value-of select="@BuildStamp"/></xsl:variable>
|
||||||
|
<xsl:variable name="Generator"><xsl:value-of select="@Generator"/></xsl:variable>
|
||||||
|
<xsl:variable name="CompilerName"><xsl:value-of select="@CompilerName"/></xsl:variable>
|
||||||
|
<xsl:variable name="OSName"><xsl:value-of select="@OSName"/></xsl:variable>
|
||||||
|
<xsl:variable name="OSRelease"><xsl:value-of select="@OSRelease"/></xsl:variable>
|
||||||
|
<xsl:variable name="OSVersion"><xsl:value-of select="@OSVersion"/></xsl:variable>
|
||||||
|
<xsl:variable name="OSPlatform"><xsl:value-of select="@OSPlatform"/></xsl:variable>
|
||||||
|
<xsl:variable name="Is64Bits"><xsl:value-of select="@Is64Bits"/></xsl:variable>
|
||||||
|
<xsl:variable name="VendorString"><xsl:value-of select="@VendorString"/></xsl:variable>
|
||||||
|
<xsl:variable name="VendorID"><xsl:value-of select="@VendorID"/></xsl:variable>
|
||||||
|
<xsl:variable name="FamilyID"><xsl:value-of select="@FamilyID"/></xsl:variable>
|
||||||
|
<xsl:variable name="ModelID"><xsl:value-of select="@ModelID"/></xsl:variable>
|
||||||
|
<xsl:variable name="ProcessorCacheSize"><xsl:value-of select="@ProcessorCacheSize"/></xsl:variable>
|
||||||
|
<xsl:variable name="NumberOfLogicalCPU"><xsl:value-of select="@NumberOfLogicalCPU"/></xsl:variable>
|
||||||
|
<xsl:variable name="NumberOfPhysicalCPU"><xsl:value-of select="@NumberOfPhysicalCPU"/></xsl:variable>
|
||||||
|
<xsl:variable name="TotalVirtualMemory"><xsl:value-of select="@TotalVirtualMemory"/></xsl:variable>
|
||||||
|
<xsl:variable name="TotalPhysicalMemory"><xsl:value-of select="@TotalPhysicalMemory"/></xsl:variable>
|
||||||
|
<xsl:variable name="LogicalProcessorsPerPhysical"><xsl:value-of select="@LogicalProcessorsPerPhysical"/></xsl:variable>
|
||||||
|
<xsl:variable name="ProcessorClockFrequency"><xsl:value-of select="@ProcessorClockFrequency"/></xsl:variable>
|
||||||
|
<properties>
|
||||||
|
<property name="BuildName" value="{$BuildName}" />
|
||||||
|
<property name="BuildStamp" value="{$BuildStamp}" />
|
||||||
|
<property name="Name" value="{$Name}" />
|
||||||
|
<property name="Generator" value="{$Generator}" />
|
||||||
|
<property name="CompilerName" value="{$CompilerName}" />
|
||||||
|
<property name="OSName" value="{$OSName}" />
|
||||||
|
<property name="Hostname" value="{$Hostname}" />
|
||||||
|
<property name="OSRelease" value="{$OSRelease}" />
|
||||||
|
<property name="OSVersion" value="{$OSVersion}" />
|
||||||
|
<property name="OSPlatform" value="{$OSPlatform}" />
|
||||||
|
<property name="Is64Bits" value="{$Is64Bits}" />
|
||||||
|
<property name="VendorString" value="{$VendorString}" />
|
||||||
|
<property name="VendorID" value="{$VendorID}" />
|
||||||
|
<property name="FamilyID" value="{$FamilyID}" />
|
||||||
|
<property name="ModelID" value="{$ModelID}" />
|
||||||
|
<property name="ProcessorCacheSize" value="{$ProcessorCacheSize}" />
|
||||||
|
<property name="NumberOfLogicalCPU" value="{$NumberOfLogicalCPU}" />
|
||||||
|
<property name="NumberOfPhysicalCPU" value="{$NumberOfPhysicalCPU}" />
|
||||||
|
<property name="TotalVirtualMemory" value="{$TotalVirtualMemory}" />
|
||||||
|
<property name="TotalPhysicalMemory" value="{$TotalPhysicalMemory}" />
|
||||||
|
<property name="LogicalProcessorsPerPhysical" value="{$LogicalProcessorsPerPhysical}" />
|
||||||
|
<property name="ProcessorClockFrequency" value="{$ProcessorClockFrequency}" />
|
||||||
|
</properties>
|
||||||
|
<xsl:apply-templates select="Testing/Test"/>
|
||||||
|
|
||||||
|
<system-out>
|
||||||
|
BuildName: <xsl:value-of select="$BuildName" />
|
||||||
|
BuildStamp: <xsl:value-of select="$BuildStamp" />
|
||||||
|
Name: <xsl:value-of select="$Name" />
|
||||||
|
Generator: <xsl:value-of select="$Generator" />
|
||||||
|
CompilerName: <xsl:value-of select="$CompilerName" />
|
||||||
|
OSName: <xsl:value-of select="$OSName" />
|
||||||
|
Hostname: <xsl:value-of select="$Hostname" />
|
||||||
|
OSRelease: <xsl:value-of select="$OSRelease" />
|
||||||
|
OSVersion: <xsl:value-of select="$OSVersion" />
|
||||||
|
OSPlatform: <xsl:value-of select="$OSPlatform" />
|
||||||
|
Is64Bits: <xsl:value-of select="$Is64Bits" />
|
||||||
|
VendorString: <xsl:value-of select="$VendorString" />
|
||||||
|
VendorID: <xsl:value-of select="$VendorID" />
|
||||||
|
FamilyID: <xsl:value-of select="$FamilyID" />
|
||||||
|
ModelID: <xsl:value-of select="$ModelID" />
|
||||||
|
ProcessorCacheSize: <xsl:value-of select="$ProcessorCacheSize" />
|
||||||
|
NumberOfLogicalCPU: <xsl:value-of select="$NumberOfLogicalCPU" />
|
||||||
|
NumberOfPhysicalCPU: <xsl:value-of select="$NumberOfPhysicalCPU" />
|
||||||
|
TotalVirtualMemory: <xsl:value-of select="$TotalVirtualMemory" />
|
||||||
|
TotalPhysicalMemory: <xsl:value-of select="$TotalPhysicalMemory" />
|
||||||
|
LogicalProcessorsPerPhysical: <xsl:value-of select="$LogicalProcessorsPerPhysical" />
|
||||||
|
ProcessorClockFrequency: <xsl:value-of select="$ProcessorClockFrequency" />
|
||||||
|
</system-out>
|
||||||
|
</testsuite>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="Testing/Test">
|
||||||
|
<xsl:variable name="testcasename"><xsl:value-of select= "Name"/></xsl:variable>
|
||||||
|
<xsl:variable name="testclassname"><xsl:value-of select= " concat('this', substring(Path,2))"/></xsl:variable>
|
||||||
|
<xsl:variable name="exectime">
|
||||||
|
<xsl:for-each select="Results/NamedMeasurement">
|
||||||
|
<xsl:if test="@name = 'Execution Time'">
|
||||||
|
<xsl:value-of select="."/>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:for-each>
|
||||||
|
</xsl:variable>
|
||||||
|
|
||||||
|
<testcase name="{$testcasename}" classname="{$testclassname}" time="{$exectime}">
|
||||||
|
<xsl:if test="@Status = 'passed'">
|
||||||
|
</xsl:if>
|
||||||
|
<xsl:if test="@Status = 'failed'">
|
||||||
|
<xsl:variable name="failtype">
|
||||||
|
<xsl:for-each select="Results/NamedMeasurement">
|
||||||
|
<xsl:if test="@name = 'Exit Code'">
|
||||||
|
<xsl:value-of select="."/>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:for-each>
|
||||||
|
</xsl:variable>
|
||||||
|
<xsl:variable name="failcode">
|
||||||
|
<xsl:for-each select="Results/NamedMeasurement">
|
||||||
|
<xsl:if test="@name = 'Exit Value'">
|
||||||
|
<xsl:value-of select="."/>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:for-each>
|
||||||
|
</xsl:variable>
|
||||||
|
<failure message="{$failtype} ({$failcode})"><xsl:value-of select="Results/Measurement/Value/text()" /></failure>
|
||||||
|
</xsl:if>
|
||||||
|
<xsl:if test="@Status = 'notrun'">
|
||||||
|
<skipped><xsl:value-of select="Results/Measurement/Value/text()" /></skipped>
|
||||||
|
</xsl:if>
|
||||||
|
</testcase>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
</xsl:stylesheet>
|
14
circle.yml
14
circle.yml
|
@ -12,15 +12,19 @@ checkout:
|
||||||
|
|
||||||
dependencies:
|
dependencies:
|
||||||
pre:
|
pre:
|
||||||
- docker pull px4io/px4-dev-nuttx:2016-12-26
|
- docker pull px4io/px4-dev-base
|
||||||
|
|
||||||
test:
|
test:
|
||||||
override:
|
override:
|
||||||
- docker run --rm -v `pwd`:`pwd`:rw -e CI=true -w=`pwd` -e LOCAL_USER_ID=$UID -it px4io/px4-dev-nuttx:2016-12-26 /bin/bash -c "make quick_check"
|
- PX4_DOCKER=1 make tests
|
||||||
|
# copy test results for circleci
|
||||||
|
- mkdir -p $CIRCLE_TEST_REPORTS/unittests/ && cp build_unittest/test_detail.xml $CIRCLE_TEST_REPORTS/unittests/
|
||||||
|
- mkdir -p $CIRCLE_TEST_REPORTS/sitlunittests/ && cp ./build_posix_sitl_default/JUnitTestResults.xml $CIRCLE_TEST_REPORTS/sitlunittests/
|
||||||
|
- make distclean
|
||||||
|
- PX4_DOCKER=1 make tests_coverage
|
||||||
|
|
||||||
general:
|
general:
|
||||||
artifacts:
|
artifacts:
|
||||||
- "build_px4fmu-v2_default/parameters.xml"
|
- "coverage-html"
|
||||||
- "build_px4fmu-v2_default/airframes.xml"
|
- "coverage.info"
|
||||||
- "build_.*/src/firmware/nuttx/.*.px4"
|
|
||||||
|
|
||||||
|
|
|
@ -187,4 +187,22 @@ foreach(test_name ${test_src_files})
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
|
add_custom_target(test_results
|
||||||
|
COMMAND ${CMAKE_CTEST_COMMAND} --output-on-failure -T Test
|
||||||
|
DEPENDS px4
|
||||||
|
USES_TERMINAL
|
||||||
|
COMMENT "Running tests in sitl"
|
||||||
|
WORKING_DIRECTORY ${PX4_BINARY_DIR})
|
||||||
|
|
||||||
|
add_custom_target(test_results_junit
|
||||||
|
COMMAND xsltproc ${PX4_SOURCE_DIR}/Tools/CTest2JUnit.xsl Testing/`head -n 1 < Testing/TAG`/Test.xml > JUnitTestResults.xml
|
||||||
|
DEPENDS test_results
|
||||||
|
COMMENT "Converting ctest output to junit xml"
|
||||||
|
WORKING_DIRECTORY ${PX4_BINARY_DIR})
|
||||||
|
|
||||||
|
add_custom_target(test_cdash_submit
|
||||||
|
COMMAND ${CMAKE_CTEST_COMMAND} -D Experimental
|
||||||
|
USES_TERMINAL
|
||||||
|
WORKING_DIRECTORY ${PX4_BINARY_DIR})
|
||||||
|
|
||||||
# vim: set noet ft=cmake fenc=utf-8 ff=unix :
|
# vim: set noet ft=cmake fenc=utf-8 ff=unix :
|
||||||
|
|
|
@ -10,6 +10,8 @@ endif()
|
||||||
project(px4_unittests)
|
project(px4_unittests)
|
||||||
enable_testing()
|
enable_testing()
|
||||||
|
|
||||||
|
message(STATUS ${CONFIG})
|
||||||
|
|
||||||
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -Werror -std=gnu99 -g")
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -Werror -std=gnu99 -g")
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Werror -std=gnu++0x -g -fno-exceptions -fno-rtti -fno-threadsafe-statics -DCONFIG_WCHAR_BUILTIN -D__CUSTOM_FILE_IO__")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Werror -std=gnu++0x -g -fno-exceptions -fno-rtti -fno-threadsafe-statics -DCONFIG_WCHAR_BUILTIN -D__CUSTOM_FILE_IO__")
|
||||||
|
|
||||||
|
@ -90,7 +92,7 @@ function(add_gtest)
|
||||||
else()
|
else()
|
||||||
target_link_libraries(${test_name} gtest_main pthread rt ${PX4_PLATFORM})
|
target_link_libraries(${test_name} gtest_main pthread rt ${PX4_PLATFORM})
|
||||||
endif()
|
endif()
|
||||||
add_test(NAME ${test_name} COMMAND ${test_name} WORKING_DIRECTORY ${PX4_SOURCE_DIR})
|
add_test(NAME ${test_name} COMMAND ${test_name} --gtest_output=xml WORKING_DIRECTORY ${PX4_BINARY_DIR})
|
||||||
add_dependencies(check ${test_name})
|
add_dependencies(check ${test_name})
|
||||||
endforeach()
|
endforeach()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
Loading…
Reference in New Issue