e01a369f0281cb84c6e22cc6ac07096bc97a91fc
2 * Japanese Calendar Testcase
4 * Copyright 2019 Katayama Hirofumi MZ
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
23 #ifndef CAL_SABBREVERASTRING
24 #define CAL_SABBREVERASTRING 0x00000039
27 START_TEST(JapaneseCalendar
)
32 DWORD langid
= MAKELANGID(LANG_JAPANESE
, SUBLANG_DEFAULT
);
33 LCID lcid
= MAKELCID(langid
, SORT_DEFAULT
);
37 static const WCHAR s_szSeireki19
[] = {0x897F, 0x66A6, '1', '9', 0}; // L"\u897F\u66A6" L"19"
38 static const WCHAR s_szHeisei
[] = {0x5E73, 0x6210, 0}; // L"\u5E73\u6210"
39 static const WCHAR s_szHeisei31
[] = {0x5E73, 0x6210, '3', '1', 0}; // L"\u5E73\u6210" L"31"
40 static const WCHAR s_szOneCharHeisei
[] = {0x5E73, 0}; // L"\u5E73"
41 static const WCHAR s_szWareki
[] = {0x548C, 0x66A6, 0}; // L"\u548C\u66A6"
42 static const WCHAR s_szNen
[] = {0x5E74, 0}; // L"\u5E74"
44 trace("lcid: 0x%08lX\n", lcid
);
45 trace("langid: 0x%04lX\n", langid
);
49 skip("Codepage is not Japanese.\n");
53 ZeroMemory(&st
, sizeof(st
));
59 /* Standard Date Formatting */
65 ret
= GetDateFormatA(lcid
, dwFlags
, &st
, "gyy", szTextA
, ARRAYSIZE(szTextA
));
66 ok(ret
!= 0, "ret: %d\n", ret
);
67 ok(/* WinXP */ lstrcmpiA(szTextA
, "19") == 0 ||
68 /* Win10 */ lstrcmpiA(szTextA
, "\x90\xBC\x97\xEF" "19") == 0, "szTextA: %s\n", szTextA
);
72 ret
= GetDateFormatA(lcid
, dwFlags
, &st
, "ggyy", szTextA
, ARRAYSIZE(szTextA
));
73 ok(ret
!= 0, "ret: %d\n", ret
);
74 ok(/* WinXP */ lstrcmpiA(szTextA
, "19") == 0 ||
75 /* Win10 */ lstrcmpiA(szTextA
, "\x90\xBC\x97\xEF" "19") == 0, "szTextA: %s\n", szTextA
);
79 ret
= GetDateFormatW(lcid
, dwFlags
, &st
, L
"gyy", szTextW
, ARRAYSIZE(szTextW
));
80 ok(ret
!= 0, "ret: %d\n", ret
);
81 ok(/* WinXP */ lstrcmpiW(szTextW
, L
"19") == 0 ||
82 /* Win10 */ lstrcmpiW(szTextW
, s_szSeireki19
) == 0,
83 "szTextW: %04X %04X %04X\n", szTextW
[0], szTextW
[1], szTextW
[2]);
87 ret
= GetDateFormatW(lcid
, dwFlags
, &st
, L
"ggyy", szTextW
, ARRAYSIZE(szTextW
));
88 ok(ret
!= 0, "ret: %d\n", ret
);
89 ok(/* WinXP */ lstrcmpiW(szTextW
, L
"19") == 0 ||
90 /* Win10 */ lstrcmpiW(szTextW
, s_szSeireki19
) == 0,
91 "szTextW: %04X %04X %04X\n", szTextW
[0], szTextW
[1], szTextW
[2]);
94 /* Alternative Date Formatting (Wareki) */
96 DWORD dwFlags
= DATE_USE_ALT_CALENDAR
;
100 ret
= GetDateFormatA(lcid
, dwFlags
, &st
, "gyy", szTextA
, ARRAYSIZE(szTextA
));
101 ok(ret
!= 0, "ret: %d\n", ret
);
102 ok(lstrcmpiA(szTextA
, "\x95\xBD\x90\xAC" "31") == 0, "szTextA: %s\n", szTextA
);
106 ret
= GetDateFormatA(lcid
, dwFlags
, &st
, "ggyy", szTextA
, ARRAYSIZE(szTextA
));
107 ok(ret
!= 0, "ret: %d\n", ret
);
108 ok(lstrcmpiA(szTextA
, "\x95\xBD\x90\xAC" "31") == 0, "szTextA: %s\n", szTextA
);
112 ret
= GetDateFormatW(lcid
, dwFlags
, &st
, L
"gyy", szTextW
, ARRAYSIZE(szTextW
));
113 ok(ret
!= 0, "ret: %d\n", ret
);
114 ok(lstrcmpiW(szTextW
, s_szHeisei31
) == 0,
115 "szTextW: %04X %04X %04X\n", szTextW
[0], szTextW
[1], szTextW
[2]);
119 ret
= GetDateFormatW(lcid
, dwFlags
, &st
, L
"ggyy", szTextW
, ARRAYSIZE(szTextW
));
120 ok(ret
!= 0, "ret: %d\n", ret
);
121 ok(lstrcmpiW(szTextW
, s_szHeisei31
) == 0,
122 "szTextW: %04X %04X %04X\n", szTextW
[0], szTextW
[1], szTextW
[2]);
125 /* Japanese calendar-related locale info (MBCS) */
127 type
= CAL_ICALINTVALUE
| CAL_RETURN_NUMBER
;
128 ret
= GetCalendarInfoA(lcid
, CAL_JAPAN
, type
, NULL
, 0, &dwValue
);
129 ok(ret
!= 0, "ret: %d\n", ret
);
132 type
= CAL_ITWODIGITYEARMAX
| CAL_RETURN_NUMBER
;
133 ret
= GetCalendarInfoA(lcid
, CAL_JAPAN
, type
, NULL
, 0, &dwValue
);
134 ok(ret
!= 0, "ret: %d\n", ret
);
135 ok_long(dwValue
, 99);
137 type
= CAL_IYEAROFFSETRANGE
| CAL_RETURN_NUMBER
;
138 ret
= GetCalendarInfoA(lcid
, CAL_JAPAN
, type
, NULL
, 0, &dwValue
);
139 ok(ret
!= 0, "ret: %d\n", ret
);
140 ok(dwValue
== 1989 || dwValue
== 2019, "dwValue was %ld\n", dwValue
);
144 type
= CAL_SABBREVERASTRING
;
145 ret
= GetCalendarInfoA(lcid
, CAL_JAPAN
, type
, szTextA
, ARRAYSIZE(szTextA
), NULL
);
147 ok(lstrcmpiA(szTextA
, "\x7F") == 0, "szTextA: %s\n", szTextA
);
152 ret
= GetCalendarInfoA(lcid
, CAL_JAPAN
, type
, szTextA
, ARRAYSIZE(szTextA
), NULL
);
153 ok(ret
!= 0, "ret: %d\n", ret
);
154 ok(lstrcmpiA(szTextA
, "\x98\x61\x97\xEF") == 0, "szTextA: %s\n", szTextA
);
158 type
= CAL_SERASTRING
;
159 ret
= GetCalendarInfoA(lcid
, CAL_JAPAN
, type
, szTextA
, ARRAYSIZE(szTextA
), NULL
);
160 ok(ret
!= 0, "ret: %d\n", ret
);
161 ok(lstrcmpiA(szTextA
, "\x95\xBD\x90\xAC") == 0, "szTextA: %s\n", szTextA
);
165 type
= CAL_SLONGDATE
;
166 ret
= GetCalendarInfoA(lcid
, CAL_JAPAN
, type
, szTextA
, ARRAYSIZE(szTextA
), NULL
);
167 ok(ret
!= 0, "ret: %d\n", ret
);
168 ok(strstr(szTextA
, "\x94\x4E") != NULL
, "szTextA: %s\n", szTextA
);
172 type
= CAL_SSHORTDATE
;
173 ret
= GetCalendarInfoA(lcid
, CAL_JAPAN
, type
, szTextA
, ARRAYSIZE(szTextA
), NULL
);
174 ok(ret
!= 0, "ret: %d\n", ret
);
175 ok(strstr(szTextA
, "/") != NULL
, "szTextA: %s\n", szTextA
);
178 /* Japanese calendar-related locale info (Unicode) */
180 type
= CAL_ICALINTVALUE
| CAL_RETURN_NUMBER
;
181 ret
= GetCalendarInfoW(lcid
, CAL_JAPAN
, type
, NULL
, 0, &dwValue
);
182 ok(ret
!= 0, "ret: %d\n", ret
);
185 type
= CAL_ITWODIGITYEARMAX
| CAL_RETURN_NUMBER
;
186 ret
= GetCalendarInfoW(lcid
, CAL_JAPAN
, type
, NULL
, 0, &dwValue
);
187 ok(ret
!= 0, "ret: %d\n", ret
);
188 ok_long(dwValue
, 99);
190 type
= CAL_IYEAROFFSETRANGE
| CAL_RETURN_NUMBER
;
191 ret
= GetCalendarInfoW(lcid
, CAL_JAPAN
, type
, NULL
, 0, &dwValue
);
192 ok(ret
!= 0, "ret: %d\n", ret
);
193 ok(dwValue
== 1989 || dwValue
== 2019, "dwValue was %ld\n", dwValue
);
197 type
= CAL_SABBREVERASTRING
;
198 ret
= GetCalendarInfoW(lcid
, CAL_JAPAN
, type
, szTextW
, ARRAYSIZE(szTextW
), NULL
);
199 ok(/* WinXP */ ret
== 0 || /* Win10 */ ret
!= 0, "ret: %d\n", ret
);
200 ok(/* WinXP */ (szTextW
[0] == 0x7F && szTextW
[1] == 0) ||
201 /* Win10 */ lstrcmpiW(szTextW
, s_szOneCharHeisei
) == 0,
202 "szTextW: %04X %04X %04X\n", szTextW
[0], szTextW
[1], szTextW
[2]);
207 ret
= GetCalendarInfoW(lcid
, CAL_JAPAN
, type
, szTextW
, ARRAYSIZE(szTextW
), NULL
);
208 ok(ret
!= 0, "ret: %d\n", ret
);
209 ok(lstrcmpiW(szTextW
, s_szWareki
) == 0, "szTextW: %04X %04X %04X\n", szTextW
[0], szTextW
[1], szTextW
[2]);
213 type
= CAL_SERASTRING
;
214 ret
= GetCalendarInfoW(lcid
, CAL_JAPAN
, type
, szTextW
, ARRAYSIZE(szTextW
), NULL
);
215 ok(ret
!= 0, "ret: %d\n", ret
);
216 ok(wcsstr(szTextW
, s_szHeisei
) != NULL
, "szTextW: %04X %04X %04X\n", szTextW
[0], szTextW
[1], szTextW
[2]);
220 type
= CAL_SLONGDATE
;
221 ret
= GetCalendarInfoW(lcid
, CAL_JAPAN
, type
, szTextW
, ARRAYSIZE(szTextW
), NULL
);
222 ok(ret
!= 0, "ret: %d\n", ret
);
223 ok(wcsstr(szTextW
, s_szNen
) != NULL
, "\n");
227 type
= CAL_SSHORTDATE
;
228 ret
= GetCalendarInfoW(lcid
, CAL_JAPAN
, type
, szTextW
, ARRAYSIZE(szTextW
), NULL
);
229 ok(ret
!= 0, "ret: %d\n", ret
);
230 ok(wcsstr(szTextW
, L
"/") != NULL
, "\n");