Reputation: 682
I'm trying to write a simple model manager that will filter on a particular field.
I have a model which looks like this:
"""Model definition for Period."""
year = models.ForeignKey(Year, on_delete=models.PROTECT)
name = models.CharField(max_length=50)
active = models.BooleanField(default=False)
objects = models.Manager()
active_year_periods = PeriodManager().active_year_periods()
My Period manager looks like this:
class PeriodManager(models.Manager):
"""
The manager for Period objects
"""
def active_year_periods(self):
"""
Gets the Period objects for the active year
Returns:
Period<Queryset> -- Periods for an active year
"""
return super().get_queryset().filter(year__active=True)
I wrote something simple to test this particular manager, but am running up against an error which I'm not sure what it means:
File "/dir/path/myapp/models.py", line 44, in <module>
class Period(models.Model):
File "/dir/path/myapp/models.py", line 55, in Period
active_year_periods = PeriodManager().active_year_periods()
File "/dir/path/myapp/managers.py", line 19, in active_year_periods
return self.get_queryset().filter(year__active=True)
File "/dir/path/venv/lib/python3.7/site-packages/django/db/models/query.py", line 892, in filter
return self._filter_or_exclude(False, *args, **kwargs)
File "/dir/path/venv/lib/python3.7/site-packages/django/db/models/query.py", line 910, in _filter_or_exclude
clone.query.add_q(Q(*args, **kwargs))
File "/dir/path/venv/lib/python3.7/site-packages/django/db/models/sql/query.py", line 1290, in add_q
clause, _ = self._add_q(q_object, self.used_aliases)
File "/dir/path/venv/lib/python3.7/site-packages/django/db/models/sql/query.py", line 1318, in _add_q
split_subq=split_subq, simple_col=simple_col,
File "/dir/path/venv/lib/python3.7/site-packages/django/db/models/sql/query.py", line 1190, in build_filter
lookups, parts, reffed_expression = self.solve_lookup_type(arg)
File "/dir/path/venv/lib/python3.7/site-packages/django/db/models/sql/query.py", line 1049, in solve_lookup_type
_, field, _, lookup_parts = self.names_to_path(lookup_splitted, self.get_meta())
File "/dir/path/venv/lib/python3.7/site-packages/django/db/models/sql/query.py", line 297, in get_meta
return self.model._meta
AttributeError: 'NoneType' object has no attribute '_meta'
That error is kicked off before my test will even run - my test is built to fail currently, but it won't even fail because of that error.
Here is my test:
class TestPeriodManager(TestCase):
"""
Test cases for the Period Manager
"""
def setUp(self):
pass
def test_active_year_periods_returns_correct_amount(self):
"""
Test that the PeriodManager active_year_periods method returns
appropriate amount of Periods
"""
# periods_in_active_year = swm.Period.active_year_periods
# print(periods_in_active_year)
self.assertTrue(False)
Any ideas why I might be running into this issue? Am I going about this all wrong?
I'm trying to use custom manager methods so eventually I can pass in arguments for additional filtering where needed.
Upvotes: 0
Views: 637
Reputation: 3920
You need to assign the active_year_periods
(your custom manager) to the manager class, not the method:
models.py:
objects = models.Manager()
active_year_periods = PeriodManager()
Upvotes: 1