[Zope-Checkins] CVS: Packages/ZConfig/tests - test_schema.py:1.1.2.3

Fred L. Drake, Jr. fred@zope.com
Wed, 11 Dec 2002 16:25:20 -0500


Update of /cvs-repository/Packages/ZConfig/tests
In directory cvs.zope.org:/tmp/cvs-serv31131/tests

Modified Files:
      Tag: zconfig-schema-devel-branch
	test_schema.py 
Log Message:
More tests, some cleanup.

=== Packages/ZConfig/tests/test_schema.py 1.1.2.2 => 1.1.2.3 ===
--- Packages/ZConfig/tests/test_schema.py:1.1.2.2	Wed Dec 11 15:31:22 2002
+++ Packages/ZConfig/tests/test_schema.py	Wed Dec 11 16:25:19 2002
@@ -28,7 +28,7 @@
     # tests
 
     def test_minimal_schema(self):
-        schema = self.loadtext("<schema/>")
+        schema = self.load_schema_text("<schema/>")
         self.assertEqual(len(schema), 0)
         self.assertEqual(schema.getchildnames(), [])
         self.assertRaises(IndexError,
@@ -37,7 +37,7 @@
                           schema.getinfo, "foo")
 
     def test_simple(self):
-        schema, conf = self.loadBoth("simple.xml", "simple.conf")
+        schema, conf = self.load_both("simple.xml", "simple.conf")
         eq = self.assertEqual
         eq(conf.var1, 'abc')
         eq(conf.int_var, 12)
@@ -52,23 +52,46 @@
         check(not conf.false_var_2)
         check(not conf.false_var_3)
 
+    def test_multivalued_keys(self):
+        schema = self.load_schema_text(
+            "<schema>"
+            "  <key name='a' minOccurs='2' maxOccurs='5' />"
+            "  <key name='b' minOccurs='2' maxOccurs='2' >"
+            "    <default>first</default>"
+            "    <default>second</default>"
+            "  </key>"
+            "</schema>")
+        conf = self.load_config_text(schema,
+                                     "a foo\n"
+                                     "a bar\n"
+                                     )
+        self.assertEqual(conf.a, ['foo', 'bar'])
+        self.assertEqual(conf.b, ['first', 'second'])
+
     # utilities
 
-    def load(self, relurl):
+    def load_both(self, schema_url, conf_url):
+        schema = self.load_schema(schema_url)
+        conf = self.load_config(schema, conf_url)
+        return schema, conf
+
+    def load_schema(self, relurl):
         self.url = urlparse.urljoin(CONFIG_BASE, relurl)
         self.schema = ZConfig.loadSchema(self.url)
         self.assert_(self.schema.issection())
         return self.schema
 
-    def loadtext(self, text):
+    def load_schema_text(self, text):
         sio = StringIO.StringIO(text)
         return ZConfig.loadSchemaFile(sio)
 
-    def loadBoth(self, schema_url, conf_url):
-        schema = self.load(schema_url)
+    def load_config(self, schema, conf_url):
         conf_url = urlparse.urljoin(CONFIG_BASE, conf_url)
-        conf = ConfigLoader(schema).loadURL(conf_url)
-        return schema, conf
+        return ConfigLoader(schema).loadURL(conf_url)
+
+    def load_config_text(self, schema, text):
+        sio = StringIO.StringIO(text)
+        return ConfigLoader(schema).loadFile(sio)
 
 
 def test_suite():