You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
OS Version: Ubuntu 24.04
rviz version: ros2 jazzy
Compiler name and version number: Ubuntu clang version 18.1.3
Source or binary build?
source build
build options: --mixin asan-gcc
Description:
In the SelectionHandler::registerHandle() function, when context_ is nullptr, the function does not perform a null pointer check, which leads to a segmentation fault when dereferencing the null pointer. This issue affects the stability of the program, as it fails to provide proper error handling when an invalid pointer is passed.
Running main() from gmock_main.cc
[==========] Running 1 test from 1 test suite.
[----------] Global test environment set-up.
[----------] 1 test from SelectionHandlerFixture
[ RUN ] SelectionHandlerFixture.createSelectionHandler_prevents_memory_leak_on_exception
[rviz_rendering:debug] Available Renderers(1): OpenGL Rendering Subsystem, at /home/shangzh/ros2_jazzy/src/ros2/rviz/rviz_rendering/src/rviz_rendering/render_system.cpp:289
[rviz_rendering:info] Stereo is NOT SUPPORTED, at /home/shangzh/ros2_jazzy/src/ros2/rviz/rviz_rendering/src/rviz_rendering/render_system.cpp:531
[rviz_rendering:info] OpenGl version: 4.3 (GLSL 4.3), at /home/shangzh/ros2_jazzy/src/ros2/rviz/rviz_rendering/src/rviz_rendering/render_system.cpp:272
AddressSanitizer:DEADLYSIGNAL=================================================================
==419319==ERROR: AddressSanitizer: SEGV on unknown address 0x000000000000 (pc 0x708bb87785ab bp 0x7fff520540a0 sp 0x7fff52053fc0 T0)
==419319==The signal is caused by a READ memory access.
==419319==Hint: address points to the zero page.
#0 0x708bb87785ab in rviz_common::interaction::SelectionHandler::registerHandle() (/home/shangzh/ros2_jazzy/install/rviz_common/lib/librviz_common.so+0x7785ab) (BuildId: 39789ab887abf563a7a1d60c39fc9c650a624184)
#1 0x5c9daa048a4a in std::shared_ptr<rviz_common::interaction::SelectionHandler> rviz_common::interaction::createSelectionHandler<rviz_common::interaction::SelectionHandler, decltype(nullptr)>(decltype(nullptr)) (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x139a4a) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#2 0x5c9daa04072c in SelectionHandlerFixture_createSelectionHandler_prevents_memory_leak_on_exception_Test::TestBody() (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x13172c) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#3 0x5c9daa17d3db in void testing::internal::HandleSehExceptionsInMethodIfSupported<testing::Test, void>(testing::Test*, void (testing::Test::*)(), char const*) (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x26e3db) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#4 0x5c9daa16a745 in void testing::internal::HandleExceptionsInMethodIfSupported<testing::Test, void>(testing::Test*, void (testing::Test::*)(), char const*) (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x25b745) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#5 0x5c9daa110d1b in testing::Test::Run() (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x201d1b) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#6 0x5c9daa1124f7 in testing::TestInfo::Run() (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x2034f7) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#7 0x5c9daa113850 in testing::TestSuite::Run() (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x204850) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#8 0x5c9daa13a57b in testing::internal::UnitTestImpl::RunAllTests() (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x22b57b) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#9 0x5c9daa180836 in bool testing::internal::HandleSehExceptionsInMethodIfSupported<testing::internal::UnitTestImpl, bool>(testing::internal::UnitTestImpl*, bool (testing::internal::UnitTestImpl::*)(), char const*) (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x271836) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#10 0x5c9daa16d9e2 in bool testing::internal::HandleExceptionsInMethodIfSupported<testing::internal::UnitTestImpl, bool>(testing::internal::UnitTestImpl*, bool (testing::internal::UnitTestImpl::*)(), char const*) (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x25e9e2) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#11 0x5c9daa136b85 in testing::UnitTest::Run() (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x227b85) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#12 0x5c9daa0e1027 in RUN_ALL_TESTS() (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x1d2027) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#13 0x5c9daa0e0f73 in main (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x1d1f73) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
#14 0x708bb322a1c9 in __libc_start_call_main ../sysdeps/nptl/libc_start_call_main.h:58
#15 0x708bb322a28a in __libc_start_main_impl ../csu/libc-start.c:360
#16 0x5c9daa0404b4 in _start (/home/shangzh/ros2_jazzy/build/rviz_common/selection_handler_test+0x1314b4) (BuildId: c0fa7f8e4a8615e6ffce9d9137547b4543050c33)
AddressSanitizer can not provide additional info.
SUMMARY: AddressSanitizer: SEGV (/home/shangzh/ros2_jazzy/install/rviz_common/lib/librviz_common.so+0x7785ab) (BuildId: 39789ab887abf563a7a1d60c39fc9c650a624184) in rviz_common::interaction::SelectionHandler::registerHandle()
==419319==ABORTING
Expected behavior
When context_ is nullptr, the function should throw a std::invalid_argument exception or another appropriate error to notify the caller that an invalid pointer has been passed.
The function should perform a validity check on the pointer to ensure it is valid before dereferencing, preventing access to invalid memory and ensuring the program runs smoothly.
Actual behavior
Without a null pointer check, if context_ is nullptr, SelectionHandler::registerHandle() attempts to access context_->getHandlerManager(), causing a segmentation fault when dereferencing the null pointer.
The expected exception cannot be caught during testing, and the program crashes directly, causing the test to fail.
Additional information
The text was updated successfully, but these errors were encountered:
Operating System:
Linux shangzh-VMware-Virtual-Platform 6.11.0-19-generic #19~24.04.1-Ubuntu SMP PREEMPT_DYNAMIC Mon Feb 17 11:51:52 UTC 2 x86_64 x86_64 x86_64 GNU/Linux
ROS version or commit hash:
ros2 jazzy
RMW implementation (if applicable):
No response
RMW Configuration (if applicable):
No response
Client library (if applicable):
rviz
'ros2 doctor --report' output
ros2 doc --report
Steps to reproduce issue
Environment
OS Version: Ubuntu 24.04
rviz version: ros2 jazzy
Compiler name and version number: Ubuntu clang version 18.1.3
Source or binary build?
source build
build options: --mixin asan-gcc
Description:
In the SelectionHandler::registerHandle() function, when context_ is nullptr, the function does not perform a null pointer check, which leads to a segmentation fault when dereferencing the null pointer. This issue affects the stability of the program, as it fails to provide proper error handling when an invalid pointer is passed.
Test Case
Output
Expected behavior
When context_ is nullptr, the function should throw a std::invalid_argument exception or another appropriate error to notify the caller that an invalid pointer has been passed.
The function should perform a validity check on the pointer to ensure it is valid before dereferencing, preventing access to invalid memory and ensuring the program runs smoothly.
Actual behavior
Without a null pointer check, if context_ is nullptr, SelectionHandler::registerHandle() attempts to access context_->getHandlerManager(), causing a segmentation fault when dereferencing the null pointer.
The expected exception cannot be caught during testing, and the program crashes directly, causing the test to fail.
Additional information
The text was updated successfully, but these errors were encountered: