This bug is typical since version 2.0 and exists until now.
--
Ticket URL: <https://code.djangoproject.com/ticket/29810>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.
Old description:
> When I try to join table with using `FilteredRelation` clause it failed
> if the result of a joined table is null.
> This error can be reproduce by adding the following test case to the
> corresponding
> [https://github.com/django/django/blob/2.0/tests/filtered_relation/tests.py#L9
> test module]:
> {{{#!div style="font-size: 80%"
> tests.filtered_relation.tests.FilteredRelationTests:
> {{{#!python
> def test_select_related_empty_join(self):
> self.assertFalse(
> Author.objects.annotate(
> empty_join=FilteredRelation('book', condition=Q(
> book__title='not existing book')),
> ).select_related('empty_join')
> )
> }}}
> }}}
>
> This bug is typical since version 2.0 and exists until now.
New description:
When I try to join table with using `FilteredRelation` clause it failed if
the result of a joined table is null.
This error can be reproduce by adding the following test case to the
corresponding
[https://github.com/django/django/blob/2.0/tests/filtered_relation/tests.py#L9
test module]:
{{{#!div style="font-size: 80%"
tests.filtered_relation.tests.FilteredRelationTests:
{{{#!python
def test_select_related_empty_join(self):
self.assertFalse(
Author.objects.annotate(
empty_join=FilteredRelation('book', condition=Q(
book__title='not existing book')),
).select_related('empty_join')
)
}}}
}}}
{{{#!div style="font-size: 80%"
Error:
{{{
............E.s................
======================================================================
ERROR: test_select_related_empty_join
(filtered_relation.tests.FilteredRelationTests)
----------------------------------------------------------------------
Traceback (most recent call last):
File "/usr/lib/python3.6/unittest/case.py", line 59, in testPartExecutor
yield
File "/usr/lib/python3.6/unittest/case.py", line 605, in run
testMethod()
File
"/home/adv/projects/github/django/tests/filtered_relation/tests.py", line
46, in test_select_related_empty_join
).select_related('empty_join')
File "/usr/lib/python3.6/unittest/case.py", line 674, in assertFalse
if expr:
File "/home/adv/projects/github/django/django/db/models/query.py", line
271, in __bool__
self._fetch_all()
File "/home/adv/projects/github/django/django/db/models/query.py", line
1232, in _fetch_all
self._result_cache = list(self._iterable_class(self))
File "/home/adv/projects/github/django/django/db/models/query.py", line
67, in __iter__
rel_populator.populate(row, obj)
File "/home/adv/projects/github/django/django/db/models/query.py", line
1876, in populate
self.local_setter(from_obj, obj)
File
"/home/adv/projects/github/django/django/db/models/sql/compiler.py", line
892, in local_setter
f.remote_field.set_cached_value(from_obj, obj)
File
"/home/adv/projects/github/django/django/db/models/fields/mixins.py", line
23, in set_cached_value
instance._state.fields_cache[self.get_cache_name()] = value
AttributeError: 'NoneType' object has no attribute '_state'
----------------------------------------------------------------------
}}}
}}}
This bug is typical since version 2.0 and exists until now.
--
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:1>
* stage: Unreviewed => Accepted
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:2>
Comment (by Can Sarıgöl):
Hi, could you review this [https://code.djangoproject.com/ticket/29810
PR].
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:3>
* cc: Can Sarıgöl (added)
* has_patch: 0 => 1
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:4>
* needs_better_patch: 0 => 1
Comment:
Tests aren't passing.
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:5>
Comment (by Can Sarıgöl):
Sorry, I didn't think it was about PR. I'm looking at
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:6>
* needs_better_patch: 1 => 0
Comment:
I hope the fails are not about me this time :)
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:7>
* status: new => assigned
* owner: nobody => Can Sarıgöl
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:8>
* needs_better_patch: 0 => 1
* version: 2.0 => master
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:9>
* needs_better_patch: 1 => 0
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:10>
* status: assigned => closed
* resolution: => fixed
Comment:
In [changeset:"c00b4dbda2d9217cac205c4ffb3ccc1fa59a28ae" c00b4dbd]:
{{{
#!CommitTicketReference repository=""
revision="c00b4dbda2d9217cac205c4ffb3ccc1fa59a28ae"
Fixed #29810 -- Fixed crash of select_related() on FilteredRelation with
empty result.
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/29810#comment:11>