Daniel Veillard | e6227e0 | 2003-01-14 11:42:39 +0000 | [diff] [blame] | 1 | #!/usr/bin/python -u |
| 2 | # |
| 3 | # This test exercise the redirection of error messages with a |
| 4 | # functions defined in Python. |
| 5 | # |
| 6 | import sys |
| 7 | import libxml2 |
| 8 | |
| 9 | # Memory debug specific |
| 10 | libxml2.debugMemory(1) |
| 11 | |
Daniel Veillard | 417be3a | 2003-01-20 21:26:34 +0000 | [diff] [blame] | 12 | expect="""--> (3) xmlns: URI foo is not absolute |
Daniel Veillard | 6c5b2d3 | 2003-03-27 14:55:52 +0000 | [diff] [blame^] | 13 | --> (4) Opening and ending tag mismatch: x line 0 and y |
Daniel Veillard | e6227e0 | 2003-01-14 11:42:39 +0000 | [diff] [blame] | 14 | """ |
| 15 | |
| 16 | err="" |
Daniel Veillard | 417be3a | 2003-01-20 21:26:34 +0000 | [diff] [blame] | 17 | def callback(arg,msg,severity,reserved): |
| 18 | global err |
| 19 | err = err + "%s (%d) %s" % (arg,severity,msg) |
Daniel Veillard | e6227e0 | 2003-01-14 11:42:39 +0000 | [diff] [blame] | 20 | |
Daniel Veillard | 417be3a | 2003-01-20 21:26:34 +0000 | [diff] [blame] | 21 | s = """<x xmlns="foo"></y>""" |
Daniel Veillard | e6227e0 | 2003-01-14 11:42:39 +0000 | [diff] [blame] | 22 | |
| 23 | parserCtxt = libxml2.createPushParser(None,"",0,"test.xml") |
Daniel Veillard | 417be3a | 2003-01-20 21:26:34 +0000 | [diff] [blame] | 24 | parserCtxt.setErrorHandler(callback, "-->") |
| 25 | if parserCtxt.getErrorHandler() != (callback,"-->"): |
| 26 | print "getErrorHandler failed" |
| 27 | sys.exit(1) |
Daniel Veillard | e6227e0 | 2003-01-14 11:42:39 +0000 | [diff] [blame] | 28 | parserCtxt.parseChunk(s,len(s),1) |
| 29 | doc = parserCtxt.doc() |
| 30 | doc.freeDoc() |
| 31 | parserCtxt = None |
| 32 | |
| 33 | if err != expect: |
| 34 | print "error" |
| 35 | print "received %s" %(err) |
| 36 | print "expected %s" %(expect) |
| 37 | sys.exit(1) |
| 38 | |
| 39 | i = 10000 |
| 40 | while i > 0: |
| 41 | parserCtxt = libxml2.createPushParser(None,"",0,"test.xml") |
Daniel Veillard | 417be3a | 2003-01-20 21:26:34 +0000 | [diff] [blame] | 42 | parserCtxt.setErrorHandler(callback, "-->") |
Daniel Veillard | e6227e0 | 2003-01-14 11:42:39 +0000 | [diff] [blame] | 43 | parserCtxt.parseChunk(s,len(s),1) |
| 44 | doc = parserCtxt.doc() |
| 45 | doc.freeDoc() |
| 46 | parserCtxt = None |
| 47 | err = "" |
| 48 | i = i - 1 |
| 49 | |
| 50 | # Memory debug specific |
| 51 | libxml2.cleanupParser() |
| 52 | if libxml2.debugMemory(1) == 0: |
| 53 | print "OK" |
| 54 | else: |
| 55 | print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |
| 56 | libxml2.dumpMemory() |