mirror of
https://github.com/peeringdb/peeringdb.git
synced 2024-05-11 05:55:09 +00:00
* use new peeringdb client (1.0.0) for pdb_load_data sync (#599) * drop django-mobi for lack of py3/dj2 support (#492) remove django-forms-bootstrap for lack of py3/dj2 support (#492) * black formatted * django2.2 and py3 upgrade (#492) * drop ixlans (#21) ui and api changes * drop local_asn (#168) * org search (#193) * phone number validation (#50) * implement help text tooltips (#228) * Mark own ASN as transit-free (#394) * py3 fix for `pdb_migrate_ixlans` command when writing migration report * pdb_migrate_ixlans: properly handle py3 Runtime error if ixlan dict changes during iteration * set rest DEFAULT_SCHEMA_CLASS to coreapi to fix swagger apidocs fix migration 0027 missing from facsimile manifest * fix swagger doc strings * fix tests that were broken from api doc fixes * fix UniqueFieldValidator for netixlan ipaddress validation that broke during django/drf upgrade * fix org merge tool layout issues * travis config * update pipfile and lock * black formatting * update travis dist * beta mode banner (#411) * add beta banner template (#411) * automatically scheduled sync may not always be on, add a flag that lets us reflect that state in the beta banner message clean up beta banner implementation (#411) * add tests for beta banner (#411)
129 lines
3.7 KiB
Python
129 lines
3.7 KiB
Python
import io
|
|
|
|
from .util import ClientCase, Group
|
|
|
|
from django.core.management import call_command
|
|
from django.contrib.auth import get_user_model
|
|
from django.conf import settings
|
|
|
|
from peeringdb_server.models import REFTAG_MAP
|
|
|
|
|
|
class TestRenumberLans(ClientCase):
|
|
@classmethod
|
|
def setUpTestData(cls):
|
|
super(TestRenumberLans, cls).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=1,
|
|
old="206.223.116.0/23",
|
|
new="206.223.110.0/23",
|
|
commit=True,
|
|
)
|
|
|
|
assert ixlan.ixpfx_set.get(id=1).prefix.compressed == "206.223.110.0/23"
|
|
assert ixlan.netixlan_set.get(id=1).ipaddr4.compressed == "206.223.110.101"
|
|
|
|
call_command(
|
|
"pdb_renumber_lans",
|
|
ix=1,
|
|
old="2001:504:0:1::/64",
|
|
new="2001:504:0:2::/64",
|
|
commit=True,
|
|
)
|
|
|
|
assert ixlan.ixpfx_set.get(id=2).prefix.compressed == "2001:504:0:2::/64"
|
|
assert ixlan.netixlan_set.get(id=1).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 ixpfx in ixlan.ixpfx_set.all():
|
|
ixpfx.delete()
|
|
|
|
for netixlan in ixlan.netixlan_set.all():
|
|
netixlan.delete()
|
|
|
|
call_command(
|
|
"pdb_renumber_lans",
|
|
ix=1,
|
|
old="206.223.116.0/23",
|
|
new="206.223.110.0/23",
|
|
commit=True,
|
|
)
|
|
|
|
assert ixlan.ixpfx_set.get(id=1).prefix.compressed == "206.223.116.0/23"
|
|
assert ixlan.netixlan_set.get(id=1).ipaddr4.compressed == "206.223.116.101"
|
|
|
|
call_command(
|
|
"pdb_renumber_lans",
|
|
ix=1,
|
|
old="2001:504:0:1::/64",
|
|
new="2001:504:0:2::/64",
|
|
commit=True,
|
|
)
|
|
|
|
assert ixlan.ixpfx_set.get(id=2).prefix.compressed == "2001:504:0:1::/64"
|
|
assert ixlan.netixlan_set.get(id=1).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=1,
|
|
old="206.223.114.0/23",
|
|
new="206.223.110.0/23",
|
|
commit=True,
|
|
stdout=out,
|
|
)
|
|
|
|
assert ixlan.ixpfx_set.get(id=1).prefix.compressed == "206.223.116.0/23"
|
|
assert ixlan.netixlan_set.get(id=1).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=1,
|
|
old="2001:504:0:3::/64",
|
|
new="2001:504:0:2::/64",
|
|
commit=True,
|
|
stdout=out,
|
|
)
|
|
|
|
assert ixlan.ixpfx_set.get(id=2).prefix.compressed == "2001:504:0:1::/64"
|
|
assert ixlan.netixlan_set.get(id=1).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
|