Opened 5 years ago

Closed 5 years ago

#31720 closed Cleanup/optimization (fixed)

Better documentation and defaults for BoolOr and BoolAnd

Reported by: Alex Scott Owned by: David Chorpash
Component: Database layer (models, ORM) Version: 3.0
Severity: Normal Keywords:
Cc: Triage Stage: Ready for checkin
Has patch: yes Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

The only documentation available (that I found at least) for Postgres DB functions is:
https://docs.djangoproject.com/en/3.0/ref/contrib/postgres/aggregates/

It would be really nice to have an example or two for each of those.

One issue I ran into with BoolOr when I was doing something like BoolOr(Q('someCharField') == Value('someVal')) (which in itself would be a great example to show), is an error:

'Cannot resolve expression type, unknown output_field'

Adding output_field=BooleanField() seemed to solve it but this wasn't intuitive. Shouldn't the default output for BoolOr be boolean? If so, it would be good to set it as such I think.

Change History (14)

comment:1 by Simon Charette, 5 years ago

Component: contrib.postgresDatabase layer (models, ORM)
Needs documentation: set
Owner: set to nobody
Triage Stage: UnreviewedAccepted
Type: UncategorizedCleanup/optimization

A patch for both documentation and explicit output_field for BoolOr and BoolAnd would be welcome. The issue you're experiencing here is likely due to the fact Q and WhereNode are marked conditional=True but don't set output_field = models.BooleanField() and thus the default behavior of Expression._resolve_output_field cannot be leveraged.

Are you interested in submitting a PR with these improvements?

in reply to:  1 comment:2 by Alex Scott, 5 years ago

Thanks Simon for the quick response. I'm a bit of a n00b and have never really contributed a PR to an open source project but maybe this could be the first. Do you think setting the default is all that needs to be done? I can try to take a look over this next week (and read about how to contribute) and let you know if I think I'm capable.

Replying to Simon Charette:

A patch for both documentation and explicit output_field for BoolOr and BoolAnd would be welcome. The issue you're experiencing here is likely due to the fact Q and WhereNode are marked conditional=True but don't set output_field = models.BooleanField() and thus the default behavior of Expression._resolve_output_field cannot be leveraged.

Are you interested in submitting a PR with these improvements?

comment:3 by Simon Charette, 5 years ago

Do you think setting the default is all that needs to be done?

yeah, defining BoolOr.output_field = models.BooleanField() at the class level (for BoolAnd as well) should be enough.

For the tests an extra method in tests/postgres_tests/test_aggregates.py for usage of Q objects for both functions should be enough for each aggregate function.

e.g.

def test_bool_or_q_object(self):
    values = AggregateTestModel.objects.aggregate(boolor=BoolOr(Q(integer_field__gt=2))
    self.assertEqual(values, {'boolor': False})

I think examples in the documentation would also be welcome.

comment:4 by David Chorpash, 5 years ago

Owner: changed from nobody to David Chorpash
Status: newassigned

I am interested in working this ticket. I know plenty of time has passed since this was last modified, but I'll give it up to Alex if he wants to give it a shot within the next day or so.

comment:5 by Alex Scott, 5 years ago

Thanks David! Please do. Day job work got in the way of me taking a stab at this and I'll continue to be busy for the next few weeks. So happy for you to take it.

comment:6 by David Chorpash, 5 years ago

Has patch: set

Alex, I understand how that goes!

Simon, I submitted a PR and I wanted to make sure I set it up where I'm merging to the correct branch. This is the first time submitting a PR for a ticket where the version was not set to master.

Since the version is set to 3.0, I'm going to be merging into the stable/3.1.x. Is that correct?

comment:7 by Simon Charette, 5 years ago

Thanks for your PR Alex!

I left some comments on Github but you'll want to target the master branch instead of stable/3.1.x, mergers will take care of the backport if necessary.

I also think it might be worth documenting the usage of Q objects for these aggregates and not solely boolean fields.

comment:8 by David Chorpash, 5 years ago

Thank you for the feedback, Simon!

I fixed the PR so that it's targeting master. I also made adjustments based on the comments and added documentation for Q objects.

comment:9 by Mariusz Felisiak, 5 years ago

Needs documentation: unset
Triage Stage: AcceptedReady for checkin

comment:10 by Mariusz Felisiak <felisiak.mariusz@…>, 5 years ago

In a2e621b:

Refs #31720 -- Added examples to BoolAnd() and BoolOr() documentation.

comment:11 by Mariusz Felisiak <felisiak.mariusz@…>, 5 years ago

In 6ec5eb5:

Refs #31720 -- Defined default output_field of BoolAnd() and BoolOr() aggregate functions.

comment:12 by Mariusz Felisiak <felisiak.mariusz@…>, 5 years ago

In 5360f00:

[3.1.x] Refs #31720 -- Added examples to BoolAnd() and BoolOr() documentation.

Backport of a2e621b14e85836362b7fc0e6b1bf7d7ff98e42b from master

comment:13 by Mariusz Felisiak <felisiak.mariusz@…>, 5 years ago

In 0a3c1272:

[3.0.x] Refs #31720 -- Added examples to BoolAnd() and BoolOr() documentation.

Backport of a2e621b14e85836362b7fc0e6b1bf7d7ff98e42b from master

comment:14 by Mariusz Felisiak, 5 years ago

Resolution: fixed
Status: assignedclosed
Note: See TracTickets for help on using tickets.
Back to Top