1 #include <gtest/gtest.h>
2 #include <marnav/nmea/mwd.hpp>
3 #include <marnav/nmea/nmea.hpp>
4 #include "type_traits_helper.hpp"
9 using namespace marnav
;
11 class Test_nmea_mwd
: public ::testing::Test
15 TEST_F(Test_nmea_mwd
, contruction
)
17 EXPECT_NO_THROW(nmea::mwd mwd
);
20 TEST_F(Test_nmea_mwd
, properties
)
22 nmea_sentence_traits
<nmea::mwd
>();
25 TEST_F(Test_nmea_mwd
, parse
)
27 auto s
= nmea::make_sentence("$WIMWD,12.4,T,,,,,,*0D");
28 ASSERT_NE(nullptr, s
);
30 auto mwd
= nmea::sentence_cast
<nmea::mwd
>(s
);
31 ASSERT_NE(nullptr, mwd
);
34 TEST_F(Test_nmea_mwd
, parse_invalid_number_of_arguments
)
37 nmea::detail::factory::sentence_parse
<nmea::mwd
>(nmea::talker::none
, {1, "@"}));
39 nmea::detail::factory::sentence_parse
<nmea::mwd
>(nmea::talker::none
, {3, "@"}));
42 TEST_F(Test_nmea_mwd
, empty_to_string
)
46 EXPECT_STREQ("$WIMWD,,,,,,,,*40", nmea::to_string(mwd
).c_str());
49 TEST_F(Test_nmea_mwd
, set_direction_true
)
52 mwd
.set_direction_true(12.3);
54 EXPECT_STREQ("$WIMWD,12.3,T,,,,,,*0A", nmea::to_string(mwd
).c_str());
57 TEST_F(Test_nmea_mwd
, set_direction_mag
)
60 mwd
.set_direction_mag(12.3);
62 EXPECT_STREQ("$WIMWD,,,12.3,M,,,,*13", nmea::to_string(mwd
).c_str());
65 TEST_F(Test_nmea_mwd
, set_speed_knot
)
68 mwd
.set_speed_knots(marnav::units::knots
{12.3});
70 EXPECT_STREQ("$WIMWD,,,,,12.3,N,,*10", nmea::to_string(mwd
).c_str());
73 TEST_F(Test_nmea_mwd
, set_speed_mps
)
76 mwd
.set_speed_mps(marnav::units::meters_per_second
{12.3});
78 EXPECT_STREQ("$WIMWD,,,,,,,12.3,M*13", nmea::to_string(mwd
).c_str());