mirror of
https://gitlab.gnome.org/GNOME/libxml2
synced 2025-03-28 21:33:13 +00:00
add the new test in 'make check' and update it to check subdictionaries
* Makefile.am testdict.c: add the new test in 'make check' and update it to check subdictionaries processing. Daniel svn path=/trunk/; revision=3769
This commit is contained in:
parent
d68f8912c4
commit
d330f18fbc
@ -1,3 +1,8 @@
|
|||||||
|
Fri Aug 8 14:01:59 CEST 2008 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
|
* Makefile.am testdict.c: add the new test in 'make check' and
|
||||||
|
update it to check subdictionaries processing.
|
||||||
|
|
||||||
Fri Aug 8 12:07:20 CEST 2008 Daniel Veillard <daniel@veillard.com>
|
Fri Aug 8 12:07:20 CEST 2008 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
* testdict.c: added a program to regression test the dictionary code
|
* testdict.c: added a program to regression test the dictionary code
|
||||||
|
@ -9,7 +9,7 @@ INCLUDES = -I$(top_builddir)/include -I@srcdir@/include @THREAD_CFLAGS@ @Z_CFLAG
|
|||||||
noinst_PROGRAMS=testSchemas testRelax testSAX testHTML testXPath testURI \
|
noinst_PROGRAMS=testSchemas testRelax testSAX testHTML testXPath testURI \
|
||||||
testThreads testC14N testAutomata testRegexp \
|
testThreads testC14N testAutomata testRegexp \
|
||||||
testReader testapi testModule runtest runsuite testchar \
|
testReader testapi testModule runtest runsuite testchar \
|
||||||
runxmlconf
|
testdict runxmlconf
|
||||||
|
|
||||||
bin_PROGRAMS = xmllint xmlcatalog
|
bin_PROGRAMS = xmllint xmlcatalog
|
||||||
|
|
||||||
@ -61,6 +61,11 @@ testchar_LDFLAGS =
|
|||||||
testchar_DEPENDENCIES = $(DEPS)
|
testchar_DEPENDENCIES = $(DEPS)
|
||||||
testchar_LDADD= @RDL_LIBS@ $(LDADDS)
|
testchar_LDADD= @RDL_LIBS@ $(LDADDS)
|
||||||
|
|
||||||
|
testdict_SOURCES=testdict.c
|
||||||
|
testdict_LDFLAGS =
|
||||||
|
testdict_DEPENDENCIES = $(DEPS)
|
||||||
|
testdict_LDADD= @RDL_LIBS@ $(LDADDS)
|
||||||
|
|
||||||
runsuite_SOURCES=runsuite.c
|
runsuite_SOURCES=runsuite.c
|
||||||
runsuite_LDFLAGS =
|
runsuite_LDFLAGS =
|
||||||
runsuite_DEPENDENCIES = $(DEPS)
|
runsuite_DEPENDENCIES = $(DEPS)
|
||||||
@ -167,7 +172,7 @@ runxmlconf_LDADD= $(LDADDS)
|
|||||||
#testOOM_LDADD= $(LDADDS)
|
#testOOM_LDADD= $(LDADDS)
|
||||||
|
|
||||||
runtests:
|
runtests:
|
||||||
./runtest$(EXEEXT) && ./testapi$(EXEEXT) && ./runxmlconf$(EXEEXT)
|
./runtest$(EXEEXT) && ./testapi$(EXEEXT) && ./testdict$(EXEEXT) && ./runxmlconf$(EXEEXT)
|
||||||
|
|
||||||
check: all runtests
|
check: all runtests
|
||||||
|
|
||||||
|
310
testdict.c
310
testdict.c
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
/* #define WITH_PRINT */
|
/* #define WITH_PRINT */
|
||||||
|
|
||||||
static const char *seeds[] = {
|
static const char *seeds1[] = {
|
||||||
"a", "b", "c",
|
"a", "b", "c",
|
||||||
"d", "e", "f",
|
"d", "e", "f",
|
||||||
"g", "h", "i",
|
"g", "h", "i",
|
||||||
@ -13,12 +13,24 @@ static const char *seeds[] = {
|
|||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const char *seeds2[] = {
|
||||||
|
"m", "n", "o",
|
||||||
|
"p", "q", "r",
|
||||||
|
"s", "t", "u",
|
||||||
|
"v", "w", "x",
|
||||||
|
|
||||||
|
NULL
|
||||||
|
};
|
||||||
|
|
||||||
#define NB_STRINGS_NS 100
|
#define NB_STRINGS_NS 100
|
||||||
#define NB_STRINGS_MAX 10000
|
#define NB_STRINGS_MAX 10000
|
||||||
#define NB_STRINGS_MIN 10
|
#define NB_STRINGS_MIN 10
|
||||||
|
|
||||||
static xmlChar *strings[NB_STRINGS_MAX];
|
static xmlChar *strings1[NB_STRINGS_MAX];
|
||||||
|
static xmlChar *strings2[NB_STRINGS_MAX];
|
||||||
static const xmlChar *test1[NB_STRINGS_MAX];
|
static const xmlChar *test1[NB_STRINGS_MAX];
|
||||||
|
static const xmlChar *test2[NB_STRINGS_MAX];
|
||||||
|
static int nbErrors = 0;
|
||||||
|
|
||||||
static void fill_strings(void) {
|
static void fill_strings(void) {
|
||||||
int i, j, k;
|
int i, j, k;
|
||||||
@ -28,17 +40,17 @@ static void fill_strings(void) {
|
|||||||
* there is a small but sufficient number of duplicates, and we have
|
* there is a small but sufficient number of duplicates, and we have
|
||||||
* ":xxx" and full QNames in the last NB_STRINGS_NS values
|
* ":xxx" and full QNames in the last NB_STRINGS_NS values
|
||||||
*/
|
*/
|
||||||
for (i = 0; seeds[i] != NULL; i++) {
|
for (i = 0; seeds1[i] != NULL; i++) {
|
||||||
strings[i] = xmlStrdup((const xmlChar *) seeds[i]);
|
strings1[i] = xmlStrdup((const xmlChar *) seeds1[i]);
|
||||||
if (strings[i] == NULL) {
|
if (strings1[i] == NULL) {
|
||||||
fprintf(stderr, "Out of memory while generating strings\n");
|
fprintf(stderr, "Out of memory while generating strings1\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (j = 0, k = 0;i < NB_STRINGS_MAX - NB_STRINGS_NS;i++,j++) {
|
for (j = 0, k = 0;i < NB_STRINGS_MAX - NB_STRINGS_NS;i++,j++) {
|
||||||
strings[i] = xmlStrncatNew(strings[j], strings[k], -1);
|
strings1[i] = xmlStrncatNew(strings1[j], strings1[k], -1);
|
||||||
if (strings[i] == NULL) {
|
if (strings1[i] == NULL) {
|
||||||
fprintf(stderr, "Out of memory while generating strings\n");
|
fprintf(stderr, "Out of memory while generating strings1\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
if (j >= 50) {
|
if (j >= 50) {
|
||||||
@ -47,22 +59,62 @@ static void fill_strings(void) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (j = 0; (j < 50) && (i < NB_STRINGS_MAX); i++, j+=2) {
|
for (j = 0; (j < 50) && (i < NB_STRINGS_MAX); i++, j+=2) {
|
||||||
strings[i] = xmlStrncatNew(strings[j], (const xmlChar *) ":", -1);
|
strings1[i] = xmlStrncatNew(strings1[j], (const xmlChar *) ":", -1);
|
||||||
if (strings[i] == NULL) {
|
if (strings1[i] == NULL) {
|
||||||
fprintf(stderr, "Out of memory while generating strings\n");
|
fprintf(stderr, "Out of memory while generating strings1\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (j = NB_STRINGS_MAX - NB_STRINGS_NS, k = 0;
|
for (j = NB_STRINGS_MAX - NB_STRINGS_NS, k = 0;
|
||||||
i < NB_STRINGS_MAX;i++,j++) {
|
i < NB_STRINGS_MAX;i++,j++) {
|
||||||
strings[i] = xmlStrncatNew(strings[j], strings[k], -1);
|
strings1[i] = xmlStrncatNew(strings1[j], strings1[k], -1);
|
||||||
if (strings[i] == NULL) {
|
if (strings1[i] == NULL) {
|
||||||
fprintf(stderr, "Out of memory while generating strings\n");
|
fprintf(stderr, "Out of memory while generating strings1\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
k += 3;
|
k += 3;
|
||||||
if (k >= 50) k = 0;
|
if (k >= 50) k = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Now do the same with the second pool of strings
|
||||||
|
*/
|
||||||
|
for (i = 0; seeds2[i] != NULL; i++) {
|
||||||
|
strings2[i] = xmlStrdup((const xmlChar *) seeds2[i]);
|
||||||
|
if (strings2[i] == NULL) {
|
||||||
|
fprintf(stderr, "Out of memory while generating strings2\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (j = 0, k = 0;i < NB_STRINGS_MAX - NB_STRINGS_NS;i++,j++) {
|
||||||
|
strings2[i] = xmlStrncatNew(strings2[j], strings2[k], -1);
|
||||||
|
if (strings2[i] == NULL) {
|
||||||
|
fprintf(stderr, "Out of memory while generating strings2\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (j >= 50) {
|
||||||
|
j = 0;
|
||||||
|
k++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (j = 0; (j < 50) && (i < NB_STRINGS_MAX); i++, j+=2) {
|
||||||
|
strings2[i] = xmlStrncatNew(strings2[j], (const xmlChar *) ":", -1);
|
||||||
|
if (strings2[i] == NULL) {
|
||||||
|
fprintf(stderr, "Out of memory while generating strings2\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (j = NB_STRINGS_MAX - NB_STRINGS_NS, k = 0;
|
||||||
|
i < NB_STRINGS_MAX;i++,j++) {
|
||||||
|
strings2[i] = xmlStrncatNew(strings2[j], strings2[k], -1);
|
||||||
|
if (strings2[i] == NULL) {
|
||||||
|
fprintf(stderr, "Out of memory while generating strings2\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
k += 3;
|
||||||
|
if (k >= 50) k = 0;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_PRINT
|
#ifdef WITH_PRINT
|
||||||
@ -70,7 +122,10 @@ static void print_strings(void) {
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < NB_STRINGS_MAX;i++) {
|
for (i = 0; i < NB_STRINGS_MAX;i++) {
|
||||||
printf("%s\n", strings[i]);
|
printf("%s\n", strings1[i]);
|
||||||
|
}
|
||||||
|
for (i = 0; i < NB_STRINGS_MAX;i++) {
|
||||||
|
printf("%s\n", strings2[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -79,17 +134,188 @@ static void clean_strings(void) {
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < NB_STRINGS_MAX; i++) {
|
for (i = 0; i < NB_STRINGS_MAX; i++) {
|
||||||
if (strings[i] != NULL) /* really should not happen */
|
if (strings1[i] != NULL) /* really should not happen */
|
||||||
xmlFree(strings[i]);
|
xmlFree(strings1[i]);
|
||||||
|
}
|
||||||
|
for (i = 0; i < NB_STRINGS_MAX; i++) {
|
||||||
|
if (strings2[i] != NULL) /* really should not happen */
|
||||||
|
xmlFree(strings2[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This tests the sub-dictionary support
|
||||||
|
*/
|
||||||
|
static int run_test2(xmlDictPtr parent) {
|
||||||
|
int i, j;
|
||||||
|
xmlDictPtr dict;
|
||||||
|
int ret = 0;
|
||||||
|
xmlChar prefix[40];
|
||||||
|
xmlChar *cur, *pref;
|
||||||
|
const xmlChar *tmp;
|
||||||
|
|
||||||
|
dict = xmlDictCreateSub(parent);
|
||||||
|
if (dict == NULL) {
|
||||||
|
fprintf(stderr, "Out of memory while creating sub-dictionary\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
memset(test2, 0, sizeof(test2));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Fill in NB_STRINGS_MIN, at this point the dictionary should not grow
|
||||||
|
* and we allocate all those doing the fast key computations
|
||||||
|
* All the strings are based on a different seeds subset so we know
|
||||||
|
* they are allocated in the main dictionary, not coming from the parent
|
||||||
|
*/
|
||||||
|
for (i = 0;i < NB_STRINGS_MIN;i++) {
|
||||||
|
test2[i] = xmlDictLookup(dict, strings2[i], -1);
|
||||||
|
if (test2[i] == NULL) {
|
||||||
|
fprintf(stderr, "Failed lookup for '%s'\n", strings2[i]);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
j = NB_STRINGS_MAX - NB_STRINGS_NS;
|
||||||
|
/* ":foo" like strings2 */
|
||||||
|
for (i = 0;i < NB_STRINGS_MIN;i++, j++) {
|
||||||
|
test2[j] = xmlDictLookup(dict, strings2[j], xmlStrlen(strings2[j]));
|
||||||
|
if (test2[j] == NULL) {
|
||||||
|
fprintf(stderr, "Failed lookup for '%s'\n", strings2[j]);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* "a:foo" like strings2 */
|
||||||
|
j = NB_STRINGS_MAX - NB_STRINGS_MIN;
|
||||||
|
for (i = 0;i < NB_STRINGS_MIN;i++, j++) {
|
||||||
|
test2[j] = xmlDictLookup(dict, strings2[j], xmlStrlen(strings2[j]));
|
||||||
|
if (test2[j] == NULL) {
|
||||||
|
fprintf(stderr, "Failed lookup for '%s'\n", strings2[j]);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* At this point allocate all the strings
|
||||||
|
* the dictionary will grow in the process, reallocate more string tables
|
||||||
|
* and switch to the better key generator
|
||||||
|
*/
|
||||||
|
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
||||||
|
if (test2[i] != NULL)
|
||||||
|
continue;
|
||||||
|
test2[i] = xmlDictLookup(dict, strings2[i], -1);
|
||||||
|
if (test2[i] == NULL) {
|
||||||
|
fprintf(stderr, "Failed lookup for '%s'\n", strings2[i]);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Now we can start to test things, first that all strings2 belongs to
|
||||||
|
* the dict, and that none of them was actually allocated in the parent
|
||||||
|
*/
|
||||||
|
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
||||||
|
if (!xmlDictOwns(dict, test2[i])) {
|
||||||
|
fprintf(stderr, "Failed ownership failure for '%s'\n",
|
||||||
|
strings2[i]);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
if (xmlDictOwns(parent, test2[i])) {
|
||||||
|
fprintf(stderr, "Failed parent ownership failure for '%s'\n",
|
||||||
|
strings2[i]);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Also verify that all strings from the parent are seen from the subdict
|
||||||
|
*/
|
||||||
|
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
||||||
|
if (!xmlDictOwns(dict, test1[i])) {
|
||||||
|
fprintf(stderr, "Failed sub-ownership failure for '%s'\n",
|
||||||
|
strings1[i]);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Then that another lookup to the string in sub will return the same
|
||||||
|
*/
|
||||||
|
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
||||||
|
if (xmlDictLookup(dict, strings2[i], -1) != test2[i]) {
|
||||||
|
fprintf(stderr, "Failed re-lookup check for %d, '%s'\n",
|
||||||
|
i, strings2[i]);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* But also that any lookup for a string in the parent will be provided
|
||||||
|
* as in the parent
|
||||||
|
*/
|
||||||
|
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
||||||
|
if (xmlDictLookup(dict, strings1[i], -1) != test1[i]) {
|
||||||
|
fprintf(stderr, "Failed parent string lookup check for %d, '%s'\n",
|
||||||
|
i, strings1[i]);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* check the QName lookups
|
||||||
|
*/
|
||||||
|
for (i = NB_STRINGS_MAX - NB_STRINGS_NS;i < NB_STRINGS_MAX;i++) {
|
||||||
|
cur = strings2[i];
|
||||||
|
pref = &prefix[0];
|
||||||
|
while (*cur != ':') *pref++ = *cur++;
|
||||||
|
cur++;
|
||||||
|
*pref = 0;
|
||||||
|
tmp = xmlDictQLookup(dict, &prefix[0], cur);
|
||||||
|
if (xmlDictQLookup(dict, &prefix[0], cur) != test2[i]) {
|
||||||
|
fprintf(stderr, "Failed lookup check for '%s':'%s'\n",
|
||||||
|
&prefix[0], cur);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* check the QName lookups for strings from the parent
|
||||||
|
*/
|
||||||
|
for (i = NB_STRINGS_MAX - NB_STRINGS_NS;i < NB_STRINGS_MAX;i++) {
|
||||||
|
cur = strings1[i];
|
||||||
|
pref = &prefix[0];
|
||||||
|
while (*cur != ':') *pref++ = *cur++;
|
||||||
|
cur++;
|
||||||
|
*pref = 0;
|
||||||
|
tmp = xmlDictQLookup(dict, &prefix[0], cur);
|
||||||
|
if (xmlDictQLookup(dict, &prefix[0], cur) != test1[i]) {
|
||||||
|
fprintf(stderr, "Failed parent lookup check for '%s':'%s'\n",
|
||||||
|
&prefix[0], cur);
|
||||||
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
xmlDictFree(dict);
|
||||||
|
return(ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test a single dictionary
|
||||||
|
*/
|
||||||
static int run_test1(void) {
|
static int run_test1(void) {
|
||||||
int i, j;
|
int i, j;
|
||||||
xmlDictPtr dict;
|
xmlDictPtr dict;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
xmlChar prefix[40];
|
xmlChar prefix[40];
|
||||||
xmlChar *cur, *pref, *tmp;
|
xmlChar *cur, *pref;
|
||||||
|
const xmlChar *tmp;
|
||||||
|
|
||||||
dict = xmlDictCreate();
|
dict = xmlDictCreate();
|
||||||
if (dict == NULL) {
|
if (dict == NULL) {
|
||||||
@ -103,28 +329,31 @@ static int run_test1(void) {
|
|||||||
* and we allocate all those doing the fast key computations
|
* and we allocate all those doing the fast key computations
|
||||||
*/
|
*/
|
||||||
for (i = 0;i < NB_STRINGS_MIN;i++) {
|
for (i = 0;i < NB_STRINGS_MIN;i++) {
|
||||||
test1[i] = xmlDictLookup(dict, strings[i], -1);
|
test1[i] = xmlDictLookup(dict, strings1[i], -1);
|
||||||
if (test1[i] == NULL) {
|
if (test1[i] == NULL) {
|
||||||
fprintf(stderr, "Failed lookup for '%s'\n", strings[i]);
|
fprintf(stderr, "Failed lookup for '%s'\n", strings1[i]);
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
j = NB_STRINGS_MAX - NB_STRINGS_NS;
|
j = NB_STRINGS_MAX - NB_STRINGS_NS;
|
||||||
/* ":foo" like strings */
|
/* ":foo" like strings1 */
|
||||||
for (i = 0;i < NB_STRINGS_MIN;i++, j++) {
|
for (i = 0;i < NB_STRINGS_MIN;i++, j++) {
|
||||||
test1[j] = xmlDictLookup(dict, strings[j], xmlStrlen(strings[j]));
|
test1[j] = xmlDictLookup(dict, strings1[j], xmlStrlen(strings1[j]));
|
||||||
if (test1[j] == NULL) {
|
if (test1[j] == NULL) {
|
||||||
fprintf(stderr, "Failed lookup for '%s'\n", strings[j]);
|
fprintf(stderr, "Failed lookup for '%s'\n", strings1[j]);
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* "a:foo" like strings */
|
/* "a:foo" like strings1 */
|
||||||
j = NB_STRINGS_MAX - NB_STRINGS_MIN;
|
j = NB_STRINGS_MAX - NB_STRINGS_MIN;
|
||||||
for (i = 0;i < NB_STRINGS_MIN;i++, j++) {
|
for (i = 0;i < NB_STRINGS_MIN;i++, j++) {
|
||||||
test1[j] = xmlDictLookup(dict, strings[j], xmlStrlen(strings[j]));
|
test1[j] = xmlDictLookup(dict, strings1[j], xmlStrlen(strings1[j]));
|
||||||
if (test1[j] == NULL) {
|
if (test1[j] == NULL) {
|
||||||
fprintf(stderr, "Failed lookup for '%s'\n", strings[j]);
|
fprintf(stderr, "Failed lookup for '%s'\n", strings1[j]);
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -136,22 +365,24 @@ static int run_test1(void) {
|
|||||||
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
||||||
if (test1[i] != NULL)
|
if (test1[i] != NULL)
|
||||||
continue;
|
continue;
|
||||||
test1[i] = xmlDictLookup(dict, strings[i], -1);
|
test1[i] = xmlDictLookup(dict, strings1[i], -1);
|
||||||
if (test1[i] == NULL) {
|
if (test1[i] == NULL) {
|
||||||
fprintf(stderr, "Failed lookup for '%s'\n", strings[i]);
|
fprintf(stderr, "Failed lookup for '%s'\n", strings1[i]);
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Now we can start to test things, first that all strings belongs to
|
* Now we can start to test things, first that all strings1 belongs to
|
||||||
* the dict
|
* the dict
|
||||||
*/
|
*/
|
||||||
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
||||||
if (!xmlDictOwns(dict, test1[i])) {
|
if (!xmlDictOwns(dict, test1[i])) {
|
||||||
fprintf(stderr, "Failed ownership failure for '%s'\n",
|
fprintf(stderr, "Failed ownership failure for '%s'\n",
|
||||||
strings[i]);
|
strings1[i]);
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -159,10 +390,11 @@ static int run_test1(void) {
|
|||||||
* Then that another lookup to the string will return the same
|
* Then that another lookup to the string will return the same
|
||||||
*/
|
*/
|
||||||
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
for (i = 0;i < NB_STRINGS_MAX;i++) {
|
||||||
if (xmlDictLookup(dict, strings[i], -1) != test1[i]) {
|
if (xmlDictLookup(dict, strings1[i], -1) != test1[i]) {
|
||||||
fprintf(stderr, "Failed re-lookup check for %d, '%s'\n",
|
fprintf(stderr, "Failed re-lookup check for %d, '%s'\n",
|
||||||
i, strings[i]);
|
i, strings1[i]);
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -170,7 +402,7 @@ static int run_test1(void) {
|
|||||||
* More complex, check the QName lookups
|
* More complex, check the QName lookups
|
||||||
*/
|
*/
|
||||||
for (i = NB_STRINGS_MAX - NB_STRINGS_NS;i < NB_STRINGS_MAX;i++) {
|
for (i = NB_STRINGS_MAX - NB_STRINGS_NS;i < NB_STRINGS_MAX;i++) {
|
||||||
cur = strings[i];
|
cur = strings1[i];
|
||||||
pref = &prefix[0];
|
pref = &prefix[0];
|
||||||
while (*cur != ':') *pref++ = *cur++;
|
while (*cur != ':') *pref++ = *cur++;
|
||||||
cur++;
|
cur++;
|
||||||
@ -180,11 +412,14 @@ static int run_test1(void) {
|
|||||||
fprintf(stderr, "Failed lookup check for '%s':'%s'\n",
|
fprintf(stderr, "Failed lookup check for '%s':'%s'\n",
|
||||||
&prefix[0], cur);
|
&prefix[0], cur);
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
nbErrors++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
run_test2(dict);
|
||||||
|
|
||||||
xmlDictFree(dict);
|
xmlDictFree(dict);
|
||||||
return(0);
|
return(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
@ -197,6 +432,11 @@ int main(void)
|
|||||||
print_strings();
|
print_strings();
|
||||||
#endif
|
#endif
|
||||||
ret = run_test1();
|
ret = run_test1();
|
||||||
|
if (ret == 0) {
|
||||||
|
printf("dictionary tests succeeded %d strings\n", 2 * NB_STRINGS_MAX);
|
||||||
|
} else {
|
||||||
|
printf("dictionary tests failed with %d errors\n", nbErrors);
|
||||||
|
}
|
||||||
clean_strings();
|
clean_strings();
|
||||||
xmlCleanupParser();
|
xmlCleanupParser();
|
||||||
xmlMemoryDump();
|
xmlMemoryDump();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user