1 #include <gtest/gtest.h>
2 #include <marnav/nmea/bod.hpp>
3 #include <marnav/nmea/nmea.hpp>
4 #include "type_traits_helper.hpp"
9 using namespace marnav
;
11 class Test_nmea_bod
: public ::testing::Test
15 TEST_F(Test_nmea_bod
, contruction
)
17 EXPECT_NO_THROW(nmea::bod bod
);
20 TEST_F(Test_nmea_bod
, properties
)
22 nmea_sentence_traits
<nmea::bod
>();
25 TEST_F(Test_nmea_bod
, parse
)
27 auto s
= nmea::make_sentence("$GPBOD,,T,,M,,*47");
28 ASSERT_NE(nullptr, s
);
30 auto bod
= nmea::sentence_cast
<nmea::bod
>(s
);
31 ASSERT_NE(nullptr, bod
);
34 TEST_F(Test_nmea_bod
, create_sentence
)
36 const auto s
= nmea::create_sentence
<nmea::bod
>("$GPBOD,,T,,M,,*47");
37 EXPECT_EQ(nmea::sentence_id::BOD
, s
.id());
40 TEST_F(Test_nmea_bod
, create_sentence_exception
)
42 EXPECT_ANY_THROW(nmea::create_sentence
<nmea::bod
>(""));
43 EXPECT_ANY_THROW(nmea::create_sentence
<nmea::bod
>("$IIMWV,084.0,R,10.4,N,A*04"));
46 TEST_F(Test_nmea_bod
, parse_invalid_number_of_arguments
)
49 nmea::detail::factory::sentence_parse
<nmea::bod
>(nmea::talker::none
, {5, "@"}));
51 nmea::detail::factory::sentence_parse
<nmea::bod
>(nmea::talker::none
, {7, "@"}));
54 TEST_F(Test_nmea_bod
, empty_to_string
)
58 EXPECT_STREQ("$GPBOD,,,,,,*5E", nmea::to_string(bod
).c_str());
61 TEST_F(Test_nmea_bod
, set_bearing_true
)
64 bod
.set_bearing_true(12.5);
66 EXPECT_STREQ("$GPBOD,12.5,T,,,,*12", nmea::to_string(bod
).c_str());
69 TEST_F(Test_nmea_bod
, set_bearing_magn
)
72 bod
.set_bearing_magn(10.2);
74 EXPECT_STREQ("$GPBOD,,,10.2,M,,*0E", nmea::to_string(bod
).c_str());
77 TEST_F(Test_nmea_bod
, set_waypoint_to
)
80 bod
.set_waypoint_to(nmea::waypoint
{"wpt-to"});
82 EXPECT_STREQ("$GPBOD,,,,,wpt-to,*1B", nmea::to_string(bod
).c_str());
85 TEST_F(Test_nmea_bod
, set_waypoint_from
)
88 bod
.set_waypoint_from(nmea::waypoint
{"wpt-from"});
90 EXPECT_STREQ("$GPBOD,,,,,,wpt-from*16", nmea::to_string(bod
).c_str());