diff options
| author | Igor Pashev <pashev.igor@gmail.com> | 2015-10-19 15:37:26 +0300 |
|---|---|---|
| committer | Igor Pashev <pashev.igor@gmail.com> | 2015-10-19 15:37:26 +0300 |
| commit | 6c6e567eb34ad0f5a3bd90f6585c521543106401 (patch) | |
| tree | 7f8dc62f12dd2b720ffdc738d393cd1a8f82921c /python/tests/error.py | |
| parent | 7421ae696c1ef2fb48adc73ba8564ef2f276d618 (diff) | |
| parent | 218d404f34d79a8837f9c0230dd9d9f1180b4068 (diff) | |
| download | libxml2-pristine-tar.tar.gz | |
Merge branch 'pristine-tar' of git://anonscm.debian.org/debian-xml-sgml/libxml2 into pristine-tarpristine-tar
Diffstat (limited to 'python/tests/error.py')
| -rwxr-xr-x | python/tests/error.py | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/python/tests/error.py b/python/tests/error.py new file mode 100755 index 0000000..530c2ee --- /dev/null +++ b/python/tests/error.py @@ -0,0 +1,51 @@ +#!/usr/bin/python -u +# +# This test exercise the redirection of error messages with a +# functions defined in Python. +# +import sys +import libxml2 + +# Memory debug specific +libxml2.debugMemory(1) + +expect='--> I/O --> warning : --> failed to load external entity "missing.xml"\n' +err="" +def callback(ctx, str): + global err + + err = err + "%s %s" % (ctx, str) + +got_exc = 0 +libxml2.registerErrorHandler(callback, "-->") +try: + doc = libxml2.parseFile("missing.xml") +except libxml2.parserError: + got_exc = 1 + +if got_exc == 0: + print("Failed to get a parser exception") + sys.exit(1) + +if err != expect: + print("error") + print("received %s" %(err)) + print("expected %s" %(expect)) + sys.exit(1) + +i = 10000 +while i > 0: + try: + doc = libxml2.parseFile("missing.xml") + except libxml2.parserError: + got_exc = 1 + err = "" + i = i - 1 + +# Memory debug specific +libxml2.cleanupParser() +if libxml2.debugMemory(1) == 0: + print("OK") +else: + print("Memory leak %d bytes" % (libxml2.debugMemory(1))) + libxml2.dumpMemory() |
