1
2 /********************************************************************
3 * COPYRIGHT:
4 * Copyright (c) 1997-2014, International Business Machines Corporation and
5 * others. All Rights Reserved.
6 ********************************************************************/
7
8 #include "unicode/utypes.h"
9
10 #if !UCONFIG_NO_FORMATTING
11
12 #include "sdtfmtts.h"
13
14 #include "unicode/smpdtfmt.h"
15 #include "unicode/dtfmtsym.h"
16
17 // This is an API test, not a unit test. It doesn't test very many cases, and doesn't
18 // try to test the full functionality. It just calls each function in the class and
19 // verifies that it works on a basic level.
20
runIndexedTest(int32_t index,UBool exec,const char * & name,char *)21 void IntlTestSimpleDateFormatAPI::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ )
22 {
23 if (exec) logln("TestSuite SimpleDateFormatAPI");
24 switch (index) {
25 case 0: name = "SimpleDateFormat API test";
26 if (exec) {
27 logln("SimpleDateFormat API test---"); logln("");
28 UErrorCode status = U_ZERO_ERROR;
29 Locale saveLocale;
30 Locale::setDefault(Locale::getEnglish(), status);
31 if(U_FAILURE(status)) {
32 errln("ERROR: Could not set default locale, test may not give correct results");
33 }
34 testAPI(/*par*/);
35 Locale::setDefault(saveLocale, status);
36 }
37 break;
38
39 default: name = ""; break;
40 }
41 }
42
43 /**
44 * Test various generic API methods of SimpleDateFormat for API coverage.
45 */
testAPI()46 void IntlTestSimpleDateFormatAPI::testAPI(/*char *par*/)
47 {
48 UErrorCode status = U_ZERO_ERROR;
49
50 // ======= Test constructors
51
52 logln("Testing SimpleDateFormat constructors");
53
54 SimpleDateFormat def(status);
55 if(U_FAILURE(status)) {
56 dataerrln("ERROR: Could not create SimpleDateFormat (default) - exitting");
57 return;
58 }
59
60 status = U_ZERO_ERROR;
61 const UnicodeString pattern("yyyy.MM.dd G 'at' hh:mm:ss z", "");
62 const UnicodeString override("y=hebr;d=thai;s=arab", ""); /* use invariant converter */
63 const UnicodeString override_bogus("y=hebr;d=thai;s=bogus", "");
64
65 SimpleDateFormat pat(pattern, status);
66 if(U_FAILURE(status)) {
67 errln("ERROR: Could not create SimpleDateFormat (pattern) - %s", u_errorName(status));
68 }
69
70 status = U_ZERO_ERROR;
71 SimpleDateFormat pat_fr(pattern, Locale::getFrench(), status);
72 if(U_FAILURE(status)) {
73 errln("ERROR: Could not create SimpleDateFormat (pattern French)");
74 }
75
76 status = U_ZERO_ERROR;
77 DateFormatSymbols *symbols = new DateFormatSymbols(Locale::getFrench(), status);
78 if(U_FAILURE(status)) {
79 errln("ERROR: Could not create DateFormatSymbols (French)");
80 }
81
82 status = U_ZERO_ERROR;
83 SimpleDateFormat cust1(pattern, symbols, status);
84 if(U_FAILURE(status)) {
85 dataerrln("ERROR: Could not create SimpleDateFormat (pattern, symbols*) - exitting");
86 return;
87 }
88
89 status = U_ZERO_ERROR;
90 SimpleDateFormat cust2(pattern, *symbols, status);
91 if(U_FAILURE(status)) {
92 errln("ERROR: Could not create SimpleDateFormat (pattern, symbols)");
93 }
94
95 status = U_ZERO_ERROR;
96 logln(UnicodeString("Override with: ") + override);
97 SimpleDateFormat ovr1(pattern, override, status);
98 if(U_FAILURE(status)) {
99 errln("ERROR: Could not create SimpleDateFormat (pattern, override) - %s", u_errorName(status));
100 }
101
102 status = U_ZERO_ERROR;
103 SimpleDateFormat ovr2(pattern, override, Locale::getGerman(), status);
104 if(U_FAILURE(status)) {
105 errln("ERROR: Could not create SimpleDateFormat (pattern, override, locale) - %s", u_errorName(status));
106 }
107
108 status = U_ZERO_ERROR;
109 logln(UnicodeString("Override with: ") + override_bogus);
110 SimpleDateFormat ovr3(pattern, override_bogus, Locale::getGerman(), status);
111 if(U_SUCCESS(status)) {
112 errln("ERROR: Should not have been able to create SimpleDateFormat (pattern, override, locale) with a bogus override");
113 }
114
115
116 SimpleDateFormat copy(pat);
117
118 // ======= Test clone(), assignment, and equality
119
120 logln("Testing clone(), assignment and equality operators");
121
122 if( ! (copy == pat) || copy != pat) {
123 errln("ERROR: Copy constructor (or ==) failed");
124 }
125
126 copy = cust1;
127 if(copy != cust1) {
128 errln("ERROR: Assignment (or !=) failed");
129 }
130
131 Format *clone = def.clone();
132 if( ! (*clone == def) ) {
133 errln("ERROR: Clone() (or ==) failed");
134 }
135 delete clone;
136
137 // ======= Test various format() methods
138
139 logln("Testing various format() methods");
140
141 UDate d = 837039928046.0;
142 Formattable fD(d, Formattable::kIsDate);
143
144 UnicodeString res1, res2;
145 FieldPosition pos1(0), pos2(0);
146
147 res1 = def.format(d, res1, pos1);
148 logln( (UnicodeString) "" + d + " formatted to " + res1);
149
150 status = U_ZERO_ERROR;
151 res2 = cust1.format(fD, res2, pos2, status);
152 if(U_FAILURE(status)) {
153 errln("ERROR: format(Formattable [Date]) failed");
154 }
155 logln((UnicodeString) "" + fD.getDate() + " formatted to " + res2);
156
157 // ======= Test parse()
158
159 logln("Testing parse()");
160
161 UnicodeString text("02/03/76 2:50 AM, CST");
162 UDate result1, result2;
163 ParsePosition pos(0);
164 result1 = def.parse(text, pos);
165 logln(text + " parsed into " + result1);
166
167 status = U_ZERO_ERROR;
168 result2 = def.parse(text, status);
169 if(U_FAILURE(status)) {
170 errln("ERROR: parse() failed");
171 }
172 logln(text + " parsed into " + result2);
173
174 // ======= Test getters and setters
175
176 logln("Testing getters and setters");
177
178 const DateFormatSymbols *syms = pat.getDateFormatSymbols();
179 if(!syms) {
180 errln("Couldn't obtain DateFormatSymbols. Quitting test!");
181 return;
182 }
183 if(syms->getDynamicClassID() != DateFormatSymbols::getStaticClassID()) {
184 errln("ERROR: format->getDateFormatSymbols()->getDynamicClassID() != DateFormatSymbols::getStaticClassID()");
185 }
186 DateFormatSymbols *newSyms = new DateFormatSymbols(*syms);
187 def.adoptDateFormatSymbols(newSyms);
188 pat_fr.setDateFormatSymbols(*newSyms);
189 if( *(pat.getDateFormatSymbols()) != *(def.getDateFormatSymbols())) {
190 errln("ERROR: adopt or set DateFormatSymbols() failed");
191 }
192
193 status = U_ZERO_ERROR;
194 UDate startDate = pat.get2DigitYearStart(status);
195 if(U_FAILURE(status)) {
196 errln("ERROR: getTwoDigitStartDate() failed");
197 }
198
199 status = U_ZERO_ERROR;
200 pat_fr.set2DigitYearStart(startDate, status);
201 if(U_FAILURE(status)) {
202 errln("ERROR: setTwoDigitStartDate() failed");
203 }
204
205 // ======= Test DateFormatSymbols constructor
206 newSyms =new DateFormatSymbols("gregorian", status);
207 if(U_FAILURE(status)) {
208 errln("ERROR: new DateFormatSymbols() failed");
209 }
210 def.adoptDateFormatSymbols(newSyms);
211
212 // ======= Test applyPattern()
213
214 logln("Testing applyPattern()");
215
216 UnicodeString p1("yyyy.MM.dd G 'at' hh:mm:ss z");
217 logln("Applying pattern " + p1);
218 status = U_ZERO_ERROR;
219 pat.applyPattern(p1);
220
221 UnicodeString s2;
222 s2 = pat.toPattern(s2);
223 logln("Extracted pattern is " + s2);
224 if(s2 != p1) {
225 errln("ERROR: toPattern() result did not match pattern applied");
226 }
227
228 logln("Applying pattern " + p1);
229 status = U_ZERO_ERROR;
230 pat.applyLocalizedPattern(p1, status);
231 if(U_FAILURE(status)) {
232 errln("ERROR: applyPattern() failed with %s", u_errorName(status));
233 }
234 UnicodeString s3;
235 status = U_ZERO_ERROR;
236 s3 = pat.toLocalizedPattern(s3, status);
237 if(U_FAILURE(status)) {
238 errln("ERROR: toLocalizedPattern() failed");
239 }
240 logln("Extracted pattern is " + s3);
241 if(s3 != p1) {
242 errln("ERROR: toLocalizedPattern() result did not match pattern applied");
243 }
244
245 // ======= Test getStaticClassID()
246
247 logln("Testing getStaticClassID()");
248
249 status = U_ZERO_ERROR;
250 DateFormat *test = new SimpleDateFormat(status);
251 if(U_FAILURE(status)) {
252 errln("ERROR: Couldn't create a SimpleDateFormat");
253 }
254
255 if(test->getDynamicClassID() != SimpleDateFormat::getStaticClassID()) {
256 errln("ERROR: getDynamicClassID() didn't return the expected value");
257 }
258
259 delete test;
260
261 // ======= Test Ticket 5684 (Parsing with 'e' and 'Y')
262 SimpleDateFormat object(UNICODE_STRING_SIMPLE("YYYY'W'wwe"), status);
263 if(U_FAILURE(status)) {
264 errln("ERROR: Couldn't create a SimpleDateFormat");
265 }
266 object.setLenient(false);
267 ParsePosition pp(0);
268 UDate udDate = object.parse("2007W014", pp);
269 if ((double)udDate == 0.0) {
270 errln("ERROR: Parsing failed using 'Y' and 'e'");
271 }
272
273 // ====== Test ticket 11295 getNumberFormatForField returns wild pointer
274 if (object.getNumberFormatForField('B') != NULL) {
275 errln("B is not a valid field, "
276 "getNumberFormatForField should return NULL");
277 }
278 }
279
280 #endif /* #if !UCONFIG_NO_FORMATTING */
281