diff options
author | Jauhien Piatlicki (jauhien) <piatlicki@gmail.com> | 2013-06-30 21:52:17 +0200 |
---|---|---|
committer | Jauhien Piatlicki (jauhien) <piatlicki@gmail.com> | 2013-06-30 21:52:17 +0200 |
commit | e2456139f555f531c6a2a13d002b81725a7c389d (patch) | |
tree | 196f647ea12ace2da99b4d821246522276b22488 /tests | |
parent | README: how to test (diff) | |
download | g-sorcery-e2456139f555f531c6a2a13d002b81725a7c389d.tar.gz g-sorcery-e2456139f555f531c6a2a13d002b81725a7c389d.tar.bz2 g-sorcery-e2456139f555f531c6a2a13d002b81725a7c389d.zip |
g_sorcery/metadata: XMLGenerator
Diffstat (limited to 'tests')
-rw-r--r-- | tests/test_metadata.py | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/tests/test_metadata.py b/tests/test_metadata.py new file mode 100644 index 0000000..91da5bc --- /dev/null +++ b/tests/test_metadata.py @@ -0,0 +1,81 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +""" + test_metadata.py + ~~~~~~~~~~~~~~~~ + + metadata generator test suite + + :copyright: (c) 2013 by Jauhien Piatlicki + :license: GPL-2, see LICENSE for more details. +""" + +import xml.etree.ElementTree as ET + +import tempfile, unittest + +from g_sorcery import exceptions, metadata + +class TestXMLGenerator(unittest.TestCase): + def setUp(self): + pass + + def tearDown(self): + pass + + def test_generate(self): + schema = [{'name' : 'desc', + 'subtags' : [], + 'multiple' : (False, ""), + 'required' : True}, + {'name' : 'contact', + 'multiple' : (False, ""), + 'required' : False, + 'subtags' : [ + {'name' : 'email', + 'subtags' : [], + 'multiple' : (False, ""), + 'required' : True}, + + {'name' : 'phone', + 'subtags' : [], + 'multiple' : (False, ""), + 'required' : False}, + ]}, + {'name' : 'multiple', + 'subtags' : [], + 'multiple' : (True, ""), + 'required' : False}, + {'name' : 'flag', + 'subtags' : [], + 'multiple' : (True, "name"), + 'required' : False}, + ] + xg = metadata.XMLGenerator('test_ext', schema) + self.assertRaises(exceptions.XMLGeneratorError, xg.generate, {}) + tree = xg.generate({'desc' : 'test xml'}) + self.assertEqual(ET.tostring(tree, encoding='unicode'), + '<test_ext><desc>test xml</desc></test_ext>') + tree = xg.generate({'desc' : 'test xml', + 'contact' : {'email' : 'test@example.com', + 'phone' : '00-0'}}) + self.assertEqual(ET.tostring(tree, encoding='unicode'), + '<test_ext><desc>test xml</desc><contact><email>test@example.com\ +</email><phone>00-0</phone></contact></test_ext>') + tree = xg.generate({'desc' : 'test xml', + 'multiple' : ['test1', 'test2', 'test3']}) + self.assertEqual(ET.tostring(tree, encoding='unicode'), + '<test_ext><desc>test xml</desc><multiple>test1</multiple>\ +<multiple>test2</multiple><multiple>test3</multiple></test_ext>') + tree = xg.generate({'desc' : 'test xml', + 'flag' : [('flag1', 'test1'), ('flag2', 'test2')]}) + self.assertEqual(ET.tostring(tree, encoding='unicode'), + '<test_ext><desc>test xml</desc><flag name="flag1">test1</flag>\ +<flag name="flag2">test2</flag></test_ext>') + + +def suite(): + suite = unittest.TestSuite() + suite.addTest(TestXMLGenerator('test_generate')) + return suite |