misc: |filter_value & |exclude_value with block fields (#58452)
gitea-wip/wcs/pipeline/head Build started... Details

This commit is contained in:
Lauréline Guérin 2022-07-08 15:01:22 +02:00
parent 208a105c59
commit ff4c760daf
No known key found for this signature in database
GPG Key ID: 1FAB9B9B4F93D473
2 changed files with 138 additions and 2 deletions

View File

@ -3445,6 +3445,135 @@ def test_block_set_value_to_empty_string(pub):
assert formdata.data.get('1_display') is None
def test_formdata_filtering_on_block_fields(pub):
NamedDataSource.wipe()
data_source = NamedDataSource(name='foobar')
data_source.data_source = {
'type': 'formula',
'value': repr([{'id': '1', 'text': 'foo'}, {'id': '2', 'text': 'bar'}]),
}
data_source.store()
BlockDef.wipe()
block = BlockDef()
block.name = 'foobar'
block.fields = [
fields.StringField(id='1', label='String', type='string', varname='string'),
fields.ItemField(id='2', label='Item', type='item', data_source={'type': 'foobar'}, varname='item'),
fields.BoolField(id='3', label='Bool', type='bool', varname='bool'),
fields.DateField(id='4', label='Date', type='date', varname='date'),
fields.EmailField(id='5', label='Email', type='email', varname='email'),
]
block.store()
FormDef.wipe()
formdef = FormDef()
formdef.name = 'test'
formdef.fields = [
fields.BlockField(id='0', label='Block Data', varname='blockdata', type='block:foobar', max_items=3),
]
formdef.store()
data_class = formdef.data_class()
data_class.wipe()
for i in range(11):
formdata = data_class()
if i < 10: # None values for the last one
formdata.data = {
'0': {
'data': [
{
'1': 'plop%s' % i,
'2': '1' if i % 2 else '2',
'2_display': 'foo' if i % 2 else 'bar',
'2_structured': 'XXX' if i % 2 else 'YYY',
'3': bool(i % 2),
'4': '2021-06-%02d' % (i + 1),
'5': 'a@localhost' if i % 2 else 'b@localhost',
},
],
'schema': {}, # not important here
},
'0_display': 'hello',
}
if i == 0:
formdata.data['0']['data'].append(
{
'1': 'plop%s' % (i + 1),
'2': '1',
'2_display': 'foo',
'2_structured': 'XXX',
'3': True,
'4': '2021-06-02',
'5': 'a@localhost',
},
)
formdata.just_created()
formdata.jump_status('new')
formdata.store()
context = pub.substitutions.get_context_variables(mode='lazy')
# string
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|filter_value:"plop0"|count}}')
assert tmpl.render(context) == '1'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|filter_value:"plop1"|count}}')
assert tmpl.render(context) == '2'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|filter_value:"plop10"|count}}')
assert tmpl.render(context) == '0'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|exclude_value:"plop0"|count}}')
assert tmpl.render(context) == '10'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|exclude_value:"plop1"|count}}')
assert tmpl.render(context) == '9'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|exclude_value:"plop10"|count}}')
assert tmpl.render(context) == '11'
# item
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|filter_value:"1"|count}}')
assert tmpl.render(context) == '6'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|filter_value:"2"|count}}')
assert tmpl.render(context) == '5'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|filter_value:"3"|count}}')
assert tmpl.render(context) == '0'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|exclude_value:"1"|count}}')
assert tmpl.render(context) == '5'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|exclude_value:"2"|count}}')
assert tmpl.render(context) == '6'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|exclude_value:"3"|count}}')
assert tmpl.render(context) == '11'
# bool
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_bool"|filter_value:"true"|count}}')
assert tmpl.render(context) == '6'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_bool"|filter_value:"false"|count}}')
assert tmpl.render(context) == '5'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_bool"|exclude_value:"true"|count}}')
assert tmpl.render(context) == '5'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_bool"|exclude_value:"false"|count}}')
assert tmpl.render(context) == '6'
# date
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_date"|filter_value:"2021-06-01"|count}}')
assert tmpl.render(context) == '1'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_date"|filter_value:"2021-06-02"|count}}')
assert tmpl.render(context) == '2'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_date"|exclude_value:"2021-06-01"|count}}')
assert tmpl.render(context) == '10'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_date"|exclude_value:"2021-06-02"|count}}')
assert tmpl.render(context) == '9'
# email
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|filter_value:"a@localhost"|count}}')
assert tmpl.render(context) == '6'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|filter_value:"b@localhost"|count}}')
assert tmpl.render(context) == '5'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|filter_value:"c@localhost"|count}}')
assert tmpl.render(context) == '0'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|exclude_value:"a@localhost"|count}}')
assert tmpl.render(context) == '5'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|exclude_value:"b@localhost"|count}}')
assert tmpl.render(context) == '6'
tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|exclude_value:"c@localhost"|count}}')
assert tmpl.render(context) == '11'
def test_items_field_getlist(pub):
NamedDataSource.wipe()
data_source = NamedDataSource(name='foobar')

View File

@ -186,8 +186,12 @@ class LazyFormDefObjectsManager:
return self._clone(self._criterias + [Equal('id_display', str(value))])
def get_fields(self, key):
for field in self._formdef.get_all_fields():
if getattr(field, 'varname', None) == key:
for field in self._formdef.iter_fields(include_block_fields=True):
if getattr(field, 'block_field', None):
if field.key == 'items':
# not yet
continue
if field.contextual_varname == key:
yield field
def get_field(self, key):
@ -215,6 +219,9 @@ class LazyFormDefObjectsManager:
formdata=self._formdata,
)
return self.none()
if value is not None and fields[0].convert_value_to_str:
# in block fields, we store strings
value = fields[0].convert_value_to_str(value)
from wcs import sql