1
0
mirror of https://github.com/peeringdb/peeringdb.git synced 2024-05-11 05:55:09 +00:00
Files
peeringdb-peeringdb/tests/test_cmd_renumber_lans.py
Stefan Pratter 3ee0d1ea5e Support 202205 (#1188)
* Add "Last login" to https://peeringdb.com/cp/peeringdb_server/user/ #879

* Bug in renumbering tool #660

* Add the IX name and id to IX-F Import Emails #963

* Use username to create deskpro person when no first-name / last-name data exists #1057

* Organization merge tool usergroup issues #930

* Exempt superusers (PeeringDB Admin Committee & Operations Committee admins) from throttling #1172

* add missing migration for #1172

* linting

* poetry relock

* adapt to django-two-factor-auth template-tag renaming changes

* increase default for DATA_QUALITY_MAX_SPEED to 5Tb

* regenerate docs

* fix api test for netixlan max speed validation

* pdb_api_cache command needs to disable CSRF_USE_SESSIONS before it runs

Co-authored-by: David Poarch <dpoarch@20c.com>
2022-06-15 07:23:26 -05:00

129 lines
3.7 KiB
Python

import io
from django.conf import settings
from django.contrib.auth import get_user_model
from django.core.management import call_command
from peeringdb_server.models import REFTAG_MAP
from .util import ClientCase, Group
class TestRenumberLans(ClientCase):
@classmethod
def setUpTestData(cls):
super().setUpTestData()
call_command("pdb_generate_test_data", limit=1, commit=True)
def test_run(self):
"""
test a successful execution of the `pdb_renumber_lans` command
"""
ix = REFTAG_MAP["ix"].objects.all().first()
ixlan = ix.ixlan_set_active.all().first()
call_command(
"pdb_renumber_lans",
ix=ix.id,
old="206.223.116.0/23",
new="206.224.116.0/23",
commit=True,
)
assert ixlan.ixpfx_set.first().prefix.compressed == "206.224.116.0/23"
assert ixlan.netixlan_set.first().ipaddr4.compressed == "206.224.116.101"
call_command(
"pdb_renumber_lans",
ix=ix.id,
old="2001:504:0:1::/64",
new="2001:504:0:2::/64",
commit=True,
)
assert ixlan.ixpfx_set.last().prefix.compressed == "2001:504:0:2::/64"
assert ixlan.netixlan_set.first().ipaddr6.compressed == "2001:504:0:2::65"
def test_skip_deleted(self):
"""
test that `pdb_renumber_lans` command skips deleted prefixes and
netixlans
"""
ix = REFTAG_MAP["ix"].objects.all().first()
ixlan = ix.ixlan_set_active.all().first()
for netixlan in ixlan.netixlan_set.all():
netixlan.delete()
for ixpfx in ixlan.ixpfx_set.all():
ixpfx.delete()
call_command(
"pdb_renumber_lans",
ix=ix.id,
old="206.223.116.0/23",
new="206.223.110.0/23",
commit=True,
)
assert ixlan.ixpfx_set.first().prefix.compressed == "206.223.116.0/23"
assert ixlan.netixlan_set.first().ipaddr4.compressed == "206.223.116.101"
call_command(
"pdb_renumber_lans",
ix=ix.id,
old="2001:504:0:1::/64",
new="2001:504:0:2::/64",
commit=True,
)
assert ixlan.ixpfx_set.last().prefix.compressed == "2001:504:0:1::/64"
assert ixlan.netixlan_set.first().ipaddr6.compressed == "2001:504:0:1::65"
def test_ignore_diff_address_space(self):
""" "
Test that `pdb_renumber_lans` command soft errors on netixlans that
arent in the specified address space (but exist on the ixlan)
"""
ix = REFTAG_MAP["ix"].objects.all().first()
ixlan = ix.ixlan_set_active.all().first()
out = io.StringIO()
call_command(
"pdb_renumber_lans",
ix=ix.id,
old="206.223.114.0/23",
new="206.223.110.0/23",
commit=True,
stdout=out,
)
assert ixlan.ixpfx_set.first().prefix.compressed == "206.223.116.0/23"
assert ixlan.netixlan_set.first().ipaddr4.compressed == "206.223.116.101"
output = out.getvalue()
assert "[error] 206.223.116.101: Ip address not within old prefix" in output
call_command(
"pdb_renumber_lans",
ix=ix.id,
old="2001:504:0:3::/64",
new="2001:504:0:2::/64",
commit=True,
stdout=out,
)
assert ixlan.ixpfx_set.last().prefix.compressed == "2001:504:0:1::/64"
assert ixlan.netixlan_set.first().ipaddr6.compressed == "2001:504:0:1::65"
output = out.getvalue()
assert "[error] 2001:504:0:1::65: Ip address not within old prefix" in output