strtolfp.c revision 1.3 1 1.2 christos /* $NetBSD: strtolfp.c,v 1.3 2024/08/18 20:47:27 christos Exp $ */
2 1.2 christos
3 1.1 christos #include "config.h"
4 1.1 christos
5 1.1 christos #include "ntp_stdlib.h"
6 1.1 christos #include "ntp_calendar.h"
7 1.1 christos
8 1.1 christos #include "unity.h"
9 1.1 christos #include "lfptest.h"
10 1.1 christos
11 1.1 christos /* This file tests both atolfp and mstolfp */
12 1.1 christos
13 1.2 christos void setUp(void);
14 1.2 christos void test_PositiveInteger(void);
15 1.2 christos void test_NegativeInteger(void);
16 1.2 christos void test_PositiveFraction(void);
17 1.2 christos void test_NegativeFraction(void);
18 1.2 christos void test_PositiveMsFraction(void);
19 1.2 christos void test_NegativeMsFraction(void);
20 1.2 christos void test_InvalidChars(void);
21 1.2 christos
22 1.2 christos
23 1.2 christos void
24 1.2 christos setUp(void)
25 1.2 christos {
26 1.2 christos init_lib();
27 1.2 christos
28 1.2 christos return;
29 1.2 christos }
30 1.2 christos
31 1.3 christos static const char* fmtLFP(const l_fp *e, const l_fp *a)
32 1.3 christos {
33 1.3 christos static char buf[100];
34 1.3 christos snprintf(buf, sizeof(buf), "e=$%08x.%08x, a=$%08x.%08x",
35 1.3 christos e->l_ui, e->l_uf, a->l_ui, a->l_uf);
36 1.3 christos return buf;
37 1.3 christos }
38 1.2 christos
39 1.1 christos void test_PositiveInteger(void) {
40 1.1 christos const char *str = "500";
41 1.1 christos const char *str_ms = "500000";
42 1.1 christos
43 1.2 christos l_fp expected = {{500},0};
44 1.1 christos l_fp actual, actual_ms;
45 1.1 christos
46 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
47 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
48 1.1 christos
49 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual), fmtLFP(&expected, &actual));
50 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual_ms), fmtLFP(&expected, &actual_ms));
51 1.1 christos }
52 1.1 christos
53 1.1 christos void test_NegativeInteger(void) {
54 1.1 christos const char *str = "-300";
55 1.1 christos const char *str_ms = "-300000";
56 1.1 christos
57 1.1 christos l_fp expected;
58 1.1 christos expected.l_i = -300;
59 1.1 christos expected.l_uf = 0;
60 1.1 christos
61 1.1 christos l_fp actual, actual_ms;
62 1.1 christos
63 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
64 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
65 1.1 christos
66 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual), fmtLFP(&expected, &actual));
67 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual_ms), fmtLFP(&expected, &actual_ms));
68 1.1 christos }
69 1.1 christos
70 1.1 christos void test_PositiveFraction(void) {
71 1.1 christos const char *str = "+500.5";
72 1.1 christos const char *str_ms = "500500.0";
73 1.1 christos
74 1.2 christos l_fp expected = {{500}, HALF};
75 1.1 christos l_fp actual, actual_ms;
76 1.1 christos
77 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
78 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
79 1.1 christos
80 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual), fmtLFP(&expected, &actual));
81 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual_ms), fmtLFP(&expected, &actual_ms));
82 1.1 christos }
83 1.1 christos
84 1.1 christos void test_NegativeFraction(void) {
85 1.1 christos const char *str = "-300.75";
86 1.1 christos const char *str_ms = "-300750";
87 1.1 christos
88 1.1 christos l_fp expected;
89 1.1 christos expected.l_i = -301;
90 1.1 christos expected.l_uf = QUARTER;
91 1.1 christos
92 1.1 christos l_fp actual, actual_ms;
93 1.1 christos
94 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
95 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
96 1.1 christos
97 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual), fmtLFP(&expected, &actual));
98 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual_ms), fmtLFP(&expected, &actual_ms));
99 1.1 christos }
100 1.1 christos
101 1.1 christos void test_PositiveMsFraction(void) {
102 1.1 christos const char *str = "300.00025";
103 1.1 christos const char *str_ms = "300000.25";
104 1.1 christos
105 1.2 christos l_fp expected = {{300}, QUARTER_PROMILLE_APPRX};
106 1.1 christos l_fp actual, actual_ms;
107 1.1 christos
108 1.1 christos
109 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
110 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
111 1.1 christos
112 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual), fmtLFP(&expected, &actual));
113 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual_ms), fmtLFP(&expected, &actual_ms));
114 1.1 christos }
115 1.1 christos
116 1.1 christos void test_NegativeMsFraction(void) {
117 1.1 christos const char *str = "-199.99975";
118 1.1 christos const char *str_ms = "-199999.75";
119 1.1 christos
120 1.1 christos l_fp expected;
121 1.1 christos expected.l_i = -200;
122 1.1 christos expected.l_uf = QUARTER_PROMILLE_APPRX;
123 1.1 christos
124 1.1 christos l_fp actual, actual_ms;
125 1.1 christos
126 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
127 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
128 1.1 christos
129 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual), fmtLFP(&expected, &actual));
130 1.3 christos TEST_ASSERT_TRUE_MESSAGE(IsEqual(expected, actual_ms), fmtLFP(&expected, &actual_ms));
131 1.1 christos }
132 1.1 christos
133 1.1 christos void test_InvalidChars(void) {
134 1.1 christos const char *str = "500.4a2";
135 1.1 christos l_fp actual, actual_ms;
136 1.1 christos
137 1.1 christos TEST_ASSERT_FALSE(atolfp(str, &actual));
138 1.1 christos TEST_ASSERT_FALSE(mstolfp(str, &actual_ms));
139 1.1 christos }
140 1.1 christos
141