mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-06-01 19:07:45 +08:00
test(windows-shim): silence MSVC Debug CRT invalid-parameter handler
Several Windows shim unit tests intentionally exercise bad-fd / bad-handle paths (fcntl(0, 0xBAD), flock(-1, ...), _open() on a closed fd, etc.). On MSVC's Debug CRT those calls trigger the invalid-parameter handler, which by default raises Watson and terminates the process before gtest can record the EXPECT_* result; the test binary then exits with a non-zero status without ever reaching the [ PASSED ] line. Add a static-init silencer (test_main_silence.cpp) that installs a no-op _set_invalid_parameter_handler and disables the _CrtSetReportMode dialogs for assertions, errors, and warnings. The hook runs before main() and is linked into every shim unit test target via the EXTRA_SRCS argument to px4_add_unit_gtest() in the test CMakeLists.txt. Same CMakeLists.txt change adds an explicit link to ws2_32 for the headers-only test target: the inline fcntl() in the shim routes O_NONBLOCK changes through ioctlsocket(), so the symbol must be resolvable at link time even when the test does not call fcntl() itself. Signed-off-by: Nuno Marques <n.marques21@hotmail.com>
This commit is contained in:
@@ -43,11 +43,24 @@ if(NOT BUILD_TESTING)
|
|||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# Shared static-init hook that silences the MSVC Debug CRT invalid
|
||||||
|
# parameter handler so tests that exercise bad-fd / bad-handle paths do
|
||||||
|
# not abort with a debug-time assertion dialog. Linked into every
|
||||||
|
# Windows shim test target as an EXTRA_SRC.
|
||||||
|
set(_px4_windows_shim_silencer
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/test_main_silence.cpp
|
||||||
|
)
|
||||||
|
|
||||||
# Headers-only tests (libgen, dirent, sched, syslog, mman, time, unistd,
|
# Headers-only tests (libgen, dirent, sched, syslog, mman, time, unistd,
|
||||||
# getopt, fcntl). The translation unit pulls the shim headers via the
|
# getopt, fcntl). The translation unit pulls the shim headers via the
|
||||||
# existing windows_shim include path; no extra link libraries are
|
# existing windows_shim include path; the inline fcntl() routes
|
||||||
# required beyond gtest itself.
|
# O_NONBLOCK changes through ioctlsocket() so we need ws2_32 to satisfy
|
||||||
px4_add_unit_gtest(SRC test_windows_shim_headers.cpp)
|
# the symbol even on the headers-only target.
|
||||||
|
px4_add_unit_gtest(
|
||||||
|
SRC test_windows_shim_headers.cpp
|
||||||
|
EXTRA_SRCS ${_px4_windows_shim_silencer}
|
||||||
|
LINKLIBS ws2_32
|
||||||
|
)
|
||||||
|
|
||||||
# Source-defined shim tests (errno_map, env, sysconf, mman, flock, dlfcn,
|
# Source-defined shim tests (errno_map, env, sysconf, mman, flock, dlfcn,
|
||||||
# ids, if_query, resolver, socket loopback). Pulls in the standalone
|
# ids, if_query, resolver, socket loopback). Pulls in the standalone
|
||||||
@@ -69,7 +82,7 @@ set(_px4_windows_shim_test_srcs
|
|||||||
|
|
||||||
px4_add_unit_gtest(
|
px4_add_unit_gtest(
|
||||||
SRC test_windows_shim_runtime.cpp
|
SRC test_windows_shim_runtime.cpp
|
||||||
EXTRA_SRCS ${_px4_windows_shim_test_srcs}
|
EXTRA_SRCS ${_px4_windows_shim_test_srcs} ${_px4_windows_shim_silencer}
|
||||||
INCLUDES
|
INCLUDES
|
||||||
${PX4_SOURCE_DIR}/platforms/posix/include/windows_shim
|
${PX4_SOURCE_DIR}/platforms/posix/include/windows_shim
|
||||||
${_px4_windows_shim_root}/include
|
${_px4_windows_shim_root}/include
|
||||||
@@ -79,6 +92,7 @@ px4_add_unit_gtest(
|
|||||||
# poll() inline implementation - header-only test.
|
# poll() inline implementation - header-only test.
|
||||||
px4_add_unit_gtest(
|
px4_add_unit_gtest(
|
||||||
SRC test_windows_shim_poll.cpp
|
SRC test_windows_shim_poll.cpp
|
||||||
|
EXTRA_SRCS ${_px4_windows_shim_silencer}
|
||||||
INCLUDES
|
INCLUDES
|
||||||
${PX4_SOURCE_DIR}/platforms/posix/include/windows_shim
|
${PX4_SOURCE_DIR}/platforms/posix/include/windows_shim
|
||||||
LINKLIBS ws2_32
|
LINKLIBS ws2_32
|
||||||
@@ -88,6 +102,7 @@ px4_add_unit_gtest(
|
|||||||
# POSIX names route to MSVC CRT primitives via inline shim wrappers.
|
# POSIX names route to MSVC CRT primitives via inline shim wrappers.
|
||||||
px4_add_unit_gtest(
|
px4_add_unit_gtest(
|
||||||
SRC test_windows_shim_io.cpp
|
SRC test_windows_shim_io.cpp
|
||||||
|
EXTRA_SRCS ${_px4_windows_shim_silencer}
|
||||||
INCLUDES
|
INCLUDES
|
||||||
${PX4_SOURCE_DIR}/platforms/posix/include/windows_shim
|
${PX4_SOURCE_DIR}/platforms/posix/include/windows_shim
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -0,0 +1,67 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright (C) 2026 PX4 Development Team. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in
|
||||||
|
* the documentation and/or other materials provided with the
|
||||||
|
* distribution.
|
||||||
|
* 3. Neither the name PX4 nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||||
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||||
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||||
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||||
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||||
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @file test_main_silence.cpp
|
||||||
|
*
|
||||||
|
* Suppress the MSVC Debug CRT invalid-parameter handler so unit tests that
|
||||||
|
* intentionally exercise bad-fd / bad-handle paths (e.g. fcntl(0, 0xBAD),
|
||||||
|
* flock(-1, ...), _open on a closed fd) do not abort with a debug-time
|
||||||
|
* assertion dialog. Without this hook the Debug CRT raises Watson and
|
||||||
|
* terminates the process before gtest can record the EXPECT_* result.
|
||||||
|
*
|
||||||
|
* Linked into every shim unit test target via
|
||||||
|
* platforms/posix/src/px4/windows/tests/CMakeLists.txt; takes effect at
|
||||||
|
* static-init time before main() runs gtest.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <crtdbg.h>
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
static void silent_invalid_param(const wchar_t *, const wchar_t *, const wchar_t *,
|
||||||
|
unsigned, uintptr_t) {}
|
||||||
|
struct InstallSilencer {
|
||||||
|
InstallSilencer()
|
||||||
|
{
|
||||||
|
_set_invalid_parameter_handler(silent_invalid_param);
|
||||||
|
_CrtSetReportMode(_CRT_ASSERT, 0);
|
||||||
|
_CrtSetReportMode(_CRT_ERROR, 0);
|
||||||
|
_CrtSetReportMode(_CRT_WARN, 0);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
static InstallSilencer kInstallSilencer;
|
||||||
|
} // namespace
|
||||||
|
#endif
|
||||||
Reference in New Issue
Block a user