strtolfp.c revision 1.2 1 1.2 christos /* $NetBSD: strtolfp.c,v 1.2 2020/05/25 20:47:36 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.2 christos
32 1.1 christos void test_PositiveInteger(void) {
33 1.1 christos const char *str = "500";
34 1.1 christos const char *str_ms = "500000";
35 1.1 christos
36 1.2 christos l_fp expected = {{500},0};
37 1.1 christos l_fp actual, actual_ms;
38 1.1 christos
39 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
40 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
41 1.1 christos
42 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
43 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
44 1.1 christos }
45 1.1 christos
46 1.1 christos void test_NegativeInteger(void) {
47 1.1 christos const char *str = "-300";
48 1.1 christos const char *str_ms = "-300000";
49 1.1 christos
50 1.1 christos l_fp expected;
51 1.1 christos expected.l_i = -300;
52 1.1 christos expected.l_uf = 0;
53 1.1 christos
54 1.1 christos l_fp actual, actual_ms;
55 1.1 christos
56 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
57 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
58 1.1 christos
59 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
60 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
61 1.1 christos }
62 1.1 christos
63 1.1 christos void test_PositiveFraction(void) {
64 1.1 christos const char *str = "+500.5";
65 1.1 christos const char *str_ms = "500500.0";
66 1.1 christos
67 1.2 christos l_fp expected = {{500}, HALF};
68 1.1 christos l_fp actual, actual_ms;
69 1.1 christos
70 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
71 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
72 1.1 christos
73 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
74 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
75 1.1 christos }
76 1.1 christos
77 1.1 christos void test_NegativeFraction(void) {
78 1.1 christos const char *str = "-300.75";
79 1.1 christos const char *str_ms = "-300750";
80 1.1 christos
81 1.1 christos l_fp expected;
82 1.1 christos expected.l_i = -301;
83 1.1 christos expected.l_uf = QUARTER;
84 1.1 christos
85 1.1 christos l_fp actual, actual_ms;
86 1.1 christos
87 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
88 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
89 1.1 christos
90 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
91 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
92 1.1 christos }
93 1.1 christos
94 1.1 christos void test_PositiveMsFraction(void) {
95 1.1 christos const char *str = "300.00025";
96 1.1 christos const char *str_ms = "300000.25";
97 1.1 christos
98 1.2 christos l_fp expected = {{300}, QUARTER_PROMILLE_APPRX};
99 1.1 christos l_fp actual, actual_ms;
100 1.1 christos
101 1.1 christos
102 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
103 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
104 1.1 christos
105 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
106 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
107 1.1 christos
108 1.1 christos }
109 1.1 christos
110 1.1 christos void test_NegativeMsFraction(void) {
111 1.1 christos const char *str = "-199.99975";
112 1.1 christos const char *str_ms = "-199999.75";
113 1.1 christos
114 1.1 christos l_fp expected;
115 1.1 christos expected.l_i = -200;
116 1.1 christos expected.l_uf = QUARTER_PROMILLE_APPRX;
117 1.1 christos
118 1.1 christos l_fp actual, actual_ms;
119 1.1 christos
120 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
121 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
122 1.1 christos
123 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
124 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
125 1.1 christos
126 1.1 christos }
127 1.1 christos
128 1.1 christos void test_InvalidChars(void) {
129 1.1 christos const char *str = "500.4a2";
130 1.1 christos l_fp actual, actual_ms;
131 1.1 christos
132 1.1 christos TEST_ASSERT_FALSE(atolfp(str, &actual));
133 1.1 christos TEST_ASSERT_FALSE(mstolfp(str, &actual_ms));
134 1.1 christos }
135 1.1 christos
136