diff --git a/libraries/AP_GPS/AP_GPS_NMEA.h b/libraries/AP_GPS/AP_GPS_NMEA.h
index 663a5de4aa..5ddcdcd650 100644
--- a/libraries/AP_GPS/AP_GPS_NMEA.h
+++ b/libraries/AP_GPS/AP_GPS_NMEA.h
@@ -51,6 +51,8 @@
///
class AP_GPS_NMEA : public AP_GPS_Backend
{
+ friend class AP_GPS_NMEA_Test;
+
public:
AP_GPS_NMEA(AP_GPS &_gps, AP_GPS::GPS_State &_state, AP_HAL::UARTDriver *_port);
diff --git a/libraries/AP_GPS/tests/test_gps.cpp b/libraries/AP_GPS/tests/test_gps.cpp
new file mode 100644
index 0000000000..e5b33dc0e3
--- /dev/null
+++ b/libraries/AP_GPS/tests/test_gps.cpp
@@ -0,0 +1,66 @@
+/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
+/*
+ * Copyright (C) 2016 Intel Corporation. All rights reserved.
+ *
+ * This file is free software: you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This file is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+ * See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program. If not, see .
+ */
+#include
+
+#include
+
+const AP_HAL::HAL &hal = AP_HAL::get_HAL();
+
+class AP_GPS_NMEA_Test
+{
+public:
+ int32_t parse_decimal_100(const char *p) const
+ {
+ return AP_GPS_NMEA::_parse_decimal_100(p);
+ }
+};
+
+TEST(AP_GPS_NMEA, parse_decimal_100)
+{
+ AP_GPS_NMEA_Test test;
+
+ /* Positive numbers with possible round/truncate */
+ ASSERT_EQ(100, test.parse_decimal_100("1.0"));
+ ASSERT_EQ(100, test.parse_decimal_100("1.00"));
+ ASSERT_EQ(100, test.parse_decimal_100("1.001"));
+ ASSERT_EQ(101, test.parse_decimal_100("1.006"));
+
+ /* Positive numbers with possible round/truncate with + signal */
+ ASSERT_EQ(100, test.parse_decimal_100("+1.0"));
+ ASSERT_EQ(100, test.parse_decimal_100("+1.00"));
+ ASSERT_EQ(100, test.parse_decimal_100("+1.001"));
+ ASSERT_EQ(101, test.parse_decimal_100("+1.006"));
+
+ /* Positive numbers in (0, 1) range, with possible round/truncate */
+ ASSERT_EQ(0, test.parse_decimal_100("0.0"));
+ ASSERT_EQ(0, test.parse_decimal_100("0.00"));
+ ASSERT_EQ(0, test.parse_decimal_100("0.001"));
+ ASSERT_EQ(1, test.parse_decimal_100("0.006"));
+
+ /* Negative numbers with possible round/truncate */
+ ASSERT_EQ(-100, test.parse_decimal_100("-1.0"));
+ ASSERT_EQ(-100, test.parse_decimal_100("-1.00"));
+ ASSERT_EQ(-100, test.parse_decimal_100("-1.001"));
+ ASSERT_EQ(-101, test.parse_decimal_100("-1.006"));
+
+ /* Integer numbers */
+ ASSERT_EQ(100, test.parse_decimal_100("1"));
+ ASSERT_EQ(-100, test.parse_decimal_100("-1"));
+}
+
+AP_GTEST_MAIN()
diff --git a/libraries/AP_GPS/tests/wscript b/libraries/AP_GPS/tests/wscript
new file mode 100644
index 0000000000..cd3e5e3ce7
--- /dev/null
+++ b/libraries/AP_GPS/tests/wscript
@@ -0,0 +1,7 @@
+#!/usr/bin/env python
+# encoding: utf-8
+
+def build(bld):
+ bld.ap_find_tests(
+ use='ap',
+ )