def test_noattr(self):
    tree = {
      'attr1'  : 'value1',
      'attr2'  : 'value2',
      'nest'   : ['one', 'two', 'three']
      }
    expected = \
'''<root>
  <attr1>value1</attr1>
  <attr2>value2</attr2>
  <nest>one</nest>
  <nest>two</nest>
  <nest>three</nest>
</root>
'''
    xml = XMLout(tree, {'noattr':1})
    self.assertEqual(xml, expected)

    tree = { 'number' : {
      'twenty one' : { 'dec' : 21, 'hex' : '0x15' },
      'thirty two' : { 'dec' : 32, 'hex' : '0x20' }
      }}
    xml = XMLout(tree, {'noattr':1, 'keyattr':['word']})
    xml = re.sub(r'\s*<(dec)>21</\1>\s*', '21', xml)
    xml = re.sub(r'\s*<(hex)>0x15</\1>\s*', '21', xml)
    xml = re.sub(r'\s*<(word)>twenty one</\1>\s*', '21', xml)
    xml = re.sub(r'\s*<(number)>212121</\1>\s*', 'NUM', xml)
    xml = re.sub(r'\s*<(dec)>32</\1>\s*', '32', xml)
    xml = re.sub(r'\s*<(hex)>0x20</\1>\s*', '32', xml)
    xml = re.sub(r'\s*<(word)>thirty two</\1>\s*', '32', xml)
    xml = re.sub(r'\s*<(number)>323232</\1>\s*', 'NUM', xml)

    self.assert_(re.match(r'^<(\w+)\s*>NUMNUM</\1>$', xml))
示例#2
0
    def test_keeproot(self):
        tree = {'seq': {'name': 'alpha', 'alpha': [1, 2, 3]}}
        xml1 = XMLout(tree, {'rootname': 'sequence'})
        xml2 = XMLout({'sequence': tree}, {'keeproot': 1})
        self.assertEqual(xml1, xml2)

        xml = XMLout(tree, {'keeproot': 1})
        match = re.search('root', xml)
        self.assertTrue(match == None)
  def test_rootname(self):
    xml = XMLout('scalar', {'rootname': 'TOM'})
    self.assert_(re.match('^\s*<TOM>scalar<\/TOM>\s*$', xml))

    tree = {'array': ['one', 'two', 'three']}
    xml = XMLout(tree, {'rootname': 'LARRY'})
    xml = re.sub(r'<array>one</array>\s*', '', xml)
    xml = re.sub(r'<array>two</array>\s*', '', xml)
    xml = re.sub(r'<array>three</array>\s*', '', xml)

    self.assert_(re.match(r'^<(LARRY)\s*>\s*<\/\1>\s*$', xml))
示例#4
0
    def test_xml_decl(self):
        tree = {"one": 1}
        xml = XMLout(tree, {"xmldecl": 1})
        no_header = xml.replace("<?xml version='1.0' standalone='yes'?>", "")
        self.assertTrue(xml != no_header)
        self.assert_(re.match(r'^\s*<root\s+one="1"\s*/>', no_header, re.VERBOSE))

        custom_header = "<?xml custom header ?>"
        xml = XMLout(tree, {"xmldecl": custom_header})
        no_header = xml.replace(custom_header, "")
        self.assertTrue(xml != no_header)
        self.assert_(re.match(r'^\s*<root\s+one="1"\s*/>', no_header, re.VERBOSE))
  def test_escape(self):
    tree = { 'a' : '<A>', 'b' : '"B"', 'c' : '&C&' }

    # check if xml is escaped 
    xml = XMLout(tree)
    self.assert_(re.search('a="&lt;A&gt;"', xml))
    self.assert_(re.search('b="&quot;B&quot;"', xml))
    self.assert_(re.search('c="&amp;C&amp;"', xml))

    # check escape off
    tree = { 'a' : '<A>', 'b' : '"B"', 'c' : ['&C&'] }
    xml = XMLout(tree, {'noescape':1})
    self.assert_(re.search(r'a="<A>"', xml))
    self.assert_(re.search(r'b=""B""', xml))
    self.assert_(re.search(r'<c>&C&</c>', xml))
示例#6
0
    def test_grouptags(self):
        tree = {'dirs': {'first': '/usr/bin', 'second': '/usr/local/bin'}}
        expected = \
    r'''^<(\w+)>\s*
    <dirs>\s*
      <dir
        (?:
          \s+first="/usr/bin"
         |\s+second="/usr/local/bin"
        ){2}\s*
      />\s*
    </dirs>\s*
  </\1>$
'''
        xml = XMLout(
            tree, {
                'grouptags': {
                    'dirs': 'dir'
                },
                'keyattr': {
                    'dir': 'name'
                },
                'contentkey': '-content'
            })
        self.assert_(re.match(expected, xml, re.VERBOSE))
 def test_circular_data(self):
   tree = {'a': '1'}
   tree['b'] = tree
   try:
     xml = XMLout(tree)
     self.fail('circular data is not detected')
   except:
     pass
示例#8
0
def save_as_xml(filename, data_dict):
    header = '<?xml version="1.0" encoding="utf-8" ?>'
    options = {"xmldecl": header, "rootname": "config"}
    try:
        converted = XMLout(data_dict, options)
    except Exception, Error:
        msg = "An error occured while converting the data: \n"
        msg = msg + str(Error)
        print Error
        return msg
示例#9
0
    def testNestedHash(self):
        tree = {'value': '555 1234', 'hash1': {'one': 1}, 'hash2': {'two': 2}}
        expected = \
    '''<root value="555 1234">
  <hash1 one="1" />
  <hash2 two="2" />
</root>
'''
        xml = XMLout(tree)
        self.assertEqual(xml, expected)
 def test_forld_a_nested_hash(self):
   tree = { 'country' : { 'England' : { 'capital' : 'London' }}}
   xml = XMLout(tree)
   expected = r'''
 ^\s*<(\w+)\s*>\s*
   (
    <country(\s*name="England"|\s*capital="London"){2}\s*/>\s*
   )
 </\1>$
 '''
   self.assert_(re.match(expected, xml, re.VERBOSE))
  def testAnonymousArray(self):
    tree = ['1', 'two', 'Ⅲ']
    expected = \
'''<root>
  <anon>1</anon>
  <anon>two</anon>
  <anon>Ⅲ</anon>
</root>
'''
    xml = XMLout(tree)
    self.assertEqual(xml, expected)
  def testSimmpleArray(self):
    tree = {'array' : ['one', 'two', 'three']}
    expect = \
'''<root>
  <array>one</array>
  <array>two</array>
  <array>three</array>
</root>
'''
    xml = XMLout(tree)
    self.assertEqual(xml, expect)
示例#13
0
    def test_complex_hash(self):
        tree = {
            'car': {
                'LW1804': {
                    'option': {
                        '9926543-1167': {
                            'key': 1,
                            'desc': 'Steering Wheel'
                        }
                    },
                    'id': 2,
                    'make': 'GM'
                },
                'SH6673': {
                    'option': {
                        '6389733317-12': {
                            'key': 2,
                            'desc': 'Electric Windows'
                        },
                        '3735498158-01': {
                            'key': 3,
                            'desc': 'Leather Seats'
                        },
                        '5776155953-25': {
                            'key': 4,
                            'desc': 'Sun Roof'
                        },
                    },
                    'id': 1,
                    'make': 'Ford'
                }
            }
        }

        xml = XMLout(tree, {'keyattr': {'car': 'license', 'option': 'pn'}})
        self.assert_(re.search('\s*make="GM"', xml))
        self.assert_(re.search('\s*id="2"', xml))
        self.assert_(re.search('\s*license="LW1804"', xml))
        self.assert_(re.search('\s*desc="Steering Wheel"', xml))
        self.assert_(re.search('\s*pn="9926543-1167"', xml))
        self.assert_(re.search('\s*key="1"', xml))
        self.assert_(re.search('\s*make="Ford"', xml))
        self.assert_(re.search('\s*id="1"', xml))
        self.assert_(re.search('\s*license="SH6673"', xml))
        self.assert_(re.search('\s*desc="Electric Windows"', xml))
        self.assert_(re.search('\s*pn="6389733317-12"', xml))
        self.assert_(re.search('\s*key="2"', xml))
        self.assert_(re.search('\s*desc="Leather Seats"', xml))
        self.assert_(re.search('\s*pn="3735498158-01"', xml))
        self.assert_(re.search('\s*key="3"', xml))
        self.assert_(re.search('\s*desc="Sun Roof"', xml))
        self.assert_(re.search('\s*pn="5776155953-25"', xml))
        self.assert_(re.search('\s*key="4"', xml))
  def test_valueattr(self):
    tree = { 'one' : 1, 'two' : 2, 'six' : 6 };
    expected = \
'''^<root\s+two="2"\s*>
      (
        \s*<one\s+value="1"\s*/>
      | \s*<six\s+num="6"\s*/>
      ){2}
    \s*</root>$
'''
    xml = XMLout(tree, {'ValueAttr' : { 'one' : 'value', 'six' : 'num' }})
    self.assert_(re.match(expected, xml, re.VERBOSE))
  def testHashOfHash(self):
    tree = { 'country' : {
      'England' : { 'capital' : 'London' },
      'France'  : { 'capital' : 'Paris' },
      'Turkey'  : { 'capital' : 'Istanbul' },
      }}
    expected = \
'''<root>
  <country>
    <England capital="London" />
    <France capital="Paris" />
    <Turkey capital="Istanbul" />
  </country>
</root>
'''
    xml = XMLout(tree, {'keyattr':[]})
    self.assertEqual(xml, expected)

    expected = r'''
^\s*<(\w+)\s*>\s*
(
   <country(\s*fullname="Turkey"  |\s*capital="Istanbul" ){2}\s*/>\s*
  |<country(\s*fullname="France"  |\s*capital="Paris"    ){2}\s*/>\s*
  |<country(\s*fullname="England" |\s*capital="London"   ){2}\s*/>\s*
){3}
</\1>\s*$
'''
    xml = XMLout(tree, {'keyattr':['fullname']})
    self.assert_(re.match(expected, xml, re.VERBOSE))

    xml = XMLout(tree, {'keyattr':'fullname'})
    self.assert_(re.match(expected, xml, re.VERBOSE))

    xml = XMLout(tree, {'keyattr':{'country':'fullname'}})
    self.assert_(re.match(expected, xml, re.VERBOSE))

    xml = XMLout(tree, {'keyattr':{'country':'+fullname'}})
    self.assert_(re.match(expected, xml, re.VERBOSE))

    xml = XMLout(tree, {'keyattr':{'country':'-fullname'}})
    self.assert_(re.match(expected, xml, re.VERBOSE))

    expected = r'''
  ^\s*<(\w+)\s*>\s*
    (
      <country(\s*name="Turkey"|\s*capital="Istanbul"){2}\s*/>\s*
     |<country(\s*name="France"|\s*capital="Paris"){2}\s*/>\s*
     |<country(\s*name="England"|\s*capital="London"){2}\s*/>\s*
    ){3}
  </\1>$
  '''
    xml = XMLout(tree)
    self.assert_(re.match(expected, xml, re.VERBOSE))
  def test_grouptag(self):
    tree = {
      'prefix' : 'before',
      'dirs'   : [ '/usr/bin', '/usr/local/bin' ],
      'suffix' : 'after',
      }
    expected = \
'''<root>
  <dirs>
    <dir>/usr/bin</dir>
    <dir>/usr/local/bin</dir>
  </dirs>
  <prefix>before</prefix>
  <suffix>after</suffix>
</root>
'''
    xml = XMLout(tree, {'grouptags' : {'dirs' : 'dir'}, 'noattr' : 1})
    self.assertEqual(xml, expected)

    try:
      xml = XMLout(tree, {'grouptags' : {'dirs' : 'dirs'}, 'noattr' : 1})
      fail('cant detect invalid group tag')
    except:
      self.assertTrue(True)
  def testNestedAnonymousArray(self):
    tree = [[1.1, 1.2], [2.1, 2.2]]
    expected = \
'''<root>
  <anon>
    <anon>1.1</anon>
    <anon>1.2</anon>
  </anon>
  <anon>
    <anon>2.1</anon>
    <anon>2.2</anon>
  </anon>
</root>
'''
    xml = XMLout(tree)
    self.assertEqual(xml, expected)
  def test_xml_decl(self):
    tree = { 'one' : 1 }
    xml = XMLout(tree, {'xmldecl':1})
    no_header = xml.replace("<?xml version='1.0' standalone='yes'?>", '')
    self.assertTrue(xml != no_header)
    self.assert_(re.match(r'^\s*<root\s+one="1"\s*/>', no_header, re.VERBOSE))

    custom_header = '<?xml custom header ?>'
    xml = XMLout(tree, {'xmldecl':custom_header})
    no_header = xml.replace(custom_header, '')
    self.assertTrue(xml != no_header)
    self.assert_(re.match(r'^\s*<root\s+one="1"\s*/>', no_header, re.VERBOSE))
for ds_mor, name in server.get_datastores().items():
    props = VIProperty(server, ds_mor)
    name = props.info.name
    id = ""
    try:
        id = unicode(props.info.vmfs.extent[0].diskName.replace("naa.", ""))
        logging.debug("Evaluating VMware DS: " + name + " with ID: " + id)
        logging.debug("Looking for match in the LUNs table")
        if id in LUNs:
            LUNs[id]["VMwareName"] = name
            LUNs[id]["VMwareMOR"] = ds_mor
            logging.info("Mapped " + LUNs[id]['VPLEXName'] + " to " + name +
                         " as " + id)
            LUNs[id]["VirtualMachines"] = []
            logging.debug("Adding LUNs from DS list:")
            logging.debug(DSs[name])
            LUNs[id]["VirtualMachines"].extend(DSs[name])
        else:
            logging.debug("Not Found - no mapping performed")
    except AttributeError:
        logging.debug("Datastore " + name +
                      " is not a VMFS (NFS or Local CDROM?)")
server.disconnect()

wholeXML = XMLout(LUNs)

logging.debug(wholeXML)
f = open(config.get("OTHER", "outputfile"), 'w')
f.write(wholeXML)
f.close()
 def testScalar(self):
   xml = XMLout('scalar')
   self.assertEqual(XMLin(xml), 'scalar')
 def testHash(self):
   hash1 = {'one': '1', 'two': 'II', 'three': '...'}
   xml = XMLout(hash1)
   self.assertEqual(XMLin(xml), hash1)
 def test_contentkey(self):
   tree = { 'one' : 1, 'content' : 'text' }
   xml = XMLout(tree)
   expected = '^\s*<root\s+one="1">text</root>\s*$'
   self.assert_(re.match(expected, xml, re.VERBOSE))