1 #include <gtest/gtest.h>
2 #include <marnav/nmea/rma.hpp>
3 #include <marnav/nmea/nmea.hpp>
4 #include "type_traits_helper.hpp"
9 using namespace marnav
;
11 class Test_nmea_rma
: public ::testing::Test
15 TEST_F(Test_nmea_rma
, contruction
)
17 EXPECT_NO_THROW(nmea::rma rma
);
20 TEST_F(Test_nmea_rma
, properties
)
22 nmea_sentence_traits
<nmea::rma
>();
25 TEST_F(Test_nmea_rma
, parse
)
27 auto s
= nmea::make_sentence("$GPRMA,,,,,,,,,,,*65");
28 ASSERT_NE(nullptr, s
);
30 auto rma
= nmea::sentence_cast
<nmea::rma
>(s
);
31 ASSERT_NE(nullptr, rma
);
34 TEST_F(Test_nmea_rma
, parse_invalid_number_of_arguments
)
37 nmea::detail::factory::sentence_parse
<nmea::rma
>(nmea::talker::none
, {10, "@"}));
39 nmea::detail::factory::sentence_parse
<nmea::rma
>(nmea::talker::none
, {12, "@"}));
42 TEST_F(Test_nmea_rma
, empty_to_string
)
46 EXPECT_STREQ("$GPRMA,,,,,,,,,,,*65", nmea::to_string(rma
).c_str());
49 TEST_F(Test_nmea_rma
, set_lat_north
)
52 rma
.set_lat(geo::latitude
{12, 34, 56, geo::latitude::hemisphere::north
});
54 EXPECT_STREQ("$GPRMA,,1234.9333,N,,,,,,,,*0B", nmea::to_string(rma
).c_str());
57 TEST_F(Test_nmea_rma
, set_lat_south
)
60 rma
.set_lat(geo::latitude
{12, 34, 56, geo::latitude::hemisphere::south
});
62 EXPECT_STREQ("$GPRMA,,1234.9333,S,,,,,,,,*16", nmea::to_string(rma
).c_str());
65 TEST_F(Test_nmea_rma
, set_lon_east
)
68 rma
.set_lon(geo::longitude
{123, 45, 56, geo::longitude::hemisphere::east
});
70 EXPECT_STREQ("$GPRMA,,,,12345.9333,E,,,,,,*35", nmea::to_string(rma
).c_str());
73 TEST_F(Test_nmea_rma
, set_lon_west
)
76 rma
.set_lon(geo::longitude
{123, 45, 56, geo::longitude::hemisphere::west
});
78 EXPECT_STREQ("$GPRMA,,,,12345.9333,W,,,,,,*27", nmea::to_string(rma
).c_str());