1 #include <gtest/gtest.h>
2 #include <marnav/nmea/pgrme.hpp>
3 #include <marnav/nmea/nmea.hpp>
4 #include "type_traits_helper.hpp"
9 using namespace marnav
;
11 class Test_nmea_pgrme
: public ::testing::Test
15 TEST_F(Test_nmea_pgrme
, contruction
)
20 TEST_F(Test_nmea_pgrme
, properties
)
22 nmea_sentence_traits
<nmea::pgrme
>();
25 TEST_F(Test_nmea_pgrme
, parse
)
27 auto s
= nmea::make_sentence("$PGRME,1.1,M,2.2,M,3.3,M*2E");
28 ASSERT_NE(nullptr, s
);
30 auto pgrme
= nmea::sentence_cast
<nmea::pgrme
>(s
);
31 ASSERT_NE(nullptr, pgrme
);
34 TEST_F(Test_nmea_pgrme
, parse_invalid_number_of_arguments
)
37 nmea::detail::factory::sentence_parse
<nmea::pgrme
>(nmea::talker::none
, {5, "@"}));
39 nmea::detail::factory::sentence_parse
<nmea::pgrme
>(nmea::talker::none
, {7, "@"}));
42 TEST_F(Test_nmea_pgrme
, empty_to_string
)
46 EXPECT_STREQ("$PGRME,,M,,M,,M*00", nmea::to_string(pgrme
).c_str());
49 TEST_F(Test_nmea_pgrme
, set_horizontal_position_error
)
52 pgrme
.set_horizontal_position_error(units::meters
{1.1});
54 EXPECT_STREQ("$PGRME,1.1,M,,M,,M*2E", nmea::to_string(pgrme
).c_str());
57 TEST_F(Test_nmea_pgrme
, set_vertical_position_error
)
60 pgrme
.set_vertical_position_error(units::meters
{2.2});
62 EXPECT_STREQ("$PGRME,,M,2.2,M,,M*2E", nmea::to_string(pgrme
).c_str());
65 TEST_F(Test_nmea_pgrme
, set_overall_spherical_equiv_position_error
)
68 pgrme
.set_overall_spherical_equiv_position_error(units::meters
{3.3});
70 EXPECT_STREQ("$PGRME,,M,,M,3.3,M*2E", nmea::to_string(pgrme
).c_str());