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