Add tests
This commit is contained in:
parent
237e137ce2
commit
0288722985
8 changed files with 154 additions and 4 deletions
|
@ -87,8 +87,15 @@ else()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(BUILD_TESTING)
|
if(BUILD_TESTING)
|
||||||
|
find_package(ament_cmake_gtest REQUIRED)
|
||||||
find_package(ament_lint_auto REQUIRED)
|
find_package(ament_lint_auto REQUIRED)
|
||||||
ament_lint_auto_find_test_dependencies()
|
ament_lint_auto_find_test_dependencies()
|
||||||
|
|
||||||
|
ament_add_gtest(test_utils test/test_utils.cpp)
|
||||||
|
if(TARGET test_utils)
|
||||||
|
target_link_libraries(test_utils ${PROJECT_NAME} -rdynamic)
|
||||||
|
target_include_directories(test_utils PRIVATE test/)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
ament_package()
|
ament_package()
|
||||||
|
|
|
@ -189,11 +189,13 @@ TRACEPOINT_EVENT(
|
||||||
rclcpp_callback_register,
|
rclcpp_callback_register,
|
||||||
TP_ARGS(
|
TP_ARGS(
|
||||||
const void *, callback_arg,
|
const void *, callback_arg,
|
||||||
const char *, symbol_arg
|
const char *, symbol_arg,
|
||||||
|
const void *, address_arg
|
||||||
),
|
),
|
||||||
TP_FIELDS(
|
TP_FIELDS(
|
||||||
ctf_integer_hex(const void *, callback, callback_arg)
|
ctf_integer_hex(const void *, callback, callback_arg)
|
||||||
ctf_string(symbol, symbol_arg)
|
ctf_string(symbol, symbol_arg)
|
||||||
|
ctf_integer_hex(const void *, address, address_arg)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -129,7 +129,8 @@ void TRACEPOINT(
|
||||||
void TRACEPOINT(
|
void TRACEPOINT(
|
||||||
rclcpp_callback_register,
|
rclcpp_callback_register,
|
||||||
const void * callback,
|
const void * callback,
|
||||||
const char * function_symbol);
|
const char * function_symbol,
|
||||||
|
const void * address);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* tp: callback_start
|
* tp: callback_start
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
|
|
||||||
<depend>liblttng-ust-dev</depend>
|
<depend>liblttng-ust-dev</depend>
|
||||||
|
|
||||||
|
<test_depend>ament_cmake_gtest</test_depend>
|
||||||
<test_depend>ament_lint_auto</test_depend>
|
<test_depend>ament_lint_auto</test_depend>
|
||||||
<test_depend>ament_lint_common</test_depend>
|
<test_depend>ament_lint_common</test_depend>
|
||||||
|
|
||||||
|
|
|
@ -182,13 +182,15 @@ void TRACEPOINT(
|
||||||
void TRACEPOINT(
|
void TRACEPOINT(
|
||||||
rclcpp_callback_register,
|
rclcpp_callback_register,
|
||||||
const void * callback,
|
const void * callback,
|
||||||
const char * function_symbol)
|
const char * function_symbol,
|
||||||
|
const void * address)
|
||||||
{
|
{
|
||||||
CONDITIONAL_TP(
|
CONDITIONAL_TP(
|
||||||
ros2,
|
ros2,
|
||||||
rclcpp_callback_register,
|
rclcpp_callback_register,
|
||||||
callback,
|
callback,
|
||||||
function_symbol);
|
function_symbol,
|
||||||
|
address);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TRACEPOINT(
|
void TRACEPOINT(
|
||||||
|
|
|
@ -12,6 +12,8 @@
|
||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
#if defined(TRACETOOLS_LTTNG_ENABLED) && !defined(_WIN32)
|
#if defined(TRACETOOLS_LTTNG_ENABLED) && !defined(_WIN32)
|
||||||
#include <dlfcn.h>
|
#include <dlfcn.h>
|
||||||
#include <cxxabi.h>
|
#include <cxxabi.h>
|
||||||
|
@ -24,11 +26,13 @@ const char * get_symbol(void * funptr)
|
||||||
#if defined(TRACETOOLS_LTTNG_ENABLED) && !defined(_WIN32)
|
#if defined(TRACETOOLS_LTTNG_ENABLED) && !defined(_WIN32)
|
||||||
#define SYMBOL_LAMBDA "[lambda]"
|
#define SYMBOL_LAMBDA "[lambda]"
|
||||||
if (funptr == 0) {
|
if (funptr == 0) {
|
||||||
|
std::cout << "lamba!" << std::endl;
|
||||||
return SYMBOL_LAMBDA;
|
return SYMBOL_LAMBDA;
|
||||||
}
|
}
|
||||||
|
|
||||||
Dl_info info;
|
Dl_info info;
|
||||||
if (dladdr(funptr, &info) == 0) {
|
if (dladdr(funptr, &info) == 0) {
|
||||||
|
std::cout << "unknown!" << std::endl;
|
||||||
return SYMBOL_UNKNOWN;
|
return SYMBOL_UNKNOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
67
tracetools/test/test_utils.cpp
Normal file
67
tracetools/test/test_utils.cpp
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
// Copyright 2019 Robert Bosch GmbH
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
#include <functional>
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
#include "tracetools/utils.hpp"
|
||||||
|
#include "test_utils.hpp"
|
||||||
|
|
||||||
|
int function_int_int(int num)
|
||||||
|
{
|
||||||
|
return num + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
void function_generic_shared(const std::shared_ptr<int> p)
|
||||||
|
{
|
||||||
|
(void)p;
|
||||||
|
}
|
||||||
|
|
||||||
|
void function_generic_unique(const std::unique_ptr<int> p)
|
||||||
|
{
|
||||||
|
(void)p;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
Testing address and symbol resolution for std::function objects.
|
||||||
|
*/
|
||||||
|
TEST(TestUtils, valid_address_symbol) {
|
||||||
|
std::function<int(int)> f = &function_int_int;
|
||||||
|
std::function<int(int)> lambda = [](int num) {return num + 1;};
|
||||||
|
std::function<int(int)> l = lambda;
|
||||||
|
|
||||||
|
ASSERT_EQ(f(69), l(69));
|
||||||
|
|
||||||
|
// Address for an std::function with an underlying lambda should be nullptr
|
||||||
|
ASSERT_EQ(get_address(l), nullptr) << "get_address() for lambda std::function not 0";
|
||||||
|
// But address for one with an actual underlying function should be non-zero
|
||||||
|
ASSERT_GT(get_address(f), (void *)0) << "get_address() for function not valid";
|
||||||
|
|
||||||
|
ASSERT_STREQ(get_symbol(get_address(f)), "function_int_int(int)") << "invalid function name";
|
||||||
|
|
||||||
|
// Generic
|
||||||
|
std::function<void (const std::shared_ptr<int>)> fg_shared = &function_generic_shared;
|
||||||
|
SomeGenericClass<int> gc_shared;
|
||||||
|
gc_shared.set(fg_shared);
|
||||||
|
ASSERT_GT(gc_shared.get_address_(), (void *)0) << "generic -- address invalid";
|
||||||
|
ASSERT_STREQ(gc_shared.get_symbol_(), "function_generic_shared(std::shared_ptr<int>)") << "generic -- symbol invalid";
|
||||||
|
|
||||||
|
std::function<void (const std::unique_ptr<int>)> fg_unique = &function_generic_unique;
|
||||||
|
SomeGenericClass<int> gc_unique;
|
||||||
|
gc_unique.set(fg_unique);
|
||||||
|
ASSERT_GT(gc_unique.get_address_(), (void *)0) << "generic -- address invalid";
|
||||||
|
ASSERT_STREQ(gc_unique.get_symbol_(), "function_generic_unique(std::unique_ptr<int, std::default_delete<int> >)") << "generic -- symbol invalid";
|
||||||
|
}
|
66
tracetools/test/test_utils.hpp
Normal file
66
tracetools/test/test_utils.hpp
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
#include <memory>
|
||||||
|
#include <type_traits>
|
||||||
|
|
||||||
|
#include "tracetools/utils.hpp"
|
||||||
|
#include "function_traits.hpp"
|
||||||
|
|
||||||
|
|
||||||
|
template<typename ParamT>
|
||||||
|
class SomeGenericClass
|
||||||
|
{
|
||||||
|
using SharedPtrCallback = std::function<void (const std::shared_ptr<ParamT>)>;
|
||||||
|
using UniquePtrCallback = std::function<void (const std::unique_ptr<ParamT>)>;
|
||||||
|
|
||||||
|
public:
|
||||||
|
SomeGenericClass()
|
||||||
|
: my_callback_shared_(nullptr), my_callback_unique_(nullptr)
|
||||||
|
{}
|
||||||
|
|
||||||
|
template<
|
||||||
|
typename TheType,
|
||||||
|
typename std::enable_if<
|
||||||
|
rclcpp::function_traits::same_arguments<
|
||||||
|
TheType,
|
||||||
|
SharedPtrCallback
|
||||||
|
>::value
|
||||||
|
>::type * = nullptr
|
||||||
|
>
|
||||||
|
void set(TheType callback)
|
||||||
|
{
|
||||||
|
my_callback_shared_ = callback;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<
|
||||||
|
typename TheType,
|
||||||
|
typename std::enable_if<
|
||||||
|
rclcpp::function_traits::same_arguments<
|
||||||
|
TheType,
|
||||||
|
UniquePtrCallback
|
||||||
|
>::value
|
||||||
|
>::type * = nullptr
|
||||||
|
>
|
||||||
|
void set(TheType callback)
|
||||||
|
{
|
||||||
|
my_callback_unique_ = callback;
|
||||||
|
}
|
||||||
|
|
||||||
|
void * get_address_()
|
||||||
|
{
|
||||||
|
if (my_callback_shared_) {
|
||||||
|
return get_address(my_callback_shared_);
|
||||||
|
} else if (my_callback_unique_) {
|
||||||
|
return get_address(my_callback_unique_);
|
||||||
|
} else {
|
||||||
|
return (void *)0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const char * get_symbol_()
|
||||||
|
{
|
||||||
|
return get_symbol(get_address_());
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
SharedPtrCallback my_callback_shared_;
|
||||||
|
UniquePtrCallback my_callback_unique_;
|
||||||
|
};
|
Loading…
Add table
Add a link
Reference in a new issue