? GR0V Shell

GR0V shell

Linux server122.web-hosting.com 4.18.0-513.18.1.lve.el8.x86_64 #1 SMP Thu Feb 22 12:55:50 UTC 2024 x86_64

Path : /opt/cpanel/ea-libxml2/share/doc/libxml2/python/examples/
File Upload :
Current File : //opt/cpanel/ea-libxml2/share/doc/libxml2/python/examples/compareNodes.py

#!/usr/bin/env python3
import sys
import setup_test
import libxml2

# Memory debug specific
libxml2.debugMemory(1)

#
# Testing XML Node comparison and Node hash-value
#
doc = libxml2.parseDoc("""<root><foo/></root>""")
root = doc.getRootElement()

# Create two different objects which point to foo
foonode1 = root.children
foonode2 = root.children

# Now check that [in]equality tests work ok
if not ( foonode1 == foonode2 ):
    print("Error comparing nodes with ==, nodes should be equal but are unequal")
    sys.exit(1)
if not ( foonode1 != root ):
    print("Error comparing nodes with ==, nodes should not be equal but are equal")
    sys.exit(1)
if not ( foonode1 != root ):
    print("Error comparing nodes with !=, nodes should not be equal but are equal")
if ( foonode1 != foonode2 ):
    print("Error comparing nodes with !=, nodes should be equal but are unequal")

# Next check that the hash function for the objects also works ok
if not (hash(foonode1) == hash(foonode2)):
    print("Error hash values for two equal nodes are different")
    sys.exit(1)
if not (hash(foonode1) != hash(root)):
    print("Error hash values for two unequal nodes are not different")
    sys.exit(1)
if hash(foonode1) == hash(root):
    print("Error hash values for two unequal nodes are equal")
    sys.exit(1)

# Basic tests successful
doc.freeDoc()

# Memory debug specific
libxml2.cleanupParser()
if libxml2.debugMemory(1) == 0:
    print("OK")
else:
    print("Memory leak %d bytes" % (libxml2.debugMemory(1)))

T1KUS90T
  root-grov@198.54.114.191:~$