[Zope3-checkins] SVN: Zope3/trunk/ Merged r28873 from ZopeX3-3.0 branch -- fix to issue #293

Derrick Hudson dman at dman13.dyndns.org
Wed Jan 19 16:34:01 EST 2005


Log message for revision 28877:
  Merged r28873 from ZopeX3-3.0 branch -- fix to issue #293
  SequenceWidget and CustomWidgetFactory now work together.
  

Changed:
  U   Zope3/trunk/doc/CHANGES.txt
  U   Zope3/trunk/doc/TODO.txt
  U   Zope3/trunk/src/zope/app/form/__init__.py
  U   Zope3/trunk/src/zope/app/form/browser/sequencewidget.py
  U   Zope3/trunk/src/zope/app/form/browser/tests/test_sequencewidget.py

-=-
Modified: Zope3/trunk/doc/CHANGES.txt
===================================================================
--- Zope3/trunk/doc/CHANGES.txt	2005-01-19 18:59:40 UTC (rev 28876)
+++ Zope3/trunk/doc/CHANGES.txt	2005-01-19 21:34:00 UTC (rev 28877)
@@ -286,6 +286,8 @@
 
     Bug Fixes
 
+      - Fixed issue #293 (SequenceWidget and CustomWidgetFactory).
+
       - TextWidgets set the value attribute to "value" when the field
         has a missing value set and was not required and when there
         was no input.

Modified: Zope3/trunk/doc/TODO.txt
===================================================================
--- Zope3/trunk/doc/TODO.txt	2005-01-19 18:59:40 UTC (rev 28876)
+++ Zope3/trunk/doc/TODO.txt	2005-01-19 21:34:00 UTC (rev 28877)
@@ -79,8 +79,6 @@
 
 * 288: IE xmltree.js line 225 error 
 
-* 293: SequenceWidget and CustomWidgetFactory 
-
 * 296: missing display widgets 
 
 * 298: Role/permission title and description should be messageids

Modified: Zope3/trunk/src/zope/app/form/__init__.py
===================================================================
--- Zope3/trunk/src/zope/app/form/__init__.py	2005-01-19 18:59:40 UTC (rev 28876)
+++ Zope3/trunk/src/zope/app/form/__init__.py	2005-01-19 21:34:00 UTC (rev 28877)
@@ -98,6 +98,6 @@
     def __call__(self, context, request):
         args = (context, request) + self.args
         instance = self._widget_factory(*args)
-        for item in self.kw.items():
-            setattr(instance, item[0], item[1])
+        for name, value in self.kw.items():
+            setattr(instance, name, value)
         return instance

Modified: Zope3/trunk/src/zope/app/form/browser/sequencewidget.py
===================================================================
--- Zope3/trunk/src/zope/app/form/browser/sequencewidget.py	2005-01-19 18:59:40 UTC (rev 28876)
+++ Zope3/trunk/src/zope/app/form/browser/sequencewidget.py	2005-01-19 21:34:00 UTC (rev 28877)
@@ -36,13 +36,13 @@
 
     implements(IInputWidget)
 
-    _type = tuple    
+    _type = tuple
     _data = () # pre-existing sequence items (from setRenderedValue)
 
-    def __init__(self, context, value_type, request, subwidget=None):
+    def __init__(self, context, request, subwidget=None):
         super(SequenceWidget, self).__init__(context, request)
 
-        self.subwidget = None
+        self.subwidget = subwidget
 
     def __call__(self):
         """Render the widget
@@ -234,7 +234,7 @@
         return sequence
 
 class TupleSequenceWidget(SequenceWidget):
-    pass
+    _type = tuple
 
 class ListSequenceWidget(SequenceWidget):
     _type = list

Modified: Zope3/trunk/src/zope/app/form/browser/tests/test_sequencewidget.py
===================================================================
--- Zope3/trunk/src/zope/app/form/browser/tests/test_sequencewidget.py	2005-01-19 18:59:40 UTC (rev 28876)
+++ Zope3/trunk/src/zope/app/form/browser/tests/test_sequencewidget.py	2005-01-19 21:34:00 UTC (rev 28877)
@@ -25,9 +25,11 @@
 
 from zope.app import zapi
 from zope.app.tests import ztapi
-from zope.app.form.browser import TextWidget, TupleSequenceWidget
-from zope.app.form.browser import ListSequenceWidget
+from zope.app.form.browser import TextWidget, ObjectWidget
+from zope.app.form.browser import TupleSequenceWidget, ListSequenceWidget
+from zope.app.form.browser import SequenceWidget
 from zope.app.form.interfaces import IInputWidget
+from zope.app.form import CustomWidgetFactory
 
 from zope.app.form.browser.tests.test_browserwidget import BrowserWidgetTest
 
@@ -55,9 +57,7 @@
         field = field.bind(self.content)
         request = TestRequest(HTTP_ACCEPT_LANGUAGE='pl')
         request.form['field.foo'] = u'Foo Value'
-        # sequence widgets take value_type as second argument because of double
-        # dispatch
-        self._widget = self._WidgetFactory(field, TextLine(), request)
+        self._widget = self._WidgetFactory(field, request)
 
     def _FieldFactory(self, **kw):
         kw.update({
@@ -83,28 +83,64 @@
         self._widget.request.form['field.foo.0.bar'] = u'hi, mum'
         self.failUnless(self._widget.hasInput())
 
+    def test_customWidgetFactory(self):
+        """Verify that the widget can be constructed via the CustomWidgetFactory
+        (Issue #293)
+        """
+
+        value_type = TextLine(__name__=u'bar')
+        self.field = List( __name__=u'foo', value_type=value_type )
+        request = TestRequest()
+
+        # set up the custom widget factory and verify that it works
+        sw = CustomWidgetFactory(ListSequenceWidget)
+        widget = sw(self.field, request)
+        assert widget.subwidget is None
+        assert widget.context.value_type is value_type
+
+        # set up a variant that specifies the subwidget to use and verify it
+        class PollOption(object) : pass
+        ow = CustomWidgetFactory(ObjectWidget, PollOption)
+        sw = CustomWidgetFactory(ListSequenceWidget, subwidget=ow)
+        widget = sw(self.field, request)
+        assert widget.subwidget is ow
+        assert widget.context.value_type is value_type
+
+    def test_subwidget(self):
+        """This test verifies that the specified subwidget is not ignored.
+        (Issue #293)
+        """
+        self.field = List( __name__=u'foo',
+                           value_type=TextLine(__name__=u'bar'))
+        request = TestRequest()
+
+        class PollOption(object) : pass
+        ow = CustomWidgetFactory(ObjectWidget, PollOption)
+        widget = SequenceWidget(self.field, request, subwidget=ow)
+        assert widget.subwidget is ow
+
     def test_list(self):
         self.field = List(
             __name__=u'foo',
             value_type=TextLine(__name__=u'bar'))
         request = TestRequest()
-        widget = ListSequenceWidget(self.field, TextLine(), request)
+        widget = ListSequenceWidget(self.field, request)
         self.failIf(widget.hasInput())
         self.assertEquals(widget.getInputValue(), [])
 
         request = TestRequest(form={'field.foo.add': u'Add bar'})
-        widget = ListSequenceWidget(self.field, TextLine(), request)
+        widget = ListSequenceWidget(self.field, request)
         self.assert_(widget.hasInput())
         self.assertRaises(ValidationError, widget.getInputValue)
 
         request = TestRequest(form={'field.foo.0.bar': u'Hello world!'})
-        widget = ListSequenceWidget(self.field, TextLine(), request)
+        widget = ListSequenceWidget(self.field, request)
         self.assert_(widget.hasInput())
         self.assertEquals(widget.getInputValue(), [u'Hello world!'])
 
     def test_new(self):
         request = TestRequest()
-        widget = TupleSequenceWidget(self.field, TextLine(), request)
+        widget = TupleSequenceWidget(self.field, request)
         self.failIf(widget.hasInput())
         self.assertEquals(widget.getInputValue(), ())
         check_list = ('input', 'name="field.foo.add"')
@@ -112,7 +148,7 @@
 
     def test_add(self):
         request = TestRequest(form={'field.foo.add': u'Add bar'})
-        widget = TupleSequenceWidget(self.field, TextLine(), request)
+        widget = TupleSequenceWidget(self.field, request)
         self.assert_(widget.hasInput())
         self.assertRaises(ValidationError, widget.getInputValue)
         check_list = (
@@ -123,13 +159,13 @@
 
     def test_request(self):
         request = TestRequest(form={'field.foo.0.bar': u'Hello world!'})
-        widget = TupleSequenceWidget(self.field, TextLine(), request)
+        widget = TupleSequenceWidget(self.field, request)
         self.assert_(widget.hasInput())
         self.assertEquals(widget.getInputValue(), (u'Hello world!',))
 
     def test_existing(self):
         request = TestRequest()
-        widget = TupleSequenceWidget(self.field, TextLine(), request)
+        widget = TupleSequenceWidget(self.field, request)
         widget.setRenderedValue((u'existing',))
         self.assert_(widget.hasInput())
         self.assertEquals(widget.getInputValue(), (u'existing',))
@@ -155,7 +191,7 @@
         request = TestRequest(form={'field.foo.remove_0': u'Hello world!',
             'field.foo.0.bar': u'existing', 'field.foo.1.bar': u'second',
             'remove-selected-items-of-seq-field.foo': u'Remove selected items'})
-        widget = TupleSequenceWidget(self.field, TextLine(), request)
+        widget = TupleSequenceWidget(self.field, request)
         widget.setRenderedValue((u'existing', u'second'))
         self.assertEquals(widget.getInputValue(), (u'second',))
         check_list = (
@@ -168,7 +204,7 @@
     def test_min(self):
         request = TestRequest()
         self.field.min_length = 2
-        widget = TupleSequenceWidget(self.field, TextLine(), request)
+        widget = TupleSequenceWidget(self.field, request)
         widget.setRenderedValue((u'existing',))
         self.assertEquals(widget.getInputValue(), (u'existing',))
         check_list = (
@@ -183,7 +219,7 @@
     def test_max(self):
         request = TestRequest()
         self.field.max_length = 1
-        widget = TupleSequenceWidget(self.field, TextLine(), request)
+        widget = TupleSequenceWidget(self.field, request)
         widget.setRenderedValue((u'existing',))
         self.assertEquals(widget.getInputValue(), (u'existing',))
         s = widget()
@@ -192,7 +228,7 @@
     def test_anonymousfield(self):
         self.field = Tuple(__name__=u'foo', value_type=TextLine())
         request = TestRequest()
-        widget = TupleSequenceWidget(self.field, TextLine(), request)
+        widget = TupleSequenceWidget(self.field, request)
         widget.setRenderedValue((u'existing',))
         s = widget()
         check_list = (



More information about the Zope3-Checkins mailing list