VirtualBox

source: vbox/trunk/src/libs/libxml2-2.9.14/Makefile.am@ 98838

Last change on this file since 98838 was 95312, checked in by vboxsync, 3 years ago

libs/{curl,libxml2}: OSE export fixes, bugref:8515

  • Property svn:eol-style set to native
File size: 58.3 KB
Line 
1## Process this file with automake to produce Makefile.in
2
3ACLOCAL_AMFLAGS = -I m4
4
5SUBDIRS = include . doc example fuzz xstc $(PYTHON_SUBDIR)
6
7DIST_SUBDIRS = include . doc example fuzz python xstc
8
9AM_CPPFLAGS = -I$(top_builddir)/include -I$(srcdir)/include
10
11AM_CFLAGS = $(EXTRA_CFLAGS) $(THREAD_CFLAGS) $(Z_CFLAGS) $(LZMA_CFLAGS)
12
13check_PROGRAMS=testSchemas testRelax testSAX testHTML testXPath testURI \
14 testThreads testC14N testAutomata testRegexp \
15 testReader testapi testModule runtest runsuite testchar \
16 testdict runxmlconf testrecurse testlimits
17
18bin_PROGRAMS = xmllint xmlcatalog
19
20bin_SCRIPTS=xml2-config
21
22lib_LTLIBRARIES = libxml2.la
23libxml2_la_LIBADD = $(ICU_LIBS) $(THREAD_LIBS) $(Z_LIBS) $(LZMA_LIBS) $(ICONV_LIBS) $(M_LIBS) $(WIN32_EXTRA_LIBADD)
24
25if USE_VERSION_SCRIPT
26LIBXML2_VERSION_SCRIPT = $(VERSION_SCRIPT_FLAGS)$(srcdir)/libxml2.syms
27else
28LIBXML2_VERSION_SCRIPT =
29endif
30
31libxml2_la_LDFLAGS = $(CYGWIN_EXTRA_LDFLAGS) $(WIN32_EXTRA_LDFLAGS) \
32 $(LIBXML2_VERSION_SCRIPT) \
33 -version-info $(LIBXML_VERSION_INFO) \
34 $(MODULE_PLATFORM_LIBS)
35
36if WITH_SAX1_SOURCES
37docb_sources = DOCBparser.c
38else
39docb_sources =
40endif
41
42if WITH_TRIO_SOURCES
43trio_sources = triostr.c trio.c
44else
45trio_sources =
46endif
47
48libxml2_la_SOURCES = SAX.c entities.c encoding.c error.c parserInternals.c \
49 parser.c tree.c hash.c list.c xmlIO.c xmlmemory.c uri.c \
50 valid.c xlink.c HTMLparser.c HTMLtree.c debugXML.c xpath.c \
51 xpointer.c xinclude.c nanohttp.c nanoftp.c \
52 $(docb_sources) \
53 catalog.c globals.c threads.c c14n.c xmlstring.c buf.c \
54 xmlregexp.c xmlschemas.c xmlschemastypes.c xmlunicode.c \
55 $(trio_sources) \
56 xmlreader.c relaxng.c dict.c SAX2.c \
57 xmlwriter.c legacy.c chvalid.c pattern.c xmlsave.c \
58 xmlmodule.c schematron.c xzlib.c
59
60DEPS = $(top_builddir)/libxml2.la
61LDADDS = $(STATIC_BINARIES) $(top_builddir)/libxml2.la $(THREAD_LIBS) $(Z_LIBS) $(LZMA_LIBS) $(ICONV_LIBS) $(M_LIBS) $(WIN32_EXTRA_LIBADD)
62
63
64man_MANS = xml2-config.1 libxml.3
65
66m4datadir = $(datadir)/aclocal
67m4data_DATA = libxml.m4
68
69runtest_SOURCES=runtest.c
70runtest_LDFLAGS =
71runtest_DEPENDENCIES = $(DEPS)
72runtest_LDADD= $(BASE_THREAD_LIBS) $(RDL_LIBS) $(LDADDS)
73
74testrecurse_SOURCES=testrecurse.c
75testrecurse_LDFLAGS =
76testrecurse_DEPENDENCIES = $(DEPS)
77testrecurse_LDADD= $(BASE_THREAD_LIBS) $(RDL_LIBS) $(LDADDS)
78
79testlimits_SOURCES=testlimits.c
80testlimits_LDFLAGS =
81testlimits_DEPENDENCIES = $(DEPS)
82testlimits_LDADD= $(BASE_THREAD_LIBS) $(RDL_LIBS) $(LDADDS)
83
84testchar_SOURCES=testchar.c
85testchar_LDFLAGS =
86testchar_DEPENDENCIES = $(DEPS)
87testchar_LDADD= $(RDL_LIBS) $(LDADDS)
88
89testdict_SOURCES=testdict.c
90testdict_LDFLAGS =
91testdict_DEPENDENCIES = $(DEPS)
92testdict_LDADD= $(RDL_LIBS) $(LDADDS)
93
94runsuite_SOURCES=runsuite.c
95runsuite_LDFLAGS =
96runsuite_DEPENDENCIES = $(DEPS)
97runsuite_LDADD= $(RDL_LIBS) $(LDADDS)
98
99xmllint_SOURCES=xmllint.c
100xmllint_LDFLAGS =
101xmllint_DEPENDENCIES = $(DEPS)
102xmllint_LDADD= $(RDL_LIBS) $(LDADDS)
103
104testSAX_SOURCES=testSAX.c
105testSAX_LDFLAGS =
106testSAX_DEPENDENCIES = $(DEPS)
107testSAX_LDADD= $(LDADDS)
108
109testHTML_SOURCES=testHTML.c
110testHTML_LDFLAGS =
111testHTML_DEPENDENCIES = $(DEPS)
112testHTML_LDADD= $(LDADDS)
113
114xmlcatalog_SOURCES=xmlcatalog.c
115xmlcatalog_LDFLAGS =
116xmlcatalog_DEPENDENCIES = $(DEPS)
117xmlcatalog_LDADD = $(RDL_LIBS) $(LDADDS)
118
119testXPath_SOURCES=testXPath.c
120testXPath_LDFLAGS =
121testXPath_DEPENDENCIES = $(DEPS)
122testXPath_LDADD= $(LDADDS)
123
124testC14N_SOURCES=testC14N.c
125testC14N_LDFLAGS =
126testC14N_DEPENDENCIES = $(DEPS)
127testC14N_LDADD= $(LDADDS)
128
129testThreads_SOURCES = testThreads.c
130testThreads_LDFLAGS =
131testThreads_DEPENDENCIES = $(DEPS)
132testThreads_LDADD= $(BASE_THREAD_LIBS) $(LDADDS)
133
134testURI_SOURCES=testURI.c
135testURI_LDFLAGS =
136testURI_DEPENDENCIES = $(DEPS)
137testURI_LDADD= $(LDADDS)
138
139testRegexp_SOURCES=testRegexp.c
140testRegexp_LDFLAGS =
141testRegexp_DEPENDENCIES = $(DEPS)
142testRegexp_LDADD= $(LDADDS)
143
144testAutomata_SOURCES=testAutomata.c
145testAutomata_LDFLAGS =
146testAutomata_DEPENDENCIES = $(DEPS)
147testAutomata_LDADD= $(LDADDS)
148
149testSchemas_SOURCES=testSchemas.c
150testSchemas_LDFLAGS =
151testSchemas_DEPENDENCIES = $(DEPS)
152testSchemas_LDADD= $(LDADDS)
153
154testRelax_SOURCES=testRelax.c
155testRelax_LDFLAGS =
156testRelax_DEPENDENCIES = $(DEPS)
157testRelax_LDADD= $(LDADDS)
158
159testReader_SOURCES=testReader.c
160testReader_LDFLAGS =
161testReader_DEPENDENCIES = $(DEPS)
162testReader_LDADD= $(LDADDS)
163
164testModule_SOURCES=testModule.c
165testModule_LDFLAGS =
166testModule_DEPENDENCIES = $(DEPS)
167testModule_LDADD= $(LDADDS)
168
169noinst_LTLIBRARIES = testdso.la
170testdso_la_SOURCES = testdso.c
171testdso_la_LDFLAGS = -module -no-undefined -avoid-version -rpath $(libdir)
172
173# that one forces the rebuild when "make rebuild" is run on doc/
174rebuild_testapi:
175 -@(if [ "$(PYTHON)" != "" ] ; then \
176 $(PYTHON) $(srcdir)/gentest.py $(srcdir) ; fi )
177
178# that one is just to make sure it is rebuilt if missing
179# but adding the dependances generate mess
180testapi.c: $(srcdir)/gentest.py
181 -@(if [ "$(PYTHON)" != "" ] ; then \
182 $(PYTHON) $(srcdir)/gentest.py $(srcdir) ; fi )
183
184BUILT_SOURCES = testapi.c
185
186testapi_SOURCES=testapi.c
187testapi_LDFLAGS =
188testapi_DEPENDENCIES = $(DEPS)
189testapi_LDADD= $(LDADDS)
190
191runxmlconf_SOURCES=runxmlconf.c
192runxmlconf_LDFLAGS =
193runxmlconf_DEPENDENCIES = $(DEPS)
194runxmlconf_LDADD= $(LDADDS)
195
196#testOOM_SOURCES=testOOM.c testOOMlib.h testOOMlib.c
197#testOOM_LDFLAGS =
198#testOOM_DEPENDENCIES = $(DEPS)
199#testOOM_LDADD= $(LDADDS)
200
201runtests: runtest$(EXEEXT) testrecurse$(EXEEXT) testapi$(EXEEXT) \
202 testchar$(EXEEXT) testdict$(EXEEXT) runxmlconf$(EXEEXT)
203 [ -d test ] || $(LN_S) $(srcdir)/test .
204 [ -d result ] || $(LN_S) $(srcdir)/result .
205 $(CHECKER) ./runtest$(EXEEXT) && \
206 $(CHECKER) ./testrecurse$(EXEEXT) && \
207 ASAN_OPTIONS="$$ASAN_OPTIONS:detect_leaks=0" $(CHECKER) ./testapi$(EXEEXT) && \
208 $(CHECKER) ./testchar$(EXEEXT) && \
209 $(CHECKER) ./testdict$(EXEEXT) && \
210 $(CHECKER) ./runxmlconf$(EXEEXT)
211 @(if [ "$(PYTHON_SUBDIR)" != "" ] ; then cd python ; \
212 $(MAKE) tests ; fi)
213 @cd fuzz; $(MAKE) tests
214
215check: all runtests
216
217check-valgrind valgrind: all
218 @echo '## Running the regression tests under Valgrind'
219 @echo '## Go get a cup of coffee it is gonna take a while ...'
220 $(MAKE) CHECKER='valgrind -q' runtests
221
222asan:
223 @echo '## rebuilding for ASAN'
224 ./configure CFLAGS="-fsanitize=address,undefined -Wformat -Werror=format-security -Werror=array-bounds -g" CXXFLAGS="-fsanitize=address,undefined -Wformat -Werror=format-security -Werror=array-bounds -g" LDFLAGS="-fsanitize=address,undefined" CC="clang" CXX="clang++" --disable-shared ; OptimOff ; $(MAKE) clean ; $(MAKE)
225
226testall : tests SVGtests SAXtests
227
228tests: XMLtests XMLenttests NStests IDtests Errtests APItests $(READER_TEST) $(TEST_SAX) $(TEST_PUSH) $(TEST_HTML) $(TEST_PHTML) $(TEST_VALID) URItests $(TEST_PATTERN) $(TEST_XPATH) $(TEST_XPTR) $(TEST_XINCLUDE) $(TEST_C14N) $(TEST_DEBUG) $(TEST_CATALOG) $(TEST_REGEXPS) $(TEST_SCHEMAS) $(TEST_SCHEMATRON) $(TEST_THREADS) Timingtests $(TEST_VTIME) $(PYTHON_TESTS) $(TEST_MODULES)
229 @(if [ "$(PYTHON_SUBDIR)" != "" ] ; then cd python ; \
230 $(MAKE) -s tests ; fi)
231 @(cd doc/examples ; $(MAKE) -s tests)
232
233APItests: testapi$(EXEEXT)
234 @echo "## Running the API regression tests this may take a little while"
235 -@(ASAN_OPTIONS="$$ASAN_OPTIONS:detect_leaks=0" $(CHECKER) $(top_builddir)/testapi -q)
236
237HTMLtests : testHTML$(EXEEXT)
238 @(echo > .memdump)
239 @echo "## HTML regression tests"
240 -@(for i in $(srcdir)/test/HTML/* ; do \
241 name=`basename $$i`; \
242 if [ ! -d $$i ] ; then \
243 if [ ! -f $(srcdir)/result/HTML/$$name ] ; then \
244 echo New test file $$name ; \
245 $(CHECKER) $(top_builddir)/testHTML $$i > $(srcdir)/result/HTML/$$name 2>$(srcdir)/result/HTML/$$name.err ; \
246 else \
247 log=`$(CHECKER) $(top_builddir)/testHTML $$i > result.$$name 2> error.$$name ; \
248 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
249 diff $(srcdir)/result/HTML/$$name result.$$name ; \
250 diff -b $(srcdir)/result/HTML/$$name.err error.$$name ; \
251 $(CHECKER) $(top_builddir)/testHTML result.$$name > result2.$$name 2>error.$$name ; \
252 diff result.$$name result2.$$name` ; \
253 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
254 rm result.$$name result2.$$name error.$$name ; \
255 fi ; fi ; done)
256
257HTMLPushtests : testHTML$(EXEEXT)
258 @echo "## Push HTML regression tests"
259 -@(for i in $(srcdir)/test/HTML/* ; do \
260 name=`basename $$i`; \
261 if [ ! -d $$i ] ; then \
262 if [ ! -f $(srcdir)/result/HTML/$$name ] ; then \
263 echo New test file $$name ; \
264 $(CHECKER) $(top_builddir)/testHTML --push $$i > $(srcdir)/result/HTML/$$name 2>$(srcdir)/result/HTML/$$name.err ; \
265 else \
266 log=`$(CHECKER) $(top_builddir)/testHTML --push $$i > result.$$name 2> error.$$name ; \
267 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
268 diff $(srcdir)/result/HTML/$$name result.$$name ; \
269 cut -b 1-15 $(srcdir)/result/HTML/$$name.err > errorcut.$$name; \
270 cut -b 1-15 error.$$name > errorcut2.$$name; \
271 diff -b errorcut.$$name errorcut2.$$name ; \
272 $(CHECKER) $(top_builddir)/testHTML --push result.$$name > result2.$$name 2>error.$$name ; \
273 diff result.$$name result2.$$name` ; \
274 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
275 rm result.$$name result2.$$name error.$$name errorcut.$$name errorcut2.$$name ; \
276 fi ; fi ; done)
277 @echo "## HTML SAX regression tests"
278 -@(for i in $(srcdir)/test/HTML/* ; do \
279 name=`basename $$i`; \
280 if [ ! -d $$i ] ; then \
281 if [ ! -f $(srcdir)/result/HTML/$$name.sax ] ; then \
282 echo New test file $$name ; \
283 $(CHECKER) $(top_builddir)/testHTML --sax $$i > $(srcdir)/result/HTML/$$name.sax ; \
284 else \
285 log=`$(CHECKER) $(top_builddir)/testHTML --sax $$i > result.$$name.sax ; \
286 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
287 diff $(srcdir)/result/HTML/$$name.sax result.$$name.sax` ; \
288 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
289 rm result.$$name.sax ; \
290 fi ; fi ; done)
291 @echo "## Push HTML SAX regression tests"
292 -@(for i in $(srcdir)/test/HTML/* ; do \
293 name=`basename $$i`; \
294 if [ ! -d $$i ] ; then \
295 if [ ! -f $(srcdir)/result/HTML/$$name ] ; then \
296 echo New test file $$name ; \
297 $(CHECKER) $(top_builddir)/testHTML --push --sax $$i > $(srcdir)/result/HTML/$$name.sax ; \
298 else \
299 log=`$(CHECKER) $(top_builddir)/testHTML --push --sax $$i 2>&1 > result.$$name.sax ; \
300 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
301 diff $(srcdir)/result/HTML/$$name.sax result.$$name.sax` ; \
302 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
303 rm result.$$name.sax ; \
304 fi ; fi ; done)
305
306XMLtests : xmllint$(EXEEXT)
307 @(echo > .memdump)
308 @echo "## XML regression tests"
309 -@(for i in $(srcdir)/test/* ; do \
310 name=`basename $$i`; \
311 if [ ! -d $$i ] ; then \
312 if [ ! -f $(srcdir)/result/$$name ] ; then \
313 echo New test file $$name ; \
314 $(CHECKER) $(top_builddir)/xmllint $$i > $(srcdir)/result/$$name ; \
315 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
316 else \
317 log=`$(CHECKER) $(top_builddir)/xmllint $$i 2>&1 > result.$$name ; \
318 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
319 diff $(srcdir)/result/$$name result.$$name ; \
320 $(CHECKER) $(top_builddir)/xmllint result.$$name 2>&1 > result2.$$name | grep -v 'failed to load external entity' ; \
321 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
322 diff result.$$name result2.$$name` ;\
323 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
324 rm result.$$name result2.$$name ; \
325 fi ; fi ; done)
326 @echo "## XML regression tests on memory"
327 -@(for i in $(srcdir)/test/* ; do \
328 name=`basename $$i`; \
329 if [ ! -d $$i ] ; then \
330 if [ ! -f $(srcdir)/result/$$name ] ; then \
331 echo New test file $$name ; \
332 $(CHECKER) $(top_builddir)/xmllint --memory $$i > $(srcdir)/result/$$name ; \
333 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
334 else \
335 log=`$(CHECKER) $(top_builddir)/xmllint --memory $$i 2>&1 > result.$$name ; \
336 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
337 diff $(srcdir)/result/$$name result.$$name ; \
338 $(CHECKER) $(top_builddir)/xmllint --memory result.$$name 2>&1 > result2.$$name | grep -v 'failed to load external entity' ; \
339 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"`; \
340 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
341 diff result.$$name result2.$$name ; \
342 rm result.$$name result2.$$name ; \
343 fi ; fi ; done)
344
345XMLPushtests: xmllint$(EXEEXT)
346 @(echo > .memdump)
347 @echo "## XML push regression tests"
348 -@(for i in $(srcdir)/test/* ; do \
349 name=`basename $$i`; \
350 if [ ! -d $$i ] ; then \
351 if [ ! -f $(srcdir)/result/$$name ] ; then \
352 echo New test file $$name ; \
353 $(CHECKER) $(top_builddir)/xmllint --push $$i > $(srcdir)/result/$$name ; \
354 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
355 else \
356 log=`$(CHECKER) $(top_builddir)/xmllint --push $$i 2>&1 > result.$$name ; \
357 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
358 diff $(srcdir)/result/$$name result.$$name ; \
359 $(CHECKER) $(top_builddir)/xmllint --push result.$$name 2>&1 > result2.$$name | grep -v 'failed to load external entity' ; \
360 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
361 diff result.$$name result2.$$name` ; \
362 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
363 rm result.$$name result2.$$name ; \
364 fi ; fi ; done)
365
366NStests : xmllint$(EXEEXT)
367 @(echo > .memdump)
368 @echo "## XML Namespaces regression tests"
369 -@(for i in $(srcdir)/test/namespaces/* ; do \
370 name=`basename $$i`; \
371 if [ ! -d $$i ] ; then \
372 if [ ! -f $(srcdir)/result/namespaces/$$name ] ; then \
373 echo New test file $$name ; \
374 $(CHECKER) $(top_builddir)/xmllint $$i \
375 2> $(srcdir)/result/namespaces/$$name.err \
376 > $(srcdir)/result/namespaces/$$name ; \
377 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
378 else \
379 log=`$(CHECKER) $(top_builddir)/xmllint $$i 2> error.$$name > result.$$name ; \
380 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
381 diff $(srcdir)/result/namespaces/$$name result.$$name ; \
382 diff $(srcdir)/result/namespaces/$$name.err error.$$name`; \
383 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
384 rm result.$$name error.$$name ; \
385 fi ; fi ; done)
386
387IDtests : xmllint$(EXEEXT) testXPath$(EXEEXT)
388 @(echo > .memdump)
389 @echo "## xml:id regression tests"
390 -@(for i in $(srcdir)/test/xmlid/id_*.xml ; do \
391 name=`basename $$i`; \
392 if [ ! -d $$i ] ; then \
393 if [ ! -f $(srcdir)/result/xmlid/$$name ] ; then \
394 echo New test file $$name ; \
395 $(CHECKER) $(top_builddir)/testXPath -i $$i "id('bar')" \
396 2> $(srcdir)/result/xmlid/$$name.err \
397 > $(srcdir)/result/xmlid/$$name ; \
398 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
399 else \
400 log=`$(CHECKER) $(top_builddir)/testXPath -i $$i "id('bar')" 2> error.$$name > result.$$name ; \
401 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
402 diff $(srcdir)/result/xmlid/$$name result.$$name ; \
403 diff $(srcdir)/result/xmlid/$$name.err error.$$name` ; \
404 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
405 rm result.$$name error.$$name ; \
406 fi ; fi ; done)
407
408Errtests : xmllint$(EXEEXT)
409 @(echo > .memdump)
410 @echo "## Error cases regression tests"
411 -@(for i in $(srcdir)/test/errors/*.xml ; do \
412 name=`basename $$i`; \
413 if [ ! -d $$i ] ; then \
414 if [ ! -f $(srcdir)/result/errors/$$name ] ; then \
415 echo New test file $$name ; \
416 $(CHECKER) $(top_builddir)/xmllint $$i \
417 2> $(srcdir)/result/errors/$$name.err \
418 > $(srcdir)/result/errors/$$name ; \
419 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
420 else \
421 log=`$(CHECKER) $(top_builddir)/xmllint $$i 2> error.$$name > result.$$name ; \
422 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
423 diff $(srcdir)/result/errors/$$name result.$$name ; \
424 diff $(srcdir)/result/errors/$$name.err error.$$name` ; \
425 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
426 rm result.$$name error.$$name ; \
427 fi ; fi ; done)
428 @echo "## Error cases regression tests (old 1.0)"
429 -@(for i in $(srcdir)/test/errors10/*.xml ; do \
430 name=`basename $$i`; \
431 if [ ! -d $$i ] ; then \
432 if [ ! -f $(srcdir)/result/errors10/$$name ] ; then \
433 echo New test file $$name ; \
434 $(CHECKER) $(top_builddir)/xmllint --oldxml10 $$i \
435 2> $(srcdir)/result/errors10/$$name.err \
436 > $(srcdir)/result/errors10/$$name ; \
437 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
438 else \
439 log=`$(CHECKER) $(top_builddir)/xmllint --oldxml10 $$i 2> error.$$name > result.$$name ; \
440 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
441 diff $(srcdir)/result/errors10/$$name result.$$name ; \
442 diff $(srcdir)/result/errors10/$$name.err error.$$name` ; \
443 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
444 rm result.$$name error.$$name ; \
445 fi ; fi ; done)
446 @echo "## Error cases stream regression tests"
447 -@(for i in $(srcdir)/test/errors/*.xml ; do \
448 name=`basename $$i`; \
449 if [ ! -d $$i ] ; then \
450 if [ ! -f $(srcdir)/result/errors/$$name.str ] ; then \
451 echo New test file $$name ; \
452 $(CHECKER) $(top_builddir)/xmllint --stream $$i \
453 2> $(srcdir)/result/errors/$$name.str \
454 > /dev/null ; \
455 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
456 else \
457 log=`$(CHECKER) $(top_builddir)/xmllint --stream $$i 2> error.$$name > /dev/null ; \
458 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
459 diff $(srcdir)/result/errors/$$name.str error.$$name` ; \
460 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
461 rm error.$$name ; \
462 fi ; fi ; done)
463
464Docbtests : xmllint$(EXEEXT)
465
466XMLenttests : xmllint$(EXEEXT)
467 @(echo > .memdump)
468 @echo "## XML entity subst regression tests"
469 -@(for i in $(srcdir)/test/* ; do \
470 name=`basename $$i`; \
471 if [ ! -d $$i ] ; then \
472 if [ ! -f $(srcdir)/result/noent/$$name ] ; then \
473 echo New test file $$name ; \
474 $(CHECKER) $(top_builddir)/xmllint --noent $$i > $(srcdir)/result/noent/$$name ; \
475 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
476 else \
477 log=`$(CHECKER) $(top_builddir)/xmllint --noent $$i 2>&1 > result.$$name ; \
478 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
479 diff $(srcdir)/result/noent/$$name result.$$name ; \
480 $(CHECKER) $(top_builddir)/xmllint --noent result.$$name 2>&1 > result2.$$name ; \
481 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
482 diff result.$$name result2.$$name` ; \
483 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
484 rm result.$$name result2.$$name ; \
485 fi ; fi ; done)
486
487URItests : testURI$(EXEEXT)
488 @(echo > .memdump)
489 @echo "## URI module regression tests"
490 -@(for i in $(srcdir)/test/URI/*.data ; do \
491 name=`basename $$i`; \
492 if [ ! -d $$i ] ; then \
493 if [ ! -f $(srcdir)/result/URI/$$name ] ; then \
494 echo New test file $$name ; \
495 $(CHECKER) $(top_builddir)/testURI -base 'http://foo.com/path/to/index.html?orig#help' < $$i > $(srcdir)/result/URI/$$name ; \
496 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
497 else \
498 log=`$(CHECKER) $(top_builddir)/testURI -base 'http://foo.com/path/to/index.html?orig#help' < $$i 2>&1 > result.$$name ; \
499 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
500 diff $(srcdir)/result/URI/$$name result.$$name` ; \
501 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
502 rm result.$$name ; \
503 fi ; fi ; done)
504 -@(for i in $(srcdir)/test/URI/*.uri ; do \
505 name=`basename $$i`; \
506 if [ ! -d $$i ] ; then \
507 if [ ! -f $(srcdir)/result/URI/$$name ] ; then \
508 echo New test file $$name ; \
509 $(CHECKER) $(top_builddir)/testURI < $$i > $(srcdir)/result/URI/$$name ; \
510 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
511 else \
512 log=`$(CHECKER) $(top_builddir)/testURI < $$i 2>&1 > result.$$name ; \
513 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
514 diff $(srcdir)/result/URI/$$name result.$$name` ; \
515 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
516 rm result.$$name ; \
517 fi ; fi ; done)
518
519XPathtests : testXPath$(EXEEXT)
520 @(echo > .memdump)
521 @echo "## XPath regression tests"
522 -@(if [ "`$(top_builddir)/testXPath | grep 'support not compiled in'`" != "" ] ; \
523 then echo Skipping debug not compiled in ; exit 0 ; fi ; \
524 for i in $(srcdir)/test/XPath/expr/* ; do \
525 name=`basename $$i`; \
526 if [ ! -d $$i ] ; then \
527 if [ ! -f $(srcdir)/result/XPath/expr/$$name ] ; then \
528 echo New test file $$name ; \
529 $(CHECKER) $(top_builddir)/testXPath -f --expr $$i > $(srcdir)/result/XPath/expr/$$name 2> /dev/null ; \
530 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
531 else \
532 log=`$(CHECKER) $(top_builddir)/testXPath -f --expr $$i > result.$$name 2> /dev/null ; \
533 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
534 diff $(srcdir)/result/XPath/expr/$$name result.$$name` ; \
535 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
536 rm result.$$name ; \
537 fi ; fi ; done ; \
538 for i in $(srcdir)/test/XPath/docs/* ; do \
539 if [ ! -d $$i ] ; then \
540 doc=`basename $$i`; \
541 for j in $(srcdir)/test/XPath/tests/$$doc* ; do \
542 if [ ! -f $$j ] ; then continue ; fi ; \
543 name=`basename $$j`; \
544 if [ ! -d $$j ] ; then \
545 if [ ! -f $(srcdir)/result/XPath/tests/$$name ] ; then \
546 echo New test file $$name ; \
547 $(CHECKER) $(top_builddir)/testXPath -f -i $$i $$j > $(srcdir)/result/XPath/tests/$$name ; \
548 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
549 else \
550 log=`$(CHECKER) $(top_builddir)/testXPath -f -i $$i $$j > result.$$name ; \
551 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
552 diff $(srcdir)/result/XPath/tests/$$name result.$$name` ; \
553 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
554 rm result.$$name ; \
555 fi ; fi ; done ; fi ; done)
556
557XPtrtests : testXPath$(EXEEXT)
558 @(echo > .memdump)
559 @echo "## XPointer regression tests"
560 -@(if [ "`$(top_builddir)/testXPath | grep 'support not compiled in'`" != "" ] ; \
561 then echo Skipping debug not compiled in ; exit 0 ; fi ; \
562 for i in $(srcdir)/test/XPath/docs/* ; do \
563 if [ ! -d $$i ] ; then \
564 doc=`basename $$i`; \
565 for j in $(srcdir)/test/XPath/xptr/$$doc* ; do \
566 if [ ! -f $$j ] ; then continue ; fi ; \
567 name=`basename $$j`; \
568 if [ ! -d $$j ] ; then \
569 if [ ! -f $(srcdir)/result/XPath/xptr/$$name ] ; then \
570 echo New test file $$name ; \
571 $(CHECKER) $(top_builddir)/testXPath -xptr -f -i $$i $$j > $(srcdir)/result/XPath/xptr/$$name 2> /dev/null ; \
572 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
573 else \
574 log=`$(CHECKER) $(top_builddir)/testXPath -xptr -f -i $$i $$j > result.$$name 2> /dev/null ; \
575 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
576 diff $(srcdir)/result/XPath/xptr/$$name result.$$name` ; \
577 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
578 rm result.$$name ; \
579 fi ; fi ; done ; fi ; done)
580
581XIncludetests : xmllint$(EXEEXT)
582 @(echo > .memdump)
583 @echo "## XInclude regression tests"
584 -@(for i in $(srcdir)/test/XInclude/docs/* ; do \
585 name=`basename $$i`; \
586 if [ ! -d $$i ] ; then \
587 if [ ! -f $(srcdir)/result/XInclude/$$name ] ; then \
588 echo New test file $$name ; \
589 $(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude $$i > $(srcdir)/result/XInclude/$$name 2> $(srcdir)/result/XInclude/$$name.err ; \
590 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
591 else \
592 log=`$(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude $$i > result.$$name 2>error.$$name ; \
593 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
594 diff $(srcdir)/result/XInclude/$$name result.$$name ; \
595 diff $(srcdir)/result/XInclude/$$name.err error.$$name` ; \
596 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
597 rm result.$$name error.$$name ; \
598 fi ; fi ; done)
599 -@(for i in $(srcdir)/test/XInclude/docs/* ; do \
600 name=`basename $$i`; \
601 if [ ! -d $$i ] ; then \
602 if [ ! -f $(srcdir)/result/XInclude/$$name ] ; then \
603 echo New test file $$name ; \
604 $(CHECKER) $(top_builddir)/xmllint --nowarning --noxincludenode $$i > $(srcdir)/result/XInclude/$$name 2> $(srcdir)/result/XInclude/$$name.err ; \
605 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
606 else \
607 log=`$(CHECKER) $(top_builddir)/xmllint --nowarning --noxincludenode $$i > result.$$name 2>error.$$name ; \
608 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
609 diff $(srcdir)/result/XInclude/$$name result.$$name ; \
610 diff $(srcdir)/result/XInclude/$$name.err error.$$name` ; \
611 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
612 rm result.$$name error.$$name ; \
613 fi ; fi ; done)
614 @(echo > .memdump)
615 @echo "## XInclude xmlReader regression tests"
616 -@(for i in $(srcdir)/test/XInclude/docs/* ; do \
617 name=`basename $$i`; \
618 if [ ! -d $$i ] ; then \
619 if [ ! -f $(srcdir)/result/XInclude/$$name.rdr ] ; then \
620 echo New test file $$name ; \
621 $(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude --stream --debug $$i > $(srcdir)/result/XInclude/$$name.rdr ; \
622 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
623 else \
624 log=`$(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude --stream --debug $$i > result.$$name 2>error.$$name ; \
625 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
626 diff $(srcdir)/result/XInclude/$$name.err error.$$name ; \
627 diff $(srcdir)/result/XInclude/$$name.rdr result.$$name` ; \
628 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
629 rm result.$$name error.$$name ; \
630 fi ; fi ; done)
631 -@(for i in $(srcdir)/test/XInclude/docs/* ; do \
632 name=`basename $$i`; \
633 if [ ! -d $$i ] ; then \
634 if [ ! -f $(srcdir)/result/XInclude/$$name.rdr ] ; then \
635 echo New test file $$name ; \
636 $(CHECKER) $(top_builddir)/xmllint --nowarning --noxincludenode --stream --debug $$i > $(srcdir)/result/XInclude/$$name.rdr ; \
637 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
638 else \
639 log=`$(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude --stream --debug $$i > result.$$name 2>error.$$name ; \
640 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
641 diff $(srcdir)/result/XInclude/$$name.err error.$$name ; \
642 diff $(srcdir)/result/XInclude/$$name.rdr result.$$name` ; \
643 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
644 rm result.$$name error.$$name ; \
645 fi ; fi ; done)
646
647Scripttests : xmllint$(EXEEXT)
648 @(echo > .memdump)
649 @echo "## Scripts regression tests"
650 @echo "## Some of the base computations may be different if srcdir != ."
651 -@(for i in $(srcdir)/test/scripts/*.script ; do \
652 name=`basename $$i .script`; \
653 xml=$(srcdir)/test/scripts/`basename $$i .script`.xml; \
654 if [ -f $$xml ] ; then \
655 if [ ! -f $(srcdir)/result/scripts/$$name ] ; then \
656 echo New test file $$name ; \
657 $(CHECKER) $(top_builddir)/xmllint --shell $$xml < $$i > $(srcdir)/result/scripts/$$name 2> $(srcdir)/result/scripts/$$name.err ; \
658 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
659 else \
660 log=`$(CHECKER) $(top_builddir)/xmllint --shell $$xml < $$i > result.$$name 2> result.$$name.err ; \
661 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
662 diff $(srcdir)/result/scripts/$$name result.$$name ; \
663 diff $(srcdir)/result/scripts/$$name.err result.$$name.err` ; \
664 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
665 rm result.$$name result.$$name.err ; \
666 fi ; fi ; done)
667
668Catatests : xmlcatalog$(EXEEXT)
669 @(echo > .memdump)
670 @echo "## Catalog regression tests"
671 -@(for i in $(srcdir)/test/catalogs/*.script ; do \
672 name=`basename $$i .script`; \
673 xml=$(srcdir)/test/catalogs/`basename $$i .script`.xml; \
674 if [ -f $$xml ] ; then \
675 if [ ! -f $(srcdir)/result/catalogs/$$name ] ; then \
676 echo New test file $$name ; \
677 $(CHECKER) $(top_builddir)/xmlcatalog --shell $$xml < $$i 2>&1 > $(srcdir)/result/catalogs/$$name ; \
678 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
679 else \
680 log=`$(CHECKER) $(top_builddir)/xmlcatalog --shell $$xml < $$i 2>&1 > result.$$name ; \
681 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
682 diff $(srcdir)/result/catalogs/$$name result.$$name` ; \
683 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
684 rm result.$$name ; \
685 fi ; fi ; done)
686 -@(for i in $(srcdir)/test/catalogs/*.script ; do \
687 name=`basename $$i .script`; \
688 sgml=$(srcdir)/test/catalogs/`basename $$i .script`.sgml; \
689 if [ -f $$sgml ] ; then \
690 if [ ! -f $(srcdir)/result/catalogs/$$name ] ; then \
691 echo New test file $$name ; \
692 $(CHECKER) $(top_builddir)/xmlcatalog --shell $$sgml < $$i > $(srcdir)/result/catalogs/$$name ; \
693 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
694 else \
695 log=`$(CHECKER) $(top_builddir)/xmlcatalog --shell $$sgml < $$i > result.$$name ; \
696 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
697 diff $(srcdir)/result/catalogs/$$name result.$$name` ; \
698 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
699 rm result.$$name ; \
700 fi ; fi ; done)
701 @echo "## Add and del operations on XML Catalogs"
702 -@($(CHECKER) $(top_builddir)/xmlcatalog --create --noout $(srcdir)/result/catalogs/mycatalog; \
703 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
704 $(CHECKER) $(top_builddir)/xmlcatalog --noout --add public Pubid sysid $(srcdir)/result/catalogs/mycatalog; \
705 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
706 $(CHECKER) $(top_builddir)/xmlcatalog --noout --add public Pubid2 sysid2 $(srcdir)/result/catalogs/mycatalog; \
707 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
708 $(CHECKER) $(top_builddir)/xmlcatalog --noout --add public Pubid3 sysid3 $(srcdir)/result/catalogs/mycatalog; \
709 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
710 diff result/catalogs/mycatalog.full $(srcdir)/result/catalogs/mycatalog; \
711 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
712 $(CHECKER) $(top_builddir)/xmlcatalog --noout --del sysid $(srcdir)/result/catalogs/mycatalog; \
713 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
714 $(CHECKER) $(top_builddir)/xmlcatalog --noout --del sysid3 $(srcdir)/result/catalogs/mycatalog; \
715 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
716 $(CHECKER) $(top_builddir)/xmlcatalog --noout --del sysid2 $(srcdir)/result/catalogs/mycatalog; \
717 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
718 diff result/catalogs/mycatalog.empty $(srcdir)/result/catalogs/mycatalog; \
719 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
720 rm -f $(srcdir)/result/catalogs/mycatalog)
721
722SVGtests : xmllint$(EXEEXT)
723 @echo "## SVG parsing regression tests"
724 -@(for i in $(srcdir)/test/SVG/* ; do \
725 name=`basename $$i`; \
726 if [ ! -d $$i ] ; then \
727 if [ ! -f $(srcdir)/result/SVG/$$name ] ; then \
728 echo New test file $$name ; \
729 $(CHECKER) $(top_builddir)/xmllint $$i > $(srcdir)/result/SVG/$$name ; \
730 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
731 else \
732 echo Testing $$name ; \
733 $(CHECKER) $(top_builddir)/xmllint $$i > result.$$name ; \
734 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
735 diff $(srcdir)/result/SVG/$$name result.$$name ; \
736 $(CHECKER) $(top_builddir)/xmllint result.$$name > result2.$$name ; \
737 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
738 diff result.$$name result2.$$name ; \
739 rm result.$$name result2.$$name ; \
740 fi ; fi ; done)
741
742Threadtests : testThreads$(EXEEXT)
743 @echo "## Threaded regression tests"
744 -@($(CHECKER) $(top_builddir)/testThreads ; \
745 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
746 exit 0)
747
748Readertests : xmllint$(EXEEXT)
749 @(echo > .memdump)
750 @echo "## Reader regression tests"
751 -@(for i in $(srcdir)/test/* ; do \
752 name=`basename $$i`; \
753 if [ ! -d $$i ] ; then \
754 if [ ! -f $(srcdir)/result/$$name.rdr ] ; then \
755 echo New test file $$name ; \
756 $(CHECKER) $(top_builddir)/xmllint --nonet --debug --stream $$i > $(srcdir)/result/$$name.rdr 2>/dev/null ; \
757 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
758 else \
759 log=`$(CHECKER) $(top_builddir)/xmllint --nonet --debug --stream $$i > result.$$name 2>/dev/null ; \
760 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
761 diff $(srcdir)/result/$$name.rdr result.$$name` ; \
762 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
763 rm result.$$name ; \
764 fi ; fi ; done)
765 @echo "## Reader on memory regression tests"
766 -@(for i in $(srcdir)/test/* ; do \
767 name=`basename $$i`; \
768 if [ ! -d $$i ] ; then \
769 if [ ! -f $(srcdir)/result/$$name.rdr ] ; then \
770 echo New test file $$name ; \
771 $(CHECKER) $(top_builddir)/xmllint --memory --nonet --debug --stream $$i > $(srcdir)/result/$$name.rdr 2>/dev/null ; \
772 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
773 else \
774 log=`$(CHECKER) $(top_builddir)/xmllint --memory --nonet --debug --stream $$i > result.$$name 2>/dev/null ; \
775 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
776 diff $(srcdir)/result/$$name.rdr result.$$name` ; \
777 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
778 rm result.$$name ; \
779 fi ; fi ; done)
780 @(echo > .memdump)
781 @echo "## Walker regression tests"
782 -@(for i in $(srcdir)/test/* ; do \
783 name=`basename $$i`; \
784 if [ ! -d $$i ] ; then \
785 if [ ! -f $(srcdir)/result/$$name.rdr ] ; then \
786 echo New test file $$name ; \
787 $(CHECKER) $(top_builddir)/xmllint --nonet --debug --walker $$i > $(srcdir)/result/$$name.rdr 2>/dev/null ; \
788 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
789 else \
790 log=`$(CHECKER) $(top_builddir)/xmllint --nonet --debug --walker $$i > result.$$name 2>/dev/null ; \
791 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
792 diff $(srcdir)/result/$$name.rdr result.$$name` ; \
793 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
794 rm result.$$name ; \
795 fi ; fi ; done)
796 @echo "## Reader entities substitution regression tests"
797 -@(for i in $(srcdir)/test/* ; do \
798 name=`basename $$i`; \
799 if [ ! -d $$i ] ; then \
800 if [ ! -f $(srcdir)/result/$$name.rde ] ; then \
801 echo New test file $$name ; \
802 $(CHECKER) $(top_builddir)/xmllint --noent --nonet --debug --stream $$i > $(srcdir)/result/$$name.rde 2>/dev/null ; \
803 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
804 else \
805 log=`$(CHECKER) $(top_builddir)/xmllint --noent --nonet --debug --stream $$i > result.$$name 2>/dev/null ; \
806 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
807 diff $(srcdir)/result/$$name.rde result.$$name` ; \
808 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
809 rm result.$$name ; \
810 fi ; fi ; done)
811
812SAXtests : testSAX$(EXEEXT)
813 @(echo > .memdump)
814 @echo "## SAX1 callbacks regression tests"
815 -@(for i in $(srcdir)/test/* ; do \
816 name=`basename $$i`; \
817 if [ ! -d $$i ] ; then \
818 if [ ! -f $(srcdir)/result/$$name.sax ] ; then \
819 echo New test file $$name ; \
820 $(CHECKER) $(top_builddir)/testSAX $$i > $(srcdir)/result/$$name.sax 2> /dev/null ; \
821 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
822 else \
823 log=`$(CHECKER) $(top_builddir)/testSAX $$i > result.$$name 2> /dev/null ; \
824 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
825 diff $(srcdir)/result/$$name.sax result.$$name` ; \
826 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
827 rm result.$$name ; \
828 fi ; fi ; done)
829 @echo "## SAX2 callbacks regression tests"
830 -@(for i in $(srcdir)/test/* ; do \
831 name=`basename $$i`; \
832 if [ ! -d $$i ] ; then \
833 if [ ! -f $(srcdir)/result/$$name.sax2 ] ; then \
834 echo New test file $$name ; \
835 $(CHECKER) $(top_builddir)/testSAX --sax2 $$i > $(srcdir)/result/$$name.sax2 2> /dev/null ; \
836 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
837 else \
838 log=`$(CHECKER) $(top_builddir)/testSAX --sax2 $$i > result.$$name 2> /dev/null ; \
839 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
840 diff $(srcdir)/result/$$name.sax2 result.$$name` ; \
841 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
842 rm result.$$name ; \
843 fi ; fi ; done)
844 @echo "## SAX2 callbacks regression tests with entity substitution"
845 -@(for i in $(srcdir)/test/* ; do \
846 name=`basename $$i`; \
847 if [ ! -d $$i ] ; then \
848 if [ ! -f $(srcdir)/result/noent/$$name.sax2 ] ; then \
849 echo New test file $$name ; \
850 $(CHECKER) $(top_builddir)/testSAX --sax2 --noent $$i > $(srcdir)/result/noent/$$name.sax2 2> /dev/null ; \
851 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
852 else \
853 log=`$(CHECKER) $(top_builddir)/testSAX --sax2 --noent $$i > result.$$name 2> /dev/null ; \
854 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
855 diff $(srcdir)/result/noent/$$name.sax2 result.$$name` ; \
856 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
857 rm result.$$name ; \
858 fi ; fi ; done)
859
860Validtests : xmllint$(EXEEXT)
861 @(echo > .memdump)
862 @echo "## Valid documents regression tests"
863 -@(for i in $(srcdir)/test/VCM/* ; do \
864 name=`basename $$i`; \
865 if [ ! -d $$i ] ; then \
866 log=`$(CHECKER) $(top_builddir)/xmllint --valid --noout --nowarning $$i ; \
867 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"`;\
868 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
869 fi ; done ; exit 0)
870 @echo "## Validity checking regression tests"
871 -@(for i in $(srcdir)/test/VC/* ; do \
872 name=`basename $$i`; \
873 if [ ! -d $$i ] ; then \
874 if [ ! -f $(srcdir)/result/VC/$$name ] ; then \
875 echo New test file $$name ; \
876 $(CHECKER) $(top_builddir)/xmllint --noout --valid $$i 2> $(srcdir)/result/VC/$$name ; \
877 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
878 else \
879 log=`$(CHECKER) $(top_builddir)/xmllint --noout --valid $$i 2> result.$$name ; \
880 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
881 diff $(srcdir)/result/VC/$$name result.$$name` ; \
882 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
883 rm result.$$name ; \
884 fi ; fi ; done)
885 @echo "## General documents valid regression tests"
886 -@(for i in $(srcdir)/test/valid/* ; do \
887 name=`basename $$i`; \
888 if [ ! -d $$i ] ; then \
889 if [ ! -f $(srcdir)/result/valid/$$name ] ; then \
890 echo New test file $$name ; \
891 $(CHECKER) $(top_builddir)/xmllint --valid $$i > $(srcdir)/result/valid/$$name 2>$(srcdir)/result/valid/$$name.err ; \
892 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
893 else \
894 log=`$(CHECKER) $(top_builddir)/xmllint --valid $$i > result.$$name 2>error.$$name ; \
895 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
896 diff $(srcdir)/result/valid/$$name result.$$name ; \
897 diff $(srcdir)/result/valid/$$name.err error.$$name` ; \
898 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
899 rm result.$$name error.$$name ; \
900 fi ; fi ; done)
901
902Regexptests: testRegexp$(EXEEXT)
903 @(echo > .memdump)
904 @echo "## Regexp regression tests"
905 -@(for i in $(srcdir)/test/regexp/* ; do \
906 name=`basename $$i`; \
907 if [ ! -d $$i ] ; then \
908 if [ ! -f $(srcdir)/result/regexp/$$name ] ; then \
909 echo New test file $$name ; \
910 $(CHECKER) $(top_builddir)/testRegexp -i $$i > $(srcdir)/result/regexp/$$name 2> $(srcdir)/result/regexp/$$name.err ; \
911 if [ ! -s "$(srcdir)/result/regexp/$$name.err" ] ; then rm $(srcdir)/result/regexp/$$name.err; fi ; \
912 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
913 else \
914 log=`$(CHECKER) $(top_builddir)/testRegexp -i $$i > result.$$name 2> error.$$name ; \
915 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
916 diff $(srcdir)/result/regexp/$$name result.$$name ; \
917 if [ -s "$(srcdir)/result/regexp/$$name.err" -o -s "error.$$name" ] ; then diff $(srcdir)/result/regexp/$$name.err error.$$name ; fi` ; \
918 if [ -n "$$log" ] ; then echo $$name result ; echo $$log ; fi ; \
919 rm result.$$name error.$$name ; \
920 fi ; fi ; done)
921
922# Disabled for now
923Exptests: testRegexp$(EXEEXT)
924 @echo "## Formal expressions regression tests"
925 -@(for i in $(srcdir)/test/expr/* ; do \
926 name=`basename $$i`; \
927 if [ ! -d $$i ] ; then \
928 if [ ! -f $(srcdir)/result/expr/$$name ] ; then \
929 echo New test file $$name ; \
930 $(CHECKER) $(top_builddir)/testRegexp --expr -i $$i > $(srcdir)/result/expr/$$name; \
931 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
932 else \
933 log=`$(CHECKER) $(top_builddir)/testRegexp --expr -i $$i 2>&1 > result.$$name ; \
934 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
935 diff $(srcdir)/result/expr/$$name result.$$name` ; \
936 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
937 rm result.$$name ; \
938 fi ; fi ; done)
939
940Automatatests: testAutomata$(EXEEXT)
941 @(echo > .memdump)
942 @echo "## Automata regression tests"
943 -@(for i in $(srcdir)/test/automata/* ; do \
944 name=`basename $$i`; \
945 if [ ! -d $$i ] ; then \
946 if [ ! -f $(srcdir)/result/automata/$$name ] ; then \
947 echo New test file $$name ; \
948 $(CHECKER) $(top_builddir)/testAutomata $$i > $(srcdir)/result/automata/$$name; \
949 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
950 else \
951 log=`$(CHECKER) $(top_builddir)/testAutomata $$i 2>&1 > result.$$name ; \
952 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
953 diff $(srcdir)/result/automata/$$name result.$$name` ; \
954 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
955 rm result.$$name ; \
956 fi ; fi ; done)
957
958dba100000.xml: dbgenattr.pl
959 @echo "## generating dba100000.xml"
960 @($(PERL) $(top_srcdir)/dbgenattr.pl 100000 > dba100000.xml)
961
962Timingtests: xmllint$(EXEEXT) dba100000.xml
963 @echo "## Timing tests to try to detect performance"
964 @echo "## as well a memory usage breakage when streaming"
965 @echo "## 1/ using the file interface"
966 @echo "## 2/ using the memory interface"
967 @echo "## 3/ repeated DOM parsing"
968 @echo "## 4/ repeated DOM validation"
969 -@($(top_builddir)/xmllint --stream --timing dba100000.xml; \
970 MEM=`cat .memdump | grep "MEMORY ALLOCATED" | awk '{ print $$7}'`;\
971 if [ "$$MEM" != "" ] ; then echo Using $$MEM bytes ; fi ; \
972 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
973 exit 0)
974 -@($(top_builddir)/xmllint --stream --timing --memory dba100000.xml; \
975 MEM=`cat .memdump | grep "MEMORY ALLOCATED" | awk '{ print $$7}'`;\
976 if [ "$$MEM" != "" ] ; then echo Using $$MEM bytes ; fi ; \
977 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
978 exit 0)
979 -@($(top_builddir)/xmllint --noout --timing --repeat $(srcdir)/test/valid/REC-xml-19980210.xml; \
980 MEM=`cat .memdump | grep "MEMORY ALLOCATED" | awk '{ print $$7}'`;\
981 if [ "$$MEM" != "" ] ; then echo Using $$MEM bytes ; fi ; \
982 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
983 exit 0)
984
985VTimingtests: xmllint$(EXEEXT)
986 -@($(top_builddir)/xmllint --noout --timing --valid --repeat $(srcdir)/test/valid/REC-xml-19980210.xml; \
987 MEM=`cat .memdump | grep "MEMORY ALLOCATED" | awk '{ print $$7}'`;\
988 if [ "$$MEM" != "" ] ; then echo Using $$MEM bytes ; fi ; \
989 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
990 exit 0)
991
992C14Ntests : testC14N$(EXEEXT)
993 @echo "## C14N and XPath regression tests"
994 -@(for m in with-comments without-comments 1-1-without-comments exc-without-comments ; do \
995 for i in $(srcdir)/test/c14n/$$m/*.xml ; do \
996 if [ ! -d $$i ] ; then \
997 name=`basename $$i .xml`; \
998 cmdline="$(CHECKER) $(top_builddir)/testC14N --$$m $$i"; \
999 if [ -f $(srcdir)/test/c14n/$$m/$$name.xpath ] ; then \
1000 cmdline="$$cmdline $(srcdir)/test/c14n/$$m/$$name.xpath"; \
1001 if [ -f $(srcdir)/test/c14n/$$m/$$name.ns ] ; then \
1002 cmdline="$$cmdline '`cat $(srcdir)/test/c14n/$$m/$$name.ns`'"; \
1003 fi; \
1004 fi; \
1005 $$cmdline > $(srcdir)/test/c14n/test.tmp 2> /dev/null; \
1006 if [ $$? -eq 0 ]; then \
1007 diff $(srcdir)/result/c14n/$$m/$$name $(srcdir)/test/c14n/test.tmp; \
1008 if [ $$? -ne 0 ]; then \
1009 echo "Test $$m/$$name failed"; \
1010 cat $(srcdir)/test/c14n/test.tmp; \
1011 fi; \
1012 else \
1013 echo "C14N failed"; \
1014 fi; \
1015 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1016 fi; \
1017 rm -f $(srcdir)/test/c14n/test.tmp; \
1018 done; \
1019 done)
1020
1021Schemastests: testSchemas$(EXEEXT)
1022 @(echo > .memdump)
1023 @echo "## Schemas regression tests"
1024 -@(for i in $(srcdir)/test/schemas/*_*.xsd ; do \
1025 name=`basename $$i | sed 's+_.*++'`; \
1026 sno=`basename $$i | sed 's+.*_\(.*\).xsd+\1+'`; \
1027 for j in $(srcdir)/test/schemas/"$$name"_*.xml ; do \
1028 if [ -f $$j ] ; then \
1029 xno=`basename $$j | sed 's+.*_\(.*\).xml+\1+'`; \
1030 if [ ! -f $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno" ]; \
1031 then \
1032 echo New test file "$$name"_"$$sno"_"$$xno" ; \
1033 $(CHECKER) $(top_builddir)/testSchemas $$i $$j \
1034 > $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno" \
1035 2> $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno".err; \
1036 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1037 else \
1038 log=`$(CHECKER) $(top_builddir)/testSchemas $$i $$j \
1039 > res.$$name 2> err.$$name;\
1040 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1041 diff $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno" \
1042 res.$$name;\
1043 diff $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno".err \
1044 err.$$name;\
1045 grep Unimplemented err.$$name`; \
1046 if [ -n "$$log" ] ; then echo "$$name"_"$$sno"_"$$xno" result ; echo "$$log" ; fi ; \
1047 rm res.$$name err.$$name ; \
1048 fi ; fi ;\
1049 done; done)
1050
1051Relaxtests: xmllint$(EXEEXT)
1052 @(echo > .memdump)
1053 @echo "## Relax-NG regression tests"
1054 -@(for i in $(srcdir)/test/relaxng/*.rng ; do \
1055 name=`basename $$i | sed 's+\.rng++'`; \
1056 if [ ! -f $(srcdir)/result/relaxng/"$$name"_valid ] ; then \
1057 echo New schemas $$name ; \
1058 $(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $(srcdir)/test/relaxng/tutorA.rng $$i \
1059 > $(srcdir)/result/relaxng/"$$name"_valid \
1060 2> $(srcdir)/result/relaxng/"$$name"_err; \
1061 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1062 else \
1063 log=`$(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $(srcdir)/test/relaxng/tutorA.rng $$i \
1064 > res.$$name 2> err.$$name;\
1065 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1066 diff $(srcdir)/result/relaxng/"$$name"_valid \
1067 res.$$name;\
1068 diff $(srcdir)/result/relaxng/"$$name"_err \
1069 err.$$name | grep -v "error detected at";\
1070 grep Unimplemented err.$$name`; \
1071 if [ -n "$$log" ] ; then echo schemas $$name result ; echo "$$log" ; fi ; \
1072 rm res.$$name err.$$name ; \
1073 fi; \
1074 for j in $(srcdir)/test/relaxng/"$$name"_*.xml ; do \
1075 if [ -f $$j ] ; then \
1076 xno=`basename $$j | sed 's+.*_\(.*\).xml+\1+'`; \
1077 if [ ! -f $(srcdir)/result/relaxng/"$$name"_"$$xno" ]; \
1078 then \
1079 echo New test file "$$name"_"$$xno" ; \
1080 $(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $$i $$j \
1081 > $(srcdir)/result/relaxng/"$$name"_"$$xno" \
1082 2> $(srcdir)/result/relaxng/"$$name"_"$$xno".err; \
1083 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1084 else \
1085 log=`$(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $$i $$j \
1086 > res.$$name 2> err.$$name;\
1087 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1088 diff $(srcdir)/result/relaxng/"$$name"_"$$xno" \
1089 res.$$name;\
1090 diff $(srcdir)/result/relaxng/"$$name"_"$$xno".err \
1091 err.$$name | grep -v "error detected at";\
1092 grep Unimplemented err.$$name`; \
1093 if [ -n "$$log" ] ; then echo "$$name"_"$$xno" result ; echo "$$log" ; fi ; \
1094 rm res.$$name err.$$name ; \
1095 fi ; fi ; \
1096 done; done)
1097 @echo "## Relax-NG streaming regression tests"
1098 -@(for i in $(srcdir)/test/relaxng/*.rng ; do \
1099 name=`basename $$i | sed 's+\.rng++'`; \
1100 for j in $(srcdir)/test/relaxng/"$$name"_*.xml ; do \
1101 if [ -f $$j ] ; then \
1102 xno=`basename $$j | sed 's+.*_\(.*\).xml+\1+'`; \
1103 if [ ! -f $(srcdir)/result/relaxng/"$$name"_"$$xno" ]; \
1104 then \
1105 echo New test file "$$name"_"$$xno" ; \
1106 $(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $$i $$j \
1107 > $(srcdir)/result/relaxng/"$$name"_"$$xno" \
1108 2> $(srcdir)/result/relaxng/"$$name"_"$$xno".err; \
1109 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1110 else \
1111 log=`$(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --stream --relaxng $$i $$j \
1112 > res.$$name 2> err.$$name;\
1113 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1114 diff $(srcdir)/result/relaxng/"$$name"_"$$xno" res.$$name;\
1115 if [ "$$name" != "tutor10_1" -a "$$name" != "tutor10_2" -a "$$name" != "tutor3_2" -a "$$name" != "307377" -a "$$name" != "tutor8_2" ] ; then \
1116 diff $(srcdir)/result/relaxng/"$$name"_"$$xno".err \
1117 err.$$name | grep -v "error detected at";\
1118 fi ; grep Unimplemented err.$$name`; \
1119 if [ -n "$$log" ] ; then echo "$$name"_"$$xno" result ; echo "$$log" ; fi ; \
1120 rm res.$$name err.$$name ; \
1121 fi ; fi ; \
1122 done; done)
1123
1124Schematrontests: xmllint$(EXEEXT)
1125 @(echo > .memdump)
1126 @echo "## Schematron regression tests"
1127 -@(for i in $(srcdir)/test/schematron/*.sct ; do \
1128 name=`basename $$i | sed 's+\.sct++'`; \
1129 for j in $(srcdir)/test/schematron/"$$name"_*.xml ; do \
1130 if [ -f $$j ] ; then \
1131 xno=`basename $$j | sed 's+.*_\(.*\).xml+\1+'`; \
1132 if [ ! -f $(srcdir)/result/schematron/"$$name"_"$$xno" ]; \
1133 then \
1134 echo New test file "$$name"_"$$xno" ; \
1135 $(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --schematron $$i $$j \
1136 > $(srcdir)/result/schematron/"$$name"_"$$xno" \
1137 2> $(srcdir)/result/schematron/"$$name"_"$$xno".err; \
1138 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1139 else \
1140 log=`$(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --schematron $$i $$j \
1141 > res.$$name 2> err.$$name;\
1142 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1143 diff $(srcdir)/result/schematron/"$$name"_"$$xno" \
1144 res.$$name;\
1145 diff $(srcdir)/result/schematron/"$$name"_"$$xno".err \
1146 err.$$name | grep -v "error detected at";\
1147 grep Unimplemented err.$$name`; \
1148 if [ -n "$$log" ] ; then echo "$$name"_"$$xno" result ; echo "$$log" ; fi ; \
1149 rm res.$$name err.$$name ; \
1150 fi ; fi ; \
1151 done; done)
1152
1153RelaxNGPythonTests:
1154 @(if [ -x $(PYTHON) ] ; then \
1155 PYTHONPATH=$(top_builddir)/python:$(top_builddir)/python/.libs:$$PYTHONPATH ; \
1156 export PYTHONPATH; \
1157 LD_LIBRARY_PATH="$(top_builddir)/.libs:$$LD_LIBRARY_PATH" ; \
1158 export LD_LIBRARY_PATH; \
1159 echo "## Relax-NG Python based test suite 1" ; \
1160 $(CHECKER) $(PYTHON) $(srcdir)/check-relaxng-test-suite.py ; \
1161 echo "## Relax-NG Python based test suite 2" ; \
1162 $(CHECKER) $(PYTHON) $(srcdir)/check-relaxng-test-suite2.py ; \
1163 fi)
1164
1165SchemasPythonTests:
1166 @(if [ -x $(PYTHON) ] ; then \
1167 PYTHONPATH=$(top_builddir)/python:$(top_builddir)/python/.libs:$$PYTHONPATH; \
1168 export PYTHONPATH; \
1169 LD_LIBRARY_PATH="$(top_builddir)/.libs:$$LD_LIBRARY_PATH" ; \
1170 export LD_LIBRARY_PATH; \
1171 echo "## XML Schemas datatypes Python based test suite" ; \
1172 echo "## It is normal to see 11 errors reported" ; \
1173 $(CHECKER) $(PYTHON) $(srcdir)/check-xsddata-test-suite.py ; \
1174 fi)
1175 @(if [ -x $(PYTHON) -a -d xstc ] ; then cd xstc ; $(MAKE) CHECKER="$(CHECKER)" pytests ; fi)
1176
1177Patterntests: xmllint$(EXEEXT)
1178 @(echo > .memdump)
1179 @echo "## Pattern regression tests"
1180 -@(for i in $(srcdir)/test/pattern/*.pat ; do \
1181 name=`basename $$i .pat`; \
1182 if [ -f $(srcdir)/test/pattern/$$name.xml ] ; then \
1183 if [ ! -f $(srcdir)/result/pattern/$$name ] ; then \
1184 rm -f result.$$name ; \
1185 echo New test file $$name ; \
1186 for pat in `cat $$i` ; do \
1187 $(CHECKER) $(top_builddir)/xmllint --walker --pattern $$pat $(srcdir)/test/pattern/$$name.xml >> $(srcdir)/result/pattern/$$name ; \
1188 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1189 done ;\
1190 else \
1191 rm -f result.$$name ; \
1192 lst=`cat $$i` ; \
1193 log=`for pat in $$lst ; do $(CHECKER) $(top_builddir)/xmllint --walker --pattern $$pat $(srcdir)/test/pattern/$$name.xml 2>&1 >> result.$$name ; \
1194 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1195 done ;\
1196 diff $(srcdir)/result/pattern/$$name result.$$name` ; \
1197 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
1198 rm result.$$name ; \
1199 fi ; fi ; done ;)
1200
1201ModuleTests: testModule$(EXEEXT) testdso.la
1202 @echo "## Module tests"
1203 @(./testModule$(EXEEXT))
1204
1205cleanup:
1206 -@(find . -name .\#\* -exec rm {} \;)
1207 -@(find . -name \*.gcda -o -name \*.gcno -exec rm -f {} \;)
1208 -@(find . -name \*.orig -o -name \*.rej -o -name \*.old -exec rm -f {} \;)
1209
1210dist-hook: cleanup libxml2.spec
1211 -cp libxml2.spec $(distdir)
1212 (cd $(srcdir) ; tar -cf - --exclude .git win32 macos os400 vms VxWorks bakefile test result) | (cd $(distdir); tar xf -)
1213
1214dist-source: distdir
1215 $(AMTAR) -chof - --exclude Tests --exclude test --exclude result $(distdir) | GZIP=$(GZIP_ENV) gzip -c >`echo "$(distdir)" | sed "s+libxml2+libxml2-sources+"`.tar.gz
1216
1217dist-test: distdir
1218 (mkdir -p $(distdir))
1219 (cd $(srcdir) ; tar -cf - --exclude .git xstc/Tests) | (cd $(distdir); tar xf -)
1220 tar -cf - $(distdir)/test $(distdir)/result $(distdir)/xstc/Tests $(distdir)/Makefile.tests $(distdir)/README.md $(distdir)/README.tests $(distdir)/testapi.c $(distdir)/runtest.c $(distdir)/runsuite.c | GZIP=$(GZIP_ENV) gzip -c >`echo "$(distdir)" | sed "s+libxml2+libxml2-tests+"`.tar.gz
1221 @(rm -rf $(distdir)/xstc/Test)
1222
1223cleantar:
1224 @(rm -f libxml*.tar.gz COPYING.LIB)
1225
1226rpm: cleanup cleantar
1227 @(unset CDPATH ; $(MAKE) dist-source dist && rpmbuild -ta $(distdir).tar.gz)
1228
1229## We create xml2Conf.sh here and not from configure because we want
1230## to get the paths expanded correctly. Macros like srcdir are given
1231## the value NONE in configure if the user doesn't specify them (this
1232## is an autoconf feature, not a bug).
1233
1234xml2Conf.sh: xml2Conf.sh.in Makefile
1235## Use sed and then mv to avoid problems if the user interrupts.
1236 sed -e 's?\@XML_LIBDIR\@?$(XML_LIBDIR)?g' \
1237 -e 's?\@XML_INCLUDEDIR\@?$(XML_INCLUDEDIR)?g' \
1238 -e 's?\@VERSION\@?$(VERSION)?g' \
1239 -e 's?\@XML_LIBS\@?$(XML_LIBS)?g' \
1240 -e 's?\@XML_PRIVATE_LIBS\@?$(XML_PRIVATE_LIBS)?g' \
1241 < $(srcdir)/xml2Conf.sh.in > xml2Conf.tmp \
1242 && mv xml2Conf.tmp xml2Conf.sh
1243
1244CLEANFILES = runxmlconf.log test.out xml2Conf.sh *.gcda *.gcno *.res
1245DISTCLEANFILES = COPYING missing.lst
1246
1247confexecdir=$(libdir)
1248confexec_DATA = xml2Conf.sh
1249EXTRA_DIST = xml2-config.in xml2Conf.sh.in libxml.spec.in libxml2.spec \
1250 libxml.m4 Copyright check-xml-test-suite.py gentest.py \
1251 check-relaxng-test-suite.py check-relaxng-test-suite2.py \
1252 check-xsddata-test-suite.py check-xinclude-test-suite.py \
1253 example/Makefile.am example/gjobread.c example/gjobs.xml \
1254 $(man_MANS) libxml-2.0.pc.in libxml-2.0-uninstalled.pc.in \
1255 libxml2-config.cmake.in autogen.sh \
1256 trionan.c trionan.h triostr.c triostr.h trio.c trio.h \
1257 triop.h triodef.h libxml.h elfgcchack.h xzlib.h buf.h \
1258 enc.h save.h genUnicode.py TODO_SCHEMAS \
1259 dbgen.pl dbgenattr.pl regressions.py regressions.xml \
1260 README.tests Makefile.tests libxml2.syms timsort.h \
1261 README.zOS README.md \
1262 CMakeLists.txt config.h.cmake.in libxml2-config.cmake.cmake.in
1263
1264
1265pkgconfigdir = $(libdir)/pkgconfig
1266pkgconfig_DATA = libxml-2.0.pc
1267
1268cmakedir = $(libdir)/cmake/libxml2
1269cmake_DATA = libxml2-config.cmake
1270
1271#
1272# Install the tests program sources as examples
1273#
1274EXAMPLES_DIR=$(docdir)/examples
1275
1276install-data-local:
1277 $(MKDIR_P) $(DESTDIR)$(docdir)
1278 -$(INSTALL) -m 0644 $(srcdir)/Copyright $(DESTDIR)$(docdir)
1279 $(MKDIR_P) $(DESTDIR)$(EXAMPLES_DIR)
1280 -$(INSTALL) -m 0644 $(srcdir)/xmllint.c $(DESTDIR)$(EXAMPLES_DIR)
1281 -$(INSTALL) -m 0644 $(srcdir)/testSAX.c $(DESTDIR)$(EXAMPLES_DIR)
1282 -$(INSTALL) -m 0644 $(srcdir)/testHTML.c $(DESTDIR)$(EXAMPLES_DIR)
1283 -$(INSTALL) -m 0644 $(srcdir)/testXPath.c $(DESTDIR)$(EXAMPLES_DIR)
1284 @echo "If the documentation is installed, please also look at html/examples for more." > $(DESTDIR)$(EXAMPLES_DIR)/README
1285
1286uninstall-local:
1287 rm -f $(DESTDIR)$(EXAMPLES_DIR)/README
1288 rm -f $(DESTDIR)$(EXAMPLES_DIR)/testXPath.c
1289 rm -f $(DESTDIR)$(EXAMPLES_DIR)/testHTML.c
1290 rm -f $(DESTDIR)$(EXAMPLES_DIR)/testSAX.c
1291 rm -f $(DESTDIR)$(EXAMPLES_DIR)/xmllint.c
1292 rm -rf $(DESTDIR)$(EXAMPLES_DIR)
1293 rm -f $(DESTDIR)$(docdir)/Copyright
1294 rm -rf $(DESTDIR)$(docdir)
1295
1296tst: tst.c
1297 $(CC) $(CFLAGS) -Iinclude -o tst tst.c .libs/libxml2.a -lpthread -lm -lz -llzma
1298
1299sparse: clean
1300 $(MAKE) CC=cgcc
1301
1302#
1303# Coverage support, largely borrowed from libvirt
1304# Both binaries comes from the lcov package in Fedora
1305#
1306LCOV = /usr/bin/lcov
1307GENHTML = /usr/bin/genhtml
1308
1309cov: clean-cov
1310 if [ "`echo $(LDFLAGS) | grep coverage`" = "" ] ; then \
1311 echo not configured with coverage; exit 1 ; fi
1312 if [ ! -x $(LCOV) -o ! -x $(GENHTML) ] ; then \
1313 echo Need $(LCOV) and $(GENHTML) excecutables; exit 1 ; fi
1314 -@($(MAKE) check)
1315 -@(./runsuite$(EXEEXT))
1316 mkdir $(top_builddir)/coverage
1317 $(LCOV) -c -o $(top_builddir)/coverage/libxml2.info.tmp -d $(top_srcdir)
1318 $(LCOV) -r $(top_builddir)/coverage/libxml2.info.tmp -o $(top_builddir)/coverage/libxml2.info *usr*
1319 rm $(top_builddir)/coverage/libxml2.info.tmp
1320 $(GENHTML) -s -t "libxml2" -o $(top_builddir)/coverage --legend $(top_builddir)/coverage/libxml2.info
1321 echo "Coverage report is in $(top_builddir)/coverage/index.html"
1322
1323clean-cov:
1324 rm -rf $(top_builddir)/coverage
1325
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette