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