Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 26 additions & 0 deletions netbox/ipam/migrations/0083_vlangroup_populate_total_vlan_ids.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
from django.db import migrations


def populate_vlangroup_total_vlan_ids(apps, schema_editor):
VLANGroup = apps.get_model('ipam', 'VLANGroup')
db = schema_editor.connection.alias

qs = VLANGroup.objects.using(db).only('id', 'vid_ranges')
for group in qs.iterator():
total_vlan_ids = 0
if group.vid_ranges:
for r in group.vid_ranges:
# Half-open [lo, hi): length is (hi - lo).
if r is not None and r.lower is not None and r.upper is not None:
total_vlan_ids += r.upper - r.lower
VLANGroup.objects.using(db).filter(pk=group.pk).update(_total_vlan_ids=total_vlan_ids)


class Migration(migrations.Migration):
dependencies = [
('ipam', '0082_add_prefix_network_containment_indexes'),
]

operations = [
migrations.RunPython(populate_vlangroup_total_vlan_ids, migrations.RunPython.noop),
]
3 changes: 2 additions & 1 deletion netbox/ipam/models/vlans.py
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,8 @@ def clean(self):
def save(self, *args, **kwargs):
self._total_vlan_ids = 0
for vid_range in self.vid_ranges:
self._total_vlan_ids += vid_range.upper - vid_range.lower + 1
# VID range is inclusive on lower-bound, exclusive on upper-bound
self._total_vlan_ids += vid_range.upper - vid_range.lower

super().save(*args, **kwargs)

Expand Down
4 changes: 4 additions & 0 deletions netbox/ipam/tests/test_models.py
Original file line number Diff line number Diff line change
Expand Up @@ -661,6 +661,10 @@ def test_overlapping_vlan(self):
vlangroup.full_clean()
vlangroup.save()

def test_total_vlan_ids(self):
vlangroup = VLANGroup.objects.first()
self.assertEqual(vlangroup._total_vlan_ids, 100)


class TestVLAN(TestCase):

Expand Down