[XML-SIG] Wierd bug in DOM cloneNode (or copy.deepcopy)

Jeff.Johnson@stn.siemens.com Jeff.Johnson@stn.siemens.com
Tue, 27 Oct 1998 14:21:50 -0500


--0__=yExnkLfCGsa1EvhnwXSAAuTTNFW1JdjQ75rjhoLcpf6FiQ8gvGCLsUzV
Content-type: text/plain; charset=us-ascii
Content-Disposition: inline

I have been trying to figure out what is crashing the Python interpreter on
Windows NT when I ran across a strange bug.  My python program runs fine on
Win 98 but will crash on NT 4.0.  It may take a few hours of running, but
eventually it crashes.  I was hoping that if I could create a small test
file to reproduce the problem, I could get Guido to look into it.  So... I
took my DOM test file and put in an infinite loop to see if it would crash
on NT.  When I did, I noticed that __del__() is called more than __init__()
on xml.dom.core._nodeData when cloneNode() is used.  I don't know what kind
of wierd voodoo happens in the copy.deepcopy() function but it looks like
it messes up the reference counts somehow.

That leads to a question about Python, how stable is the memory management?
Should I be surprised that it runs forever on Win98 but not on WinNT?  Does
copy.deepcopy do things it should not?

Good news! While I was writing this, my test file did crash the interpreter
on NT.  I'll comment out the cloneNode line and try again.  Then I'm going
to load NT service pack 4 and try again.  The exception was in malloc().  I
think I might have been out of memory.  That's strange, if __del__ gets
called too many times, I would think the exception would be in free().
Anyone feel like figuring this one out?


(See attached file: test.py)




--0__=yExnkLfCGsa1EvhnwXSAAuTTNFW1JdjQ75rjhoLcpf6FiQ8gvGCLsUzV
Content-type: application/octet-stream; 
	name="test.py"
Content-Disposition: attachment; filename="test.py"
Content-transfer-encoding: base64

IiIiVGhpcyB0ZXN0cyB0aGUgbmV3IFhNTCBET00gcGFja2FnZSBmb3IgY2lyY3VsYXIgcmVmZXJl
bmNlIG1lbW9yeSBsZWFrcy4NClRvIHVzZSBpdCwgY29kZSBtdXN0IGJlIGFkZGVkIHRvIGNvcmUu
Tm9kZSBhbmQgY29yZS5fbm9kZURhdGEgdG8gaW5jcmVtZW50DQpOb2RlX2NvdW50ZXIgaW4gX19p
bml0X18gYW5kIGRlY3JlbWVudCBpdCBpbiBfX2RlbF9fLiIiIg0KDQpmcm9tIHhtbC5kb20gaW1w
b3J0IGNvcmUNCmZyb20geG1sLmRvbS5zYXhfYnVpbGRlciBpbXBvcnQgU2F4QnVpbGRlcg0KZnJv
bSB4bWwuc2F4IGltcG9ydCBzYXhleHRzDQpmcm9tIHhtbC5kb20ud3JpdGVyIGltcG9ydCBIdG1s
V3JpdGVyDQoNCg0KZGVmIGNoZWNrTWVtKG1zZyk6DQoJaWYgY29yZS5Ob2RlLk5vZGVfY291bnRl
ciBvciBjb3JlLl9ub2RlRGF0YS5Ob2RlX2NvdW50ZXI6DQoJCWlmIG1zZzogcHJpbnQgJyMjIyMj
IyMjIyMjIyMjIyMjIycsbXNnLCcjIyMjIyMjIyMjIyMjIyMjIyMnDQoJCXByaW50ICJFcnJvcjog
JWQgTm9kZXMgYW5kICVkIF9ub2RlRGF0YXMgd2VyZSBub3QgZGVsZXRlZCIgJSBcDQoJCQkoY29y
ZS5Ob2RlLk5vZGVfY291bnRlcixjb3JlLl9ub2RlRGF0YS5Ob2RlX2NvdW50ZXIpDQoNCmRlZiB0
ZXN0MSgpOg0KCXByaW50ICc9PT09PT09PT09PT09PT09PT0gdGVzdDEgPT09PT09PT09PT09PT09
PT09Jw0KCWRvYyA9IGNvcmUuY3JlYXRlRG9jdW1lbnQoKQ0KCWRvYyA9IE5vbmUNCgljaGVja01l
bSgndGVzdDEgZmFpbGVkJykNCg0KCQ0KZGVmIHRlc3QyKCk6DQoJcHJpbnQgJz09PT09PT09PT09
PT09PT09PSB0ZXN0MiA9PT09PT09PT09PT09PT09PT0nDQoJZG9jID0gY29yZS5jcmVhdGVEb2N1
bWVudCgpDQoJaHRtbCA9IGRvYy5jcmVhdGVFbGVtZW50KCdodG1sJykNCiMJYm9keSA9IGRvYy5j
cmVhdGVFbGVtZW50KCdib2R5JykNCiMJaHRtbC5pbnNlcnRCZWZvcmUoYm9keSxOb25lKQ0KIwlo
dG1sLmluc2VydEJlZm9yZShib2R5LE5vbmUpDQoJZG9jID0gTm9uZQ0KIwlib2R5ID0gTm9uZQ0K
CWh0bWwgPSBOb25lDQoJY2hlY2tNZW0oJ3Rlc3QyIGZhaWxlZCcpDQoJDQpkZWYgdGVzdDMoKToN
CglwcmludCAnPT09PT09PT09PT09PT09PT09IHRlc3QzID09PT09PT09PT09PT09PT09PScNCglk
b2MgPSBjb3JlLmNyZWF0ZURvY3VtZW50KCkNCglodG1sID0gZG9jLmNyZWF0ZUVsZW1lbnQoJ2h0
bWwnKQ0KIwlkb2MuZG9jdW1lbnRFbGVtZW50ID0gaHRtbAkJIyB0aGlzIGRvZXMgbm90IGR1cGxp
Y2F0ZSBodG1sIGVsZW1lbnQNCiMJZG9jLmRvY3VtZW50RWxlbWVudCA9IE5vbmUNCglkb2MgPSBO
b25lDQoJaHRtbCA9IE5vbmUNCgljaGVja01lbSgndGVzdDMgZmFpbGVkJykNCg0KZGVmIHRlc3Q0
KCk6DQoJcHJpbnQgJz09PT09PT09PT09PT09PT09PSB0ZXN0NCA9PT09PT09PT09PT09PT09PT0n
DQoJZG9jID0gY29yZS5jcmVhdGVEb2N1bWVudCgpDQoJaHRtbCA9IGRvYy5jcmVhdGVFbGVtZW50
KCdodG1sJykNCglodG1sLmluc2VydEJlZm9yZShkb2MuY3JlYXRlRWxlbWVudCgnYm9keScpLE5v
bmUpDQoJZG9jLmFwcGVuZENoaWxkKGh0bWwpDQoJZG9jLmluc2VydEJlZm9yZShodG1sLE5vbmUp
DQoJI2RvYy5kb2N1bWVudEVsZW1lbnQgPSBOb25lDQoJZG9jID0gTm9uZQ0KCWh0bWwgPSBOb25l
DQoJY2hlY2tNZW0oJ3Rlc3Q0IGZhaWxlZCcpDQoNCmRlZiB0ZXN0NSgpOg0KCXByaW50ICc9PT09
PT09PT09PT09PT09PT0gdGVzdDUgPT09PT09PT09PT09PT09PT09Jw0KCWRlZiB0ZXN0NWEoKToN
CgkJcCA9IHNheGV4dHMubWFrZV9wYXJzZXIoKQ0KCQlkaCA9IFNheEJ1aWxkZXIoKQ0KCQlwLnNl
dERvY3VtZW50SGFuZGxlcihkaCkNCgkJcC5mZWVkKCc8SFRNTD48SEVBRC8+PC9IVE1MPicpDQoJ
CWRvYyA9IGRoLmRvY3VtZW50DQoJCXAuc2V0RG9jdW1lbnRIYW5kbGVyKE5vbmUpDQoJCSNwLmNs
b3NlKCkNCg0KCXRlc3Q1YSgpDQoJY2hlY2tNZW0oJ3Rlc3Q1IGZhaWxlZCcpDQoNCmRlZiB0ZXN0
NigpOg0KCSIiIlRoaXMgd2lsbCB0ZXN0IGlmIHBhcnNlci5jbG9zZSgpIGNsZWFucyB1cCB0aGUg
Y2lyY3VsYXINCglyZWZlcmVuY2VzIGluIHBhcnNlci4iIiINCglwcmludCAnPT09PT09PT09PT09
PT09PT09IHRlc3Q2ID09PT09PT09PT09PT09PT09PScNCglkZWYgdGVzdDZhKCk6DQoJCXAgPSBz
YXhleHRzLm1ha2VfcGFyc2VyKCkNCgkJZGggPSBTYXhCdWlsZGVyKCkNCgkJcC5zZXREb2N1bWVu
dEhhbmRsZXIoZGgpDQoJCXAuZmVlZCgnPEhUTUw+PEhFQUQvPjwvSFRNTD4nKQ0KCQlkb2MgPSBk
aC5kb2N1bWVudA0KCQkjcC5zZXREb2N1bWVudEhhbmRsZXIoTm9uZSkNCgkJcC5jbG9zZSgpDQoN
Cgl0ZXN0NmEoKQ0KCWNoZWNrTWVtKCd0ZXN0NiBmYWlsZWQnKQ0KCQ0KZGVmIHRlc3Q3KCk6DQoJ
IiIiSWYgZ2V0RWxlbWVudHNCeVRhZ05hbWUoKSBjaGVja3MgaXRzZWxmIGFzIHdlbGwgYXMgZGVz
Y2VuZGFudHMNCgl0aGVuIHRoaXMgd2lsbCBwcmludCB0d28gSEVBRCBvYmplY3RzIGluc3RlYWQg
b2Ygb25lLiIiIg0KCXByaW50ICc9PT09PT09PT09PT09PT09PT0gdGVzdDcgPT09PT09PT09PT09
PT09PT09Jw0KCXAgPSBzYXhleHRzLm1ha2VfcGFyc2VyKCkNCglkaCA9IFNheEJ1aWxkZXIoKQ0K
CXAuc2V0RG9jdW1lbnRIYW5kbGVyKGRoKQ0KCXhtbCA9ICIiIg0KCTxIVE1MPg0KCTxIRUFEPg0K
CTwvSEVBRD4NCgk8L0hUTUw+DQoJIiIiDQoJcC5mZWVkKHhtbCkNCglkb2MgPSBkaC5kb2N1bWVu
dA0KCXAuc2V0RG9jdW1lbnRIYW5kbGVyKE5vbmUpDQoJI3AuY2xvc2UoKQ0KCWwgPSBkb2MuZ2V0
RWxlbWVudHNCeVRhZ05hbWUoJ0hFQUQnKQ0KCWlmIGxlbihsKSAhPSAxOg0KCQlwcmludCBsDQoJ
CXByaW50ICcjIyMjIyMjIyMjIyMjIyMjIyMnLCd0ZXN0NyBmYWlsZWQnLCcjIyMjIyMjIyMjIyMj
IyMjIyMnDQoNCgkNCmRlZiB0ZXN0OCgpOg0KCSIiIlRlc3RpbmcgeG1sLmRvbS5jb3JlLkVsZW1l
bnQuY2xvbmVOb2RlKCkiIiINCglwcmludCAnPT09PT09PT09PT09PT09PT09IHRlc3Q4ID09PT09
PT09PT09PT09PT09PScNCgkNCglkb2MgPSBjb3JlLmNyZWF0ZURvY3VtZW50KCkNCglodG1sID0g
ZG9jLmNyZWF0ZUVsZW1lbnQoJ2h0bWwnKQ0KCWJvZHkgPSBkb2MuY3JlYXRlRWxlbWVudCgnYm9k
eScpDQoJdWwgPSBkb2MuY3JlYXRlRWxlbWVudCgnVUwnKQ0KCWxpID0gZG9jLmNyZWF0ZUVsZW1l
bnQoJ0xJJykNCg0KDQoJZG9jLmFwcGVuZENoaWxkKGh0bWwpDQoJaHRtbC5hcHBlbmRDaGlsZChi
b2R5KQ0KCWJvZHkuYXBwZW5kQ2hpbGQodWwpDQoJdWwuYXBwZW5kQ2hpbGQobGkpDQoNCgkjIFRo
aXMgaXMgY2F1c2luZyBfbm9kZURhdGEgdG8gZ2V0IGZyZWVkIHR3aWNlPw0KCXVsMiA9IHVsLmNs
b25lTm9kZSgxKQ0KCWJvZHkuYXBwZW5kQ2hpbGQodWwyKQ0KDQoJcHJpbnQgZG9jLnRveG1sKCkN
Cg0KDQpkZWYgdGVzdDkoKToNCgkiIiJUZXN0aW5nIEh0bWxXcml0ZXIiIiINCglwcmludCAnPT09
PT09PT09PT09PT09PT09IHRlc3Q5ID09PT09PT09PT09PT09PT09PScNCgkNCglkb2MgPSBjb3Jl
LmNyZWF0ZURvY3VtZW50KCkNCglodG1sID0gZG9jLmNyZWF0ZUVsZW1lbnQoJ2h0bWwnKQ0KCWJv
ZHkgPSBkb2MuY3JlYXRlRWxlbWVudCgnYm9keScpDQoJdWwgPSBkb2MuY3JlYXRlRWxlbWVudCgn
VUwnKQ0KCWxpID0gZG9jLmNyZWF0ZUVsZW1lbnQoJ0xJJykNCg0KCWRvYy5hcHBlbmRDaGlsZCho
dG1sKQ0KCWh0bWwuYXBwZW5kQ2hpbGQoYm9keSkNCglib2R5LmFwcGVuZENoaWxkKHVsKQ0KCXVs
LmFwcGVuZENoaWxkKGxpKQ0KDQoJdyA9IEh0bWxXcml0ZXIoKQ0KCXcud3JpdGUoZG9jKQ0KDQoJ
cCA9IHNheGV4dHMubWFrZV9wYXJzZXIoKQ0KCWRoID0gU2F4QnVpbGRlcigpDQoJcC5zZXREb2N1
bWVudEhhbmRsZXIoZGgpDQoJeG1sID0gIiIiDQoJCTxkb2Nfc2V0IHRpdGxlPSJFV1NEIFJlbGVh
c2UgMTUiIGlkPSJld3NkMTUiPg0KCQk8ZG9jX2lzc3VlIGJvb2s9IjAyMTAiIGlzc3VlPSJoMiIg
ZG9jdW1lbnQ9IjAwMDEwIi8+DQoJCTxkb2NfaXNzdWUgYm9vaz0iMDIxMCIgaXNzdWU9ImwyIiBk
b2N1bWVudD0iMDAwMjAiLz4NCgkJPGRvY19pc3N1ZSBib29rPSIwMjEwIiBpc3N1ZT0iZzEiIGRv
Y3VtZW50PSIwMDAzMCIvPg0KCQk8L2RvY19zZXQ+DQoJCSIiIg0KCXAuZmVlZCh4bWwpDQoJZG9j
ID0gZGguZG9jdW1lbnQNCglwLnNldERvY3VtZW50SGFuZGxlcihOb25lKQ0KCXcud3JpdGUoZG9j
KQ0KDQoNCiNpZiBfX25hbWVfXyA9PSAnX19tYWluX18nOg0Kd2hpbGUgMToNCgl0ZXN0MSgpDQoJ
dGVzdDIoKQ0KCXRlc3QzKCkNCgl0ZXN0NCgpDQoJdGVzdDUoKQ0KCXRlc3Q2KCkNCgl0ZXN0Nygp
DQoJY2hlY2tNZW0oJ3Rlc3Q3IGZhaWxlZCcpDQoJdGVzdDgoKQ0KCWNoZWNrTWVtKCd0ZXN0OCBm
YWlsZWQnKQ0KCXRlc3Q5KCkNCgljaGVja01lbSgndGVzdDkgZmFpbGVkJykNCg==

--0__=yExnkLfCGsa1EvhnwXSAAuTTNFW1JdjQ75rjhoLcpf6FiQ8gvGCLsUzV--