forked from unicode-org/icu
-
Notifications
You must be signed in to change notification settings - Fork 0
/
cposxtst.c
111 lines (92 loc) · 3.41 KB
/
cposxtst.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// © 2016 and later: Unicode, Inc. and others.
// License & terms of use: http://www.unicode.org/copyright.html
/*
**********************************************************************
* Copyright (c) 2003-2009, International Business Machines
* Corporation and others. All Rights Reserved.
**********************************************************************
* Author: Alan Liu
* Created: March 20 2003
* Since: ICU 2.6
**********************************************************************
*/
#include "cintltst.h"
#include "cmemory.h"
#include "cstring.h"
#include "unicode/ucat.h"
#include "unicode/ustring.h"
/**********************************************************************/
/* Prototypes */
void TestMessageCatalog(void);
/**********************************************************************/
/* Add our tests into the hierarchy */
void addPosixTest(TestNode** root);
void addPosixTest(TestNode** root)
{
#if !UCONFIG_NO_FILE_IO && !UCONFIG_NO_LEGACY_CONVERSION
addTest(root, &TestMessageCatalog, "tsutil/cposxtst/TestMessageCatalog");
#endif
}
/**********************************************************************/
/* Test basic ucat.h API */
void TestMessageCatalog(void) {
UErrorCode ec = U_ZERO_ERROR;
u_nl_catd catd;
const char* DATA[] = {
/* set_num, msg_num, expected string result, expected error code */
"1", "4", "Good morning.", "U_ZERO_ERROR",
"1", "5", "Good afternoon.", "U_ZERO_ERROR",
"1", "6", "FAIL", "U_MISSING_RESOURCE_ERROR",
"1", "7", "Good evening.", "U_ZERO_ERROR",
"1", "8", "Good night.", "U_ZERO_ERROR",
"1", "9", "FAIL", "U_MISSING_RESOURCE_ERROR",
"3", "1", "FAIL", "U_MISSING_RESOURCE_ERROR",
"4", "14", "Please ", "U_ZERO_ERROR",
"4", "15", "FAIL", "U_MISSING_RESOURCE_ERROR",
"4", "19", "Thank you.", "U_ZERO_ERROR",
"4", "20", "Sincerely,", "U_ZERO_ERROR",
NULL
};
const UChar FAIL[] = {0x46, 0x41, 0x49, 0x4C, 0x00}; /* "FAIL" */
int32_t i;
const char *path = loadTestData(&ec);
if (U_FAILURE(ec)) {
log_data_err("FAIL: loadTestData => %s\n", u_errorName(ec));
return;
}
catd = u_catopen(path, "mc", &ec);
if (U_FAILURE(ec)) {
log_data_err("FAIL: u_catopen => %s\n", u_errorName(ec));
return;
}
for (i=0; DATA[i]!=NULL; i+=4) {
int32_t set_num = T_CString_stringToInteger(DATA[i], 10);
int32_t msg_num = T_CString_stringToInteger(DATA[i+1], 10);
UChar exp[128];
int32_t len = -1;
const char* err;
char str[128];
const UChar* ustr;
u_uastrcpy(exp, DATA[i+2]);
ec = U_ZERO_ERROR;
ustr = u_catgets(catd, set_num, msg_num, FAIL, &len, &ec);
u_austrcpy(str, ustr);
err = u_errorName(ec);
log_verbose("u_catgets(%d, %d) => \"%s\", len=%d, %s\n",
set_num, msg_num, str, len, err);
if (u_strcmp(ustr, exp) != 0) {
log_err("FAIL: u_catgets => \"%s\", exp. \"%s\"\n",
str, DATA[i+2]);
}
if (len != (int32_t) uprv_strlen(DATA[i+2])) {
log_err("FAIL: u_catgets => len=%d, exp. %d\n",
len, uprv_strlen(DATA[i+2]));
}
if (uprv_strcmp(err, DATA[i+3]) != 0) {
log_err("FAIL: u_catgets => %s, exp. %s\n",
err, DATA[i+3]);
}
}
u_catclose(catd);
}
/*eof*/