diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2021-03-30 15:05:00 +0200 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2021-03-30 15:05:00 +0200 |
commit | 31df459298bf645751520d379d4add93ce9ad9ad (patch) | |
tree | 38ff03cdcd7b07e4f951638054e8ca93dd4ffa10 /archaeological_warehouse | |
parent | fffbad69c962bea546d8193b922b472c886c4023 (diff) | |
download | Ishtar-31df459298bf645751520d379d4add93ce9ad9ad.tar.bz2 Ishtar-31df459298bf645751520d379d4add93ce9ad9ad.zip |
Container: fix index generation when only stationary containers are availables
Diffstat (limited to 'archaeological_warehouse')
-rw-r--r-- | archaeological_warehouse/models.py | 13 | ||||
-rw-r--r-- | archaeological_warehouse/tests.py | 8 |
2 files changed, 11 insertions, 10 deletions
diff --git a/archaeological_warehouse/models.py b/archaeological_warehouse/models.py index 7b694b799..5a852a367 100644 --- a/archaeological_warehouse/models.py +++ b/archaeological_warehouse/models.py @@ -1708,11 +1708,12 @@ class Container( q = q.exclude(id=self.id) if self.index and not q.count(): return - q = Container.objects.filter(location=self.location) - if q.count(): - self.index = int(q.all().aggregate(Max("index"))["index__max"]) + 1 - else: - self.index = 1 + q = Container.objects.filter(location=self.location, index__isnull=False) + self.index = ( + int(q.all().aggregate(Max("index"))["index__max"]) + 1 + if q.count() + else 1 + ) if not self.cached_division: self.cached_division = self._generate_cached_division() @@ -1738,7 +1739,7 @@ class Container( if not self.index and not self.container_type.stationary: self.skip_history_when_saving = True q = ( - Container.objects.filter(location=self.location) + Container.objects.filter(location=self.location, index__isnull=False) .exclude(pk=self.pk) .order_by("-index") ) diff --git a/archaeological_warehouse/tests.py b/archaeological_warehouse/tests.py index 503057cdf..e18d56fae 100644 --- a/archaeological_warehouse/tests.py +++ b/archaeological_warehouse/tests.py @@ -1056,6 +1056,10 @@ class ContainerTest(FindInit, TestCase): base_index = q.all()[0].index else: base_index = 0 + container_3 = models.Container.objects.create( + reference="Ref 3", location=self.main_warehouse, container_type=ct2 + ) + self.assertEqual(container_3.index, None) container_1 = models.Container.objects.create( reference="Ref 1", location=self.main_warehouse, container_type=ct ) @@ -1068,10 +1072,6 @@ class ContainerTest(FindInit, TestCase): self.assertEqual( models.Container.objects.get(pk=container_2.pk).index, base_index + 2 ) - container_3 = models.Container.objects.create( - reference="Ref 3", location=self.main_warehouse, container_type=ct2 - ) - self.assertEqual(container_3.index, None) self.assertEqual(models.Container.objects.get(pk=container_3.pk).index, None) container_4 = models.Container.objects.create( reference="Ref 4", location=self.main_warehouse, container_type=ct2 |