Projet

Général

Profil

0001-misc-filter_value-exclude_value-with-block-fields-58.patch

Lauréline Guérin, 15 juillet 2022 12:43

Télécharger (8,22 ko)

Voir les différences:

Subject: [PATCH] misc: |filter_value & |exclude_value with block fields
 (#58452)

 tests/test_formdata.py | 129 +++++++++++++++++++++++++++++++++++++++++
 wcs/variables.py       |  11 +++-
 2 files changed, 138 insertions(+), 2 deletions(-)
tests/test_formdata.py
3445 3445
    assert formdata.data.get('1_display') is None
3446 3446

  
3447 3447

  
3448
def test_formdata_filtering_on_block_fields(pub):
3449
    NamedDataSource.wipe()
3450
    data_source = NamedDataSource(name='foobar')
3451
    data_source.data_source = {
3452
        'type': 'formula',
3453
        'value': repr([{'id': '1', 'text': 'foo'}, {'id': '2', 'text': 'bar'}]),
3454
    }
3455
    data_source.store()
3456

  
3457
    BlockDef.wipe()
3458
    block = BlockDef()
3459
    block.name = 'foobar'
3460
    block.fields = [
3461
        fields.StringField(id='1', label='String', type='string', varname='string'),
3462
        fields.ItemField(id='2', label='Item', type='item', data_source={'type': 'foobar'}, varname='item'),
3463
        fields.BoolField(id='3', label='Bool', type='bool', varname='bool'),
3464
        fields.DateField(id='4', label='Date', type='date', varname='date'),
3465
        fields.EmailField(id='5', label='Email', type='email', varname='email'),
3466
    ]
3467
    block.store()
3468

  
3469
    FormDef.wipe()
3470
    formdef = FormDef()
3471
    formdef.name = 'test'
3472
    formdef.fields = [
3473
        fields.BlockField(id='0', label='Block Data', varname='blockdata', type='block:foobar', max_items=3),
3474
    ]
3475
    formdef.store()
3476

  
3477
    data_class = formdef.data_class()
3478
    data_class.wipe()
3479

  
3480
    for i in range(11):
3481
        formdata = data_class()
3482
        if i < 10:  # None values for the last one
3483
            formdata.data = {
3484
                '0': {
3485
                    'data': [
3486
                        {
3487
                            '1': 'plop%s' % i,
3488
                            '2': '1' if i % 2 else '2',
3489
                            '2_display': 'foo' if i % 2 else 'bar',
3490
                            '2_structured': 'XXX' if i % 2 else 'YYY',
3491
                            '3': bool(i % 2),
3492
                            '4': '2021-06-%02d' % (i + 1),
3493
                            '5': 'a@localhost' if i % 2 else 'b@localhost',
3494
                        },
3495
                    ],
3496
                    'schema': {},  # not important here
3497
                },
3498
                '0_display': 'hello',
3499
            }
3500
            if i == 0:
3501
                formdata.data['0']['data'].append(
3502
                    {
3503
                        '1': 'plop%s' % (i + 1),
3504
                        '2': '1',
3505
                        '2_display': 'foo',
3506
                        '2_structured': 'XXX',
3507
                        '3': True,
3508
                        '4': '2021-06-02',
3509
                        '5': 'a@localhost',
3510
                    },
3511
                )
3512
        formdata.just_created()
3513
        formdata.jump_status('new')
3514
        formdata.store()
3515

  
3516
    context = pub.substitutions.get_context_variables(mode='lazy')
3517

  
3518
    # string
3519
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|filter_value:"plop0"|count}}')
3520
    assert tmpl.render(context) == '1'
3521
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|filter_value:"plop1"|count}}')
3522
    assert tmpl.render(context) == '2'
3523
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|filter_value:"plop10"|count}}')
3524
    assert tmpl.render(context) == '0'
3525
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|exclude_value:"plop0"|count}}')
3526
    assert tmpl.render(context) == '10'
3527
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|exclude_value:"plop1"|count}}')
3528
    assert tmpl.render(context) == '9'
3529
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_string"|exclude_value:"plop10"|count}}')
3530
    assert tmpl.render(context) == '11'
3531
    # item
3532
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|filter_value:"1"|count}}')
3533
    assert tmpl.render(context) == '6'
3534
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|filter_value:"2"|count}}')
3535
    assert tmpl.render(context) == '5'
3536
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|filter_value:"3"|count}}')
3537
    assert tmpl.render(context) == '0'
3538
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|exclude_value:"1"|count}}')
3539
    assert tmpl.render(context) == '5'
3540
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|exclude_value:"2"|count}}')
3541
    assert tmpl.render(context) == '6'
3542
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_item"|exclude_value:"3"|count}}')
3543
    assert tmpl.render(context) == '11'
3544
    # bool
3545
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_bool"|filter_value:"true"|count}}')
3546
    assert tmpl.render(context) == '6'
3547
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_bool"|filter_value:"false"|count}}')
3548
    assert tmpl.render(context) == '5'
3549
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_bool"|exclude_value:"true"|count}}')
3550
    assert tmpl.render(context) == '5'
3551
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_bool"|exclude_value:"false"|count}}')
3552
    assert tmpl.render(context) == '6'
3553
    # date
3554
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_date"|filter_value:"2021-06-01"|count}}')
3555
    assert tmpl.render(context) == '1'
3556
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_date"|filter_value:"2021-06-02"|count}}')
3557
    assert tmpl.render(context) == '2'
3558
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_date"|exclude_value:"2021-06-01"|count}}')
3559
    assert tmpl.render(context) == '10'
3560
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_date"|exclude_value:"2021-06-02"|count}}')
3561
    assert tmpl.render(context) == '9'
3562
    # email
3563
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|filter_value:"a@localhost"|count}}')
3564
    assert tmpl.render(context) == '6'
3565
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|filter_value:"b@localhost"|count}}')
3566
    assert tmpl.render(context) == '5'
3567
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|filter_value:"c@localhost"|count}}')
3568
    assert tmpl.render(context) == '0'
3569
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|exclude_value:"a@localhost"|count}}')
3570
    assert tmpl.render(context) == '5'
3571
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|exclude_value:"b@localhost"|count}}')
3572
    assert tmpl.render(context) == '6'
3573
    tmpl = Template('{{forms|objects:"test"|filter_by:"blockdata_email"|exclude_value:"c@localhost"|count}}')
3574
    assert tmpl.render(context) == '11'
3575

  
3576

  
3448 3577
def test_items_field_getlist(pub):
3449 3578
    NamedDataSource.wipe()
3450 3579
    data_source = NamedDataSource(name='foobar')
wcs/variables.py
186 186
        return self._clone(self._criterias + [Equal('id_display', str(value))])
187 187

  
188 188
    def get_fields(self, key):
189
        for field in self._formdef.get_all_fields():
190
            if getattr(field, 'varname', None) == key:
189
        for field in self._formdef.iter_fields(include_block_fields=True):
190
            if getattr(field, 'block_field', None):
191
                if field.key == 'items':
192
                    # not yet
193
                    continue
194
            if field.contextual_varname == key:
191 195
                yield field
192 196

  
193 197
    def get_field(self, key):
......
215 219
                    formdata=self._formdata,
216 220
                )
217 221
                return self.none()
222
            if value is not None and fields[0].convert_value_to_str:
223
                # in block fields, we store strings
224
                value = fields[0].convert_value_to_str(value)
218 225

  
219 226
        from wcs import sql
220 227

  
221
-