#removed test-libntp
check_PROGRAMS = test-modetoa test-uglydate test-ymd2yd test-statestr test-numtoa test-numtohost \
-test-hextoint test-atoint test-atouint test-authkeys test-a_md5encrypt test-lfpfunc
+test-hextoint test-atoint test-atouint test-authkeys test-a_md5encrypt test-lfpfunc test-vi64ops
if GTEST_AVAILABLE
check_PROGRAMS += tests
tstotv.cpp \
tvtots.cpp \
g_uglydate.cpp \
- vi64ops.cpp \
+ g_vi64ops.cpp \
g_ymd2yd.cpp \
$(NULL)
$(unity_tests_LDADD) \
$(NULL)
+test_lfpfunc_CFLAGS = \
+ -I$(top_srcdir)/sntp/unity \
+ -DUNITY_INCLUDE_DOUBLE \
+ $(NULL)
+
+test_lfpfunc_LDADD = \
+ $(unity_tests_LDADD) \
+ $(NULL)
+test_vi64ops_CFLAGS = \
+ -I$(top_srcdir)/sntp/unity \
+ $(NULL)
+
+test_vi64ops_LDADD = \
+ $(unity_tests_LDADD) \
+ $(NULL)
#removed one combined test, because unity devs suggested we use one program per test
run-test-lfpfunc.c \
$(NULL)
+test_vi64ops_SOURCES = \
+ vi64ops.c \
+ run-test-vi64ops.c \
+ $(NULL)
$(srcdir)/run-test-modetoa.c: $(srcdir)/modetoa.c $(std_unity_list)
$(srcdir)/run-test-lfpfunc.c: $(srcdir)/lfpfunc.c $(std_unity_list)
$(run_unity) lfpfunc.c run-test-lfpfunc.c
+$(srcdir)/run-test-vi64ops.c: $(srcdir)/vi64ops.c $(std_unity_list)
+ $(run_unity) vi64ops.c run-test-vi64ops.c
TESTS =
--- /dev/null
+#include "config.h"
+
+#include "ntp_stdlib.h"
+//#include "ntp_calendar.h"
+
+#include "vint64ops.h"
+#include "unity.h"
+
+//technically bool
+//int IsEqual(const vint64 &expected, const vint64 &actual) {
+int IsEqual(const vint64 expected, const vint64 actual) {
+ if (0 == memcmp(&expected, &actual, sizeof(vint64))) {
+ printf( "%x.", expected.D_s.hi); //<< std::hex << expected.D_s.hi << '.'
+ printf("%x",expected.D_s.lo);//<< std::hex << expected.D_s.lo
+ printf(" but was ");
+ printf("%x.",actual.D_s.hi); //<< std::hex << actual.D_s.hi << '.'
+ printf("%x\n",actual.D_s.lo); //<< std::hex << actual.D_s.lo;
+ return TRUE;
+ } else {
+
+ printf("expected: ");
+ printf( "%d.", expected.D_s.hi); //<< std::hex << expected.D_s.hi << '.'
+ printf("%d",expected.D_s.lo);//<< std::hex << expected.D_s.lo
+ printf(" but was ");
+ printf("%d",actual.D_s.lo); //<< std::hex << actual.D_s.hi << '.'
+ printf("%d",actual.D_s.lo); //<< std::hex << actual.D_s.lo;
+ return FALSE;
+ }
+}
+
+// ----------------------------------------------------------------------
+// test number parser
+void test_ParseVUI64_pos() {
+ vint64 act, exp;
+ const char *sp;
+ char *ep;
+
+ sp = "1234x";
+ exp.D_s.hi = 0;
+ exp.D_s.lo = 1234;
+ act = strtouv64(sp, &ep, 0);
+
+ TEST_ASSERT_TRUE(IsEqual(exp, act));
+ TEST_ASSERT_EQUAL(*ep, 'x');
+}
+
+void test_ParseVUI64_neg() {
+ vint64 act, exp;
+ const char *sp;
+ char *ep;
+
+ sp = "-1234x";
+ exp.D_s.hi = ~0;
+ exp.D_s.lo = -1234;
+ act = strtouv64(sp, &ep, 0);
+ TEST_ASSERT_TRUE(IsEqual(exp, act));
+ TEST_ASSERT_EQUAL(*ep, 'x');
+}
+
+void test_ParseVUI64_case() {
+ vint64 act, exp;
+ const char *sp;
+ char *ep;
+
+ sp = "0123456789AbCdEf";
+ exp.D_s.hi = 0x01234567;
+ exp.D_s.lo = 0x89ABCDEF;
+ act = strtouv64(sp, &ep, 16);
+ TEST_ASSERT_TRUE(IsEqual(exp, act));
+ TEST_ASSERT_EQUAL(*ep, '\0');
+}
+