You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I just stumbled on a weird little edge case. I am migrating a ManyToMany field over to a through model, and specifying both through and through_fields on the ManyToMany field on the parent model, example:
and then using this package to write a test roughly like
defprepare(self):
"""Prepare some data before the migration."""User=self.old_state.apps.get_model("auth", "User")
NimbusExperiment=self.old_state.apps.get_model(
"experiments", "NimbusExperiment"
)
user=User.objects.create(email="test@example.com")
parent_experiment=NimbusExperiment.objects.create(
owner=user,
name="test parent experiment",
slug="test-parent-experiment",
application=NimbusConstants.Application.DESKTOP,
status=NimbusConstants.Status.DRAFT,
publish_status=NimbusConstants.PublishStatus.IDLE,
published_dto="{}",
)
required_experiment=NimbusExperiment.objects.create(
owner=user,
name="test required experiment",
slug="test-required-experiment",
application=NimbusConstants.Application.DESKTOP,
status=NimbusConstants.Status.DRAFT,
publish_status=NimbusConstants.PublishStatus.IDLE,
published_dto="{}",
)
parent_experiment.required_experiments.add(required_experiment)
deftest_migration(self):
"""Run the test itself."""NimbusExperiment=self.new_state.apps.get_model(
"experiments", "NimbusExperiment"
)
parent_experiment=NimbusExperiment.objects.get(slug="test-parent-experiment")
self.assertEqual(
set(
parent_experiment.required_experiments.all().values_list(
"slug", flat=True
)
),
{"test-required-experiment"},
)
however this test was failing and I couldn't see any obvious reason why. Digging deeper I found that the generated SQL for the query parent_experiment.required_experiments.all() in the test looked like
and what's interesting is that I get the correct behaviour in ./manage.py shell but not if I pdb inside the test, so something is going wrong inside the test.
Further investigation lead me to find that inside the test I see
In [9]: required_field.remote_field.through_fieldsOut[9]: ('parent_experiment', 'child_experiment')
so somehow the through_fields is None inside the test context and not the tuple it should be, which is causing the relevant method in django here to fall back to the case of looping over fields and finding the first one that matches the model, and finding child_experiment first as we can see here inside a pdb inside the test:
but I also wanted to file it here. Looking through this repo I couldn't find anything that would clearly cause this behaviour, so I'm not sure why through_fields would be None inside the test context, but hopefully the maintainers of this project will have a better idea.
Aside from that I just want to say thank you for this library and we use it constantly and it's made testing migrations much easier 🙏
Oh and this is on django-test-migrations 1.3.0 and Django 3.2.23 (I know this is old)
The text was updated successfully, but these errors were encountered:
Hi,
I just stumbled on a weird little edge case. I am migrating a ManyToMany field over to a through model, and specifying both
through
andthrough_fields
on the ManyToMany field on the parent model, example:and then using this package to write a test roughly like
however this test was failing and I couldn't see any obvious reason why. Digging deeper I found that the generated SQL for the query
parent_experiment.required_experiments.all()
in the test looked likewhereas it should be
and what's interesting is that I get the correct behaviour in
./manage.py shell
but not if I pdb inside the test, so something is going wrong inside the test.Further investigation lead me to find that inside the test I see
whereas in ./manage.py shell I see
so somehow the
through_fields
isNone
inside the test context and not the tuple it should be, which is causing the relevant method in django here to fall back to the case of looping over fields and finding the first one that matches the model, and findingchild_experiment
first as we can see here inside a pdb inside the test:So I was able to rectify this by explicitly setting
through_fields
like so in the test:but I also wanted to file it here. Looking through this repo I couldn't find anything that would clearly cause this behaviour, so I'm not sure why
through_fields
would beNone
inside the test context, but hopefully the maintainers of this project will have a better idea.Aside from that I just want to say thank you for this library and we use it constantly and it's made testing migrations much easier 🙏
Oh and this is on django-test-migrations 1.3.0 and Django 3.2.23 (I know this is old)
The text was updated successfully, but these errors were encountered: