Skip to content

Commit

Permalink
fix: use True value for isnull operator
Browse files Browse the repository at this point in the history
  • Loading branch information
asfaltboy committed Oct 9, 2022
1 parent b127321 commit 65a91f8
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 18 deletions.
2 changes: 1 addition & 1 deletion advanced_filters/forms.py
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ def _build_query_dict(self, formdata=None):
formdata = self.cleaned_data
key = "{field}__{operator}".format(**formdata)
if formdata['operator'] == "isnull":
return {key: None}
return {key: True}
elif formdata['operator'] == "istrue":
return {formdata['field']: True}
elif formdata['operator'] == "isfalse":
Expand Down
44 changes: 27 additions & 17 deletions advanced_filters/tests/test_forms.py
Original file line number Diff line number Diff line change
Expand Up @@ -71,23 +71,6 @@ def test_build_field_choices(self):
'fname': 'First name'
}

def test_build_query_dict(self):
data = self.data.copy()
form = AdvancedFilterQueryForm(self.fields, data=data)
assert form._build_query_dict() == {'fname__iexact': 'john'}

data['operator'] = 'isnull'
form = AdvancedFilterQueryForm(self.fields, data=data)
assert form._build_query_dict() == {'fname__isnull': None}

data['operator'] = 'istrue'
form = AdvancedFilterQueryForm(self.fields, data=data)
assert form._build_query_dict() == {'fname': True}

data['operator'] = 'isfalse'
form = AdvancedFilterQueryForm(self.fields, data=data)
assert form._build_query_dict() == {'fname': False}

def test_make_query(self):
form = AdvancedFilterQueryForm(self.fields, data=self.data)
assert form.is_valid()
Expand Down Expand Up @@ -201,6 +184,33 @@ def test_all_operators_are_restored(self):
assert res == expected[i]


@pytest.mark.parametrize("fields, data, expected", [
(
dict(bday='birthday', fname='first name'),
dict(field='fname', value='john', operator='iexact'),
{'fname__iexact': 'john'}
),
(
dict(bday='birthday', fname='first name'),
dict(field='fname', value='john', operator='isnull'),
{'fname__isnull': True}
),
(
dict(bday='birthday', fname='first name'),
dict(field='fname', value='john', operator='istrue'),
{'fname': True}
),
(
dict(bday='birthday', fname='first name'),
dict(field='fname', value='john', operator='isfalse'),
{'fname': False}
),
])
def test_build_query_dict(data, fields, expected):
form = AdvancedFilterQueryForm(fields, data=data)
assert form._build_query_dict() == expected


class CommonFormTest(TestCase):
mgmg_form_data = {
'form-TOTAL_FORMS': 1,
Expand Down

0 comments on commit 65a91f8

Please sign in to comment.