Commit cef7ffbb authored by Jérome Perrin's avatar Jérome Perrin

xhtml_style: fill request.form during Base_renderForm

Base_renderForm was using request.set - which only sets in request.other,
and this causes Base_renderForm to behaves differently from Base_redirect
with forms looking explicitly in request.form, like for example listbox
does before calling the list method.

See merge request !2032
parents dd813bf0 eaafdb46
...@@ -33,15 +33,7 @@ from DateTime import DateTime ...@@ -33,15 +33,7 @@ from DateTime import DateTime
from Products.ERP5Type.tests.Sequence import SequenceList from Products.ERP5Type.tests.Sequence import SequenceList
from erp5.component.module.ConfiguratorTestMixin import \ from erp5.component.module.ConfiguratorTestMixin import \
TestLiveConfiguratorWorkflowMixin TestLiveConfiguratorWorkflowMixin
from Products.ERP5Form.FormBox import FormBoxEditor
class FakeFormBoxEditor(dict):
"""Quick replacement for formbox editor.
"""
__allow_access_to_unprotected_subobjects__ = 1
def as_dict(self):
return self
class StandardConfigurationMixin(TestLiveConfiguratorWorkflowMixin): class StandardConfigurationMixin(TestLiveConfiguratorWorkflowMixin):
...@@ -1169,6 +1161,16 @@ class StandardConfigurationMixin(TestLiveConfiguratorWorkflowMixin): ...@@ -1169,6 +1161,16 @@ class StandardConfigurationMixin(TestLiveConfiguratorWorkflowMixin):
], ],
) )
form_box_editor = FormBoxEditor(
result=(
{
# this is what GenericSolver_viewConfigurationFormBox/my_tested_property_list passes as default hidden
'tested_property_list': solver_decision.getCausalityValue().getTestedPropertyList(),
},
[],
),
context=None,
)
listbox = ( listbox = (
{ {
'listbox_key': 'listbox_key':
...@@ -1177,9 +1179,7 @@ class StandardConfigurationMixin(TestLiveConfiguratorWorkflowMixin): ...@@ -1177,9 +1179,7 @@ class StandardConfigurationMixin(TestLiveConfiguratorWorkflowMixin):
'portal_solvers/Accept Solver', 'portal_solvers/Accept Solver',
# this is what GenericSolver_viewConfigurationFormBox/my_tested_property_list passes as default hidden # this is what GenericSolver_viewConfigurationFormBox/my_tested_property_list passes as default hidden
'solver_configuration': 'solver_configuration':
FakeFormBoxEditor( form_box_editor,
tested_property_list=solver_decision.getCausalityValue()
.getTestedPropertyList()),
'comment': 'comment':
'', '',
},) },)
...@@ -1607,17 +1607,24 @@ class StandardConfigurationMixin(TestLiveConfiguratorWorkflowMixin): ...@@ -1607,17 +1607,24 @@ class StandardConfigurationMixin(TestLiveConfiguratorWorkflowMixin):
], ],
) )
form_box_editor = FormBoxEditor(
result=(
{
# this is what GenericSolver_viewConfigurationFormBox/my_tested_property_list passes as default hidden
'tested_property_list': solver_decision.getCausalityValue().getTestedPropertyList(),
},
[],
),
context=None,
)
listbox = ( listbox = (
{ {
'listbox_key': 'listbox_key':
solver_decision.getPath(), solver_decision.getPath(),
'solver': 'solver':
'portal_solvers/Accept Solver', 'portal_solvers/Accept Solver',
# this is what GenericSolver_viewConfigurationFormBox/my_tested_property_list passes as default hidden
'solver_configuration': 'solver_configuration':
FakeFormBoxEditor( form_box_editor,
tested_property_list=solver_decision.getCausalityValue()
.getTestedPropertyList()),
'comment': 'comment':
'', '',
},) },)
......
...@@ -50,6 +50,16 @@ ...@@ -50,6 +50,16 @@
<td>"Update" action is done with "A value from the user".</td> <td>"Update" action is done with "A value from the user".</td>
<td></td> <td></td>
</tr> </tr>
<tr>
<td>assertValue</td>
<td>//input[@name="field_your_string_field"]</td>
<td>A value from the user</td>
</tr>
<tr>
<td>assertTextPresent</td>
<td>A value pushed by update action</td>
<td></td>
</tr>
<tr> <tr>
<td>clickAndWait</td> <td>clickAndWait</td>
<td>Base_callDialogMethod:method</td> <td>Base_callDialogMethod:method</td>
...@@ -87,4 +97,4 @@ ...@@ -87,4 +97,4 @@
<td></td> <td></td>
</tr> </tr>
</body> </body>
</html> </html>
\ No newline at end of file
"""Call the Foo_viewDummyDialog""" """Call the Foo_viewDummyDialog"""
kw.update(context.REQUEST.form) return context.Base_renderForm(
return context.ERP5Site_redirect("%s/Foo_viewDummyDialog" % context.absolute_url(), 'Foo_viewDummyDialog',
keep_items={'portal_status_message': '"Update" action is done with "%s".' % string_field}, **kw) message='"Update" action is done with "%s".' % string_field,
keep_items={
'key_posted_during_on_update': 'A value pushed by update action'
}
)
...@@ -76,6 +76,7 @@ ...@@ -76,6 +76,7 @@
<value> <value>
<list> <list>
<string>your_string_field</string> <string>your_string_field</string>
<string>your_inspect_request</string>
</list> </list>
</value> </value>
</item> </item>
......
...@@ -22,5 +22,6 @@ if REQUEST is None: ...@@ -22,5 +22,6 @@ if REQUEST is None:
for key, value in keep_items.items(): for key, value in keep_items.items():
REQUEST.set(key, value) REQUEST.set(key, value)
REQUEST.form[key] = value
return getattr(context, form_id)() return getattr(context, form_id)()
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment