mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-05-31 10:26:52 +08:00
setting parameters at runtime to get rid of the designated union initializer
This commit is contained in:
committed by
Lorenz Meier
parent
4ece1f92ca
commit
28e943ca28
@@ -61,7 +61,7 @@ add_executable(mixer_test mixer_test.cpp hrt.cpp
|
|||||||
${PX_SRC}/modules/systemlib/mixer/mixer_simple.cpp
|
${PX_SRC}/modules/systemlib/mixer/mixer_simple.cpp
|
||||||
${PX_SRC}/modules/systemlib/pwm_limit/pwm_limit.c
|
${PX_SRC}/modules/systemlib/pwm_limit/pwm_limit.c
|
||||||
${PX_SRC}/systemcmds/tests/test_mixer.cpp)
|
${PX_SRC}/systemcmds/tests/test_mixer.cpp)
|
||||||
#add_gtest(mixer_test)
|
add_gtest(mixer_test)
|
||||||
|
|
||||||
# conversion_test
|
# conversion_test
|
||||||
add_executable(conversion_test conversion_test.cpp ${PX_SRC}/systemcmds/tests/test_conv.cpp)
|
add_executable(conversion_test conversion_test.cpp ${PX_SRC}/systemcmds/tests/test_conv.cpp)
|
||||||
|
|||||||
+29
-14
@@ -3,30 +3,45 @@
|
|||||||
|
|
||||||
#include "gtest/gtest.h"
|
#include "gtest/gtest.h"
|
||||||
|
|
||||||
static const struct param_info_s test_1 = {
|
|
||||||
"TEST_1",
|
|
||||||
PARAM_TYPE_INT32,
|
|
||||||
.val.i = 2
|
|
||||||
};
|
|
||||||
|
|
||||||
struct param_info_s param_array[256];
|
struct param_info_s param_array[256];
|
||||||
struct param_info_s *param_info_base;
|
struct param_info_s *param_info_base;
|
||||||
struct param_info_s *param_info_limit;
|
struct param_info_s *param_info_limit;
|
||||||
|
|
||||||
TEST(ParamTest, ResetAll) {
|
/*
|
||||||
|
* Adds test parameters
|
||||||
|
*/
|
||||||
|
void _add_parameters() {
|
||||||
|
struct param_info_s test_1 = {
|
||||||
|
"TEST_1",
|
||||||
|
PARAM_TYPE_INT32
|
||||||
|
};
|
||||||
|
test_1.val.i = 2;
|
||||||
|
|
||||||
|
struct param_info_s test_2 = {
|
||||||
|
"TEST_2",
|
||||||
|
PARAM_TYPE_INT32
|
||||||
|
};
|
||||||
|
test_2.val.i = 4;
|
||||||
|
|
||||||
param_array[0] = test_1;
|
param_array[0] = test_1;
|
||||||
|
param_array[1] = test_2;
|
||||||
param_info_base = (struct param_info_s *) ¶m_array[0];
|
param_info_base = (struct param_info_s *) ¶m_array[0];
|
||||||
param_info_limit = (struct param_info_s *) ¶m_array[1];
|
param_info_limit = (struct param_info_s *) ¶m_array[2];
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(ParamTest, SimpleFind) {
|
||||||
|
_add_parameters();
|
||||||
|
|
||||||
printf("diff: %i\n", (unsigned)(param_info_limit - param_info_base));
|
printf("diff: %i\n", (unsigned)(param_info_limit - param_info_base));
|
||||||
|
|
||||||
param_t test_1 = param_find("TEST_1");
|
param_t param = param_find("TEST_2");
|
||||||
ASSERT_NE(PARAM_INVALID, test_1) << "param_find failed";
|
ASSERT_NE(PARAM_INVALID, param) << "param_find did not find parameter";
|
||||||
|
|
||||||
int32_t value;
|
int32_t value;
|
||||||
int result = param_get(test_1, &value);
|
int result = param_get(param, &value);
|
||||||
ASSERT_EQ(0, result) << "param_get failed";
|
ASSERT_EQ(0, result) << "param_get did not return parameter";
|
||||||
ASSERT_EQ(2, value) << "wrong param value";
|
ASSERT_EQ(4, value) << "value of returned parameter does not match";
|
||||||
|
|
||||||
//ASSERT_TRUE(false) << "fail";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user