|
|
@@ -1,26 +1,18 @@
|
|
|
-from netaddr import IPNetwork
|
|
|
-import urllib.parse
|
|
|
+import datetime
|
|
|
|
|
|
-from django.test import Client, TestCase
|
|
|
-from django.urls import reverse
|
|
|
+from netaddr import IPNetwork
|
|
|
|
|
|
from dcim.models import Device, DeviceRole, DeviceType, Manufacturer, Site
|
|
|
-from ipam.choices import ServiceProtocolChoices
|
|
|
+from ipam.choices import *
|
|
|
from ipam.models import Aggregate, IPAddress, Prefix, RIR, Role, Service, VLAN, VLANGroup, VRF
|
|
|
-from utilities.testing import create_test_user
|
|
|
+from utilities.testing import StandardTestCases
|
|
|
|
|
|
|
|
|
-class VRFTestCase(TestCase):
|
|
|
+class VRFTestCase(StandardTestCases.Views):
|
|
|
+ model = VRF
|
|
|
|
|
|
- def setUp(self):
|
|
|
- user = create_test_user(
|
|
|
- permissions=[
|
|
|
- 'ipam.view_vrf',
|
|
|
- 'ipam.add_vrf',
|
|
|
- ]
|
|
|
- )
|
|
|
- self.client = Client()
|
|
|
- self.client.force_login(user)
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
|
|
|
VRF.objects.bulk_create([
|
|
|
VRF(name='VRF 1', rd='65000:1'),
|
|
|
@@ -28,48 +20,39 @@ class VRFTestCase(TestCase):
|
|
|
VRF(name='VRF 3', rd='65000:3'),
|
|
|
])
|
|
|
|
|
|
- def test_vrf_list(self):
|
|
|
-
|
|
|
- url = reverse('ipam:vrf_list')
|
|
|
- params = {
|
|
|
- "q": "65000",
|
|
|
+ cls.form_data = {
|
|
|
+ 'name': 'VRF X',
|
|
|
+ 'rd': '65000:999',
|
|
|
+ 'tenant': None,
|
|
|
+ 'enforce_unique': True,
|
|
|
+ 'description': 'A new VRF',
|
|
|
+ 'tags': 'Alpha,Bravo,Charlie',
|
|
|
}
|
|
|
|
|
|
- response = self.client.get('{}?{}'.format(url, urllib.parse.urlencode(params)))
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_vrf(self):
|
|
|
-
|
|
|
- vrf = VRF.objects.first()
|
|
|
- response = self.client.get(vrf.get_absolute_url())
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_vrf_import(self):
|
|
|
-
|
|
|
- csv_data = (
|
|
|
+ cls.csv_data = (
|
|
|
"name",
|
|
|
"VRF 4",
|
|
|
"VRF 5",
|
|
|
"VRF 6",
|
|
|
)
|
|
|
|
|
|
- response = self.client.post(reverse('ipam:vrf_import'), {'csv': '\n'.join(csv_data)})
|
|
|
+ cls.bulk_edit_data = {
|
|
|
+ 'tenant': None,
|
|
|
+ 'enforce_unique': False,
|
|
|
+ 'description': 'New description',
|
|
|
+ }
|
|
|
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
- self.assertEqual(VRF.objects.count(), 6)
|
|
|
|
|
|
+class RIRTestCase(StandardTestCases.Views):
|
|
|
+ model = RIR
|
|
|
|
|
|
-class RIRTestCase(TestCase):
|
|
|
+ # Disable inapplicable tests
|
|
|
+ test_get_object = None
|
|
|
+ test_delete_object = None
|
|
|
+ test_bulk_edit_objects = None
|
|
|
|
|
|
- def setUp(self):
|
|
|
- user = create_test_user(
|
|
|
- permissions=[
|
|
|
- 'ipam.view_rir',
|
|
|
- 'ipam.add_rir',
|
|
|
- ]
|
|
|
- )
|
|
|
- self.client = Client()
|
|
|
- self.client.force_login(user)
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
|
|
|
RIR.objects.bulk_create([
|
|
|
RIR(name='RIR 1', slug='rir-1'),
|
|
|
@@ -77,91 +60,71 @@ class RIRTestCase(TestCase):
|
|
|
RIR(name='RIR 3', slug='rir-3'),
|
|
|
])
|
|
|
|
|
|
- def test_rir_list(self):
|
|
|
-
|
|
|
- url = reverse('ipam:rir_list')
|
|
|
-
|
|
|
- response = self.client.get(url)
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_rir_import(self):
|
|
|
+ cls.form_data = {
|
|
|
+ 'name': 'RIR X',
|
|
|
+ 'slug': 'rir-x',
|
|
|
+ 'is_private': True,
|
|
|
+ }
|
|
|
|
|
|
- csv_data = (
|
|
|
+ cls.csv_data = (
|
|
|
"name,slug",
|
|
|
"RIR 4,rir-4",
|
|
|
"RIR 5,rir-5",
|
|
|
"RIR 6,rir-6",
|
|
|
)
|
|
|
|
|
|
- response = self.client.post(reverse('ipam:rir_import'), {'csv': '\n'.join(csv_data)})
|
|
|
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
- self.assertEqual(RIR.objects.count(), 6)
|
|
|
+class AggregateTestCase(StandardTestCases.Views):
|
|
|
+ model = Aggregate
|
|
|
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
|
|
|
-class AggregateTestCase(TestCase):
|
|
|
-
|
|
|
- def setUp(self):
|
|
|
- user = create_test_user(
|
|
|
- permissions=[
|
|
|
- 'ipam.view_aggregate',
|
|
|
- 'ipam.add_aggregate',
|
|
|
- ]
|
|
|
+ rirs = (
|
|
|
+ RIR(name='RIR 1', slug='rir-1'),
|
|
|
+ RIR(name='RIR 2', slug='rir-2'),
|
|
|
)
|
|
|
- self.client = Client()
|
|
|
- self.client.force_login(user)
|
|
|
-
|
|
|
- rir = RIR(name='RIR 1', slug='rir-1')
|
|
|
- rir.save()
|
|
|
+ RIR.objects.bulk_create(rirs)
|
|
|
|
|
|
Aggregate.objects.bulk_create([
|
|
|
- Aggregate(family=4, prefix=IPNetwork('10.1.0.0/16'), rir=rir),
|
|
|
- Aggregate(family=4, prefix=IPNetwork('10.2.0.0/16'), rir=rir),
|
|
|
- Aggregate(family=4, prefix=IPNetwork('10.3.0.0/16'), rir=rir),
|
|
|
+ Aggregate(family=4, prefix=IPNetwork('10.1.0.0/16'), rir=rirs[0]),
|
|
|
+ Aggregate(family=4, prefix=IPNetwork('10.2.0.0/16'), rir=rirs[0]),
|
|
|
+ Aggregate(family=4, prefix=IPNetwork('10.3.0.0/16'), rir=rirs[0]),
|
|
|
])
|
|
|
|
|
|
- def test_aggregate_list(self):
|
|
|
-
|
|
|
- url = reverse('ipam:aggregate_list')
|
|
|
- params = {
|
|
|
- "rir": RIR.objects.first().slug,
|
|
|
+ cls.form_data = {
|
|
|
+ 'family': 4,
|
|
|
+ 'prefix': IPNetwork('10.99.0.0/16'),
|
|
|
+ 'rir': rirs[1].pk,
|
|
|
+ 'date_added': datetime.date(2020, 1, 1),
|
|
|
+ 'description': 'A new aggregate',
|
|
|
+ 'tags': 'Alpha,Bravo,Charlie',
|
|
|
}
|
|
|
|
|
|
- response = self.client.get('{}?{}'.format(url, urllib.parse.urlencode(params)))
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_aggregate(self):
|
|
|
-
|
|
|
- aggregate = Aggregate.objects.first()
|
|
|
- response = self.client.get(aggregate.get_absolute_url())
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_aggregate_import(self):
|
|
|
-
|
|
|
- csv_data = (
|
|
|
+ cls.csv_data = (
|
|
|
"prefix,rir",
|
|
|
"10.4.0.0/16,RIR 1",
|
|
|
"10.5.0.0/16,RIR 1",
|
|
|
"10.6.0.0/16,RIR 1",
|
|
|
)
|
|
|
|
|
|
- response = self.client.post(reverse('ipam:aggregate_import'), {'csv': '\n'.join(csv_data)})
|
|
|
+ cls.bulk_edit_data = {
|
|
|
+ 'rir': rirs[1].pk,
|
|
|
+ 'date_added': datetime.date(2020, 1, 1),
|
|
|
+ 'description': 'New description',
|
|
|
+ }
|
|
|
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
- self.assertEqual(Aggregate.objects.count(), 6)
|
|
|
|
|
|
+class RoleTestCase(StandardTestCases.Views):
|
|
|
+ model = Role
|
|
|
|
|
|
-class RoleTestCase(TestCase):
|
|
|
+ # Disable inapplicable tests
|
|
|
+ test_get_object = None
|
|
|
+ test_delete_object = None
|
|
|
+ test_bulk_edit_objects = None
|
|
|
|
|
|
- def setUp(self):
|
|
|
- user = create_test_user(
|
|
|
- permissions=[
|
|
|
- 'ipam.view_role',
|
|
|
- 'ipam.add_role',
|
|
|
- ]
|
|
|
- )
|
|
|
- self.client = Client()
|
|
|
- self.client.force_login(user)
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
|
|
|
Role.objects.bulk_create([
|
|
|
Role(name='Role 1', slug='role-1'),
|
|
|
@@ -169,146 +132,140 @@ class RoleTestCase(TestCase):
|
|
|
Role(name='Role 3', slug='role-3'),
|
|
|
])
|
|
|
|
|
|
- def test_role_list(self):
|
|
|
-
|
|
|
- url = reverse('ipam:role_list')
|
|
|
-
|
|
|
- response = self.client.get(url)
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_role_import(self):
|
|
|
+ cls.form_data = {
|
|
|
+ 'name': 'Role X',
|
|
|
+ 'slug': 'role-x',
|
|
|
+ 'weight': 200,
|
|
|
+ 'description': 'A new role',
|
|
|
+ }
|
|
|
|
|
|
- csv_data = (
|
|
|
+ cls.csv_data = (
|
|
|
"name,slug,weight",
|
|
|
"Role 4,role-4,1000",
|
|
|
"Role 5,role-5,1000",
|
|
|
"Role 6,role-6,1000",
|
|
|
)
|
|
|
|
|
|
- response = self.client.post(reverse('ipam:role_import'), {'csv': '\n'.join(csv_data)})
|
|
|
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
- self.assertEqual(Role.objects.count(), 6)
|
|
|
+class PrefixTestCase(StandardTestCases.Views):
|
|
|
+ model = Prefix
|
|
|
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
|
|
|
-class PrefixTestCase(TestCase):
|
|
|
+ sites = (
|
|
|
+ Site(name='Site 1', slug='site-1'),
|
|
|
+ Site(name='Site 2', slug='site-2'),
|
|
|
+ )
|
|
|
+ Site.objects.bulk_create(sites)
|
|
|
|
|
|
- def setUp(self):
|
|
|
- user = create_test_user(
|
|
|
- permissions=[
|
|
|
- 'ipam.view_prefix',
|
|
|
- 'ipam.add_prefix',
|
|
|
- ]
|
|
|
+ vrfs = (
|
|
|
+ VRF(name='VRF 1', rd='65000:1'),
|
|
|
+ VRF(name='VRF 2', rd='65000:2'),
|
|
|
)
|
|
|
- self.client = Client()
|
|
|
- self.client.force_login(user)
|
|
|
+ VRF.objects.bulk_create(vrfs)
|
|
|
|
|
|
- site = Site(name='Site 1', slug='site-1')
|
|
|
- site.save()
|
|
|
+ roles = (
|
|
|
+ Role(name='Role 1', slug='role-1'),
|
|
|
+ Role(name='Role 2', slug='role-2'),
|
|
|
+ )
|
|
|
|
|
|
Prefix.objects.bulk_create([
|
|
|
- Prefix(family=4, prefix=IPNetwork('10.1.0.0/16'), site=site),
|
|
|
- Prefix(family=4, prefix=IPNetwork('10.2.0.0/16'), site=site),
|
|
|
- Prefix(family=4, prefix=IPNetwork('10.3.0.0/16'), site=site),
|
|
|
+ Prefix(family=4, prefix=IPNetwork('10.1.0.0/16'), vrf=vrfs[0], site=sites[0], role=roles[0]),
|
|
|
+ Prefix(family=4, prefix=IPNetwork('10.2.0.0/16'), vrf=vrfs[0], site=sites[0], role=roles[0]),
|
|
|
+ Prefix(family=4, prefix=IPNetwork('10.3.0.0/16'), vrf=vrfs[0], site=sites[0], role=roles[0]),
|
|
|
])
|
|
|
|
|
|
- def test_prefix_list(self):
|
|
|
-
|
|
|
- url = reverse('ipam:prefix_list')
|
|
|
- params = {
|
|
|
- "site": Site.objects.first().slug,
|
|
|
+ cls.form_data = {
|
|
|
+ 'prefix': IPNetwork('192.0.2.0/24'),
|
|
|
+ 'site': sites[1].pk,
|
|
|
+ 'vrf': vrfs[1].pk,
|
|
|
+ 'tenant': None,
|
|
|
+ 'vlan': None,
|
|
|
+ 'status': PrefixStatusChoices.STATUS_RESERVED,
|
|
|
+ 'role': roles[1].pk,
|
|
|
+ 'is_pool': True,
|
|
|
+ 'description': 'A new prefix',
|
|
|
+ 'tags': 'Alpha,Bravo,Charlie',
|
|
|
}
|
|
|
|
|
|
- response = self.client.get('{}?{}'.format(url, urllib.parse.urlencode(params)))
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_prefix(self):
|
|
|
-
|
|
|
- prefix = Prefix.objects.first()
|
|
|
- response = self.client.get(prefix.get_absolute_url())
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_prefix_import(self):
|
|
|
-
|
|
|
- csv_data = (
|
|
|
+ cls.csv_data = (
|
|
|
"prefix,status",
|
|
|
"10.4.0.0/16,Active",
|
|
|
"10.5.0.0/16,Active",
|
|
|
"10.6.0.0/16,Active",
|
|
|
)
|
|
|
|
|
|
- response = self.client.post(reverse('ipam:prefix_import'), {'csv': '\n'.join(csv_data)})
|
|
|
+ cls.bulk_edit_data = {
|
|
|
+ 'site': sites[1].pk,
|
|
|
+ 'vrf': vrfs[1].pk,
|
|
|
+ 'tenant': None,
|
|
|
+ 'status': PrefixStatusChoices.STATUS_RESERVED,
|
|
|
+ 'role': roles[1].pk,
|
|
|
+ 'is_pool': False,
|
|
|
+ 'description': 'New description',
|
|
|
+ }
|
|
|
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
- self.assertEqual(Prefix.objects.count(), 6)
|
|
|
|
|
|
+class IPAddressTestCase(StandardTestCases.Views):
|
|
|
+ model = IPAddress
|
|
|
|
|
|
-class IPAddressTestCase(TestCase):
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
|
|
|
- def setUp(self):
|
|
|
- user = create_test_user(
|
|
|
- permissions=[
|
|
|
- 'ipam.view_ipaddress',
|
|
|
- 'ipam.add_ipaddress',
|
|
|
- ]
|
|
|
+ vrfs = (
|
|
|
+ VRF(name='VRF 1', rd='65000:1'),
|
|
|
+ VRF(name='VRF 2', rd='65000:2'),
|
|
|
)
|
|
|
- self.client = Client()
|
|
|
- self.client.force_login(user)
|
|
|
-
|
|
|
- vrf = VRF(name='VRF 1', rd='65000:1')
|
|
|
- vrf.save()
|
|
|
|
|
|
IPAddress.objects.bulk_create([
|
|
|
- IPAddress(family=4, address=IPNetwork('192.0.2.1/24'), vrf=vrf),
|
|
|
- IPAddress(family=4, address=IPNetwork('192.0.2.2/24'), vrf=vrf),
|
|
|
- IPAddress(family=4, address=IPNetwork('192.0.2.3/24'), vrf=vrf),
|
|
|
+ IPAddress(family=4, address=IPNetwork('192.0.2.1/24'), vrf=vrfs[0]),
|
|
|
+ IPAddress(family=4, address=IPNetwork('192.0.2.2/24'), vrf=vrfs[0]),
|
|
|
+ IPAddress(family=4, address=IPNetwork('192.0.2.3/24'), vrf=vrfs[0]),
|
|
|
])
|
|
|
|
|
|
- def test_ipaddress_list(self):
|
|
|
-
|
|
|
- url = reverse('ipam:ipaddress_list')
|
|
|
- params = {
|
|
|
- "vrf": VRF.objects.first().rd,
|
|
|
+ cls.form_data = {
|
|
|
+ 'vrf': vrfs[1].pk,
|
|
|
+ 'address': IPNetwork('192.0.2.99/24'),
|
|
|
+ 'tenant': None,
|
|
|
+ 'status': IPAddressStatusChoices.STATUS_RESERVED,
|
|
|
+ 'role': IPAddressRoleChoices.ROLE_ANYCAST,
|
|
|
+ 'interface': None,
|
|
|
+ 'nat_inside': None,
|
|
|
+ 'dns_name': 'example',
|
|
|
+ 'description': 'A new IP address',
|
|
|
+ 'tags': 'Alpha,Bravo,Charlie',
|
|
|
}
|
|
|
|
|
|
- response = self.client.get('{}?{}'.format(url, urllib.parse.urlencode(params)))
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_ipaddress(self):
|
|
|
-
|
|
|
- ipaddress = IPAddress.objects.first()
|
|
|
- response = self.client.get(ipaddress.get_absolute_url())
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_ipaddress_import(self):
|
|
|
-
|
|
|
- csv_data = (
|
|
|
+ cls.csv_data = (
|
|
|
"address,status",
|
|
|
"192.0.2.4/24,Active",
|
|
|
"192.0.2.5/24,Active",
|
|
|
"192.0.2.6/24,Active",
|
|
|
)
|
|
|
|
|
|
- response = self.client.post(reverse('ipam:ipaddress_import'), {'csv': '\n'.join(csv_data)})
|
|
|
+ cls.bulk_edit_data = {
|
|
|
+ 'vrf': vrfs[1].pk,
|
|
|
+ 'tenant': None,
|
|
|
+ 'status': IPAddressStatusChoices.STATUS_RESERVED,
|
|
|
+ 'role': IPAddressRoleChoices.ROLE_ANYCAST,
|
|
|
+ 'dns_name': 'example',
|
|
|
+ 'description': 'New description',
|
|
|
+ }
|
|
|
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
- self.assertEqual(IPAddress.objects.count(), 6)
|
|
|
|
|
|
+class VLANGroupTestCase(StandardTestCases.Views):
|
|
|
+ model = VLANGroup
|
|
|
|
|
|
-class VLANGroupTestCase(TestCase):
|
|
|
+ # Disable inapplicable tests
|
|
|
+ test_get_object = None
|
|
|
+ test_delete_object = None
|
|
|
+ test_bulk_edit_objects = None
|
|
|
|
|
|
- def setUp(self):
|
|
|
- user = create_test_user(
|
|
|
- permissions=[
|
|
|
- 'ipam.view_vlangroup',
|
|
|
- 'ipam.add_vlangroup',
|
|
|
- ]
|
|
|
- )
|
|
|
- self.client = Client()
|
|
|
- self.client.force_login(user)
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
|
|
|
- site = Site(name='Site 1', slug='site-1')
|
|
|
- site.save()
|
|
|
+ site = Site.objects.create(name='Site 1', slug='site-1')
|
|
|
|
|
|
VLANGroup.objects.bulk_create([
|
|
|
VLANGroup(name='VLAN Group 1', slug='vlan-group-1', site=site),
|
|
|
@@ -316,104 +273,96 @@ class VLANGroupTestCase(TestCase):
|
|
|
VLANGroup(name='VLAN Group 3', slug='vlan-group-3', site=site),
|
|
|
])
|
|
|
|
|
|
- def test_vlangroup_list(self):
|
|
|
-
|
|
|
- url = reverse('ipam:vlangroup_list')
|
|
|
- params = {
|
|
|
- "site": Site.objects.first().slug,
|
|
|
+ cls.form_data = {
|
|
|
+ 'name': 'VLAN Group X',
|
|
|
+ 'slug': 'vlan-group-x',
|
|
|
+ 'site': site.pk,
|
|
|
}
|
|
|
|
|
|
- response = self.client.get('{}?{}'.format(url, urllib.parse.urlencode(params)))
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_vlangroup_import(self):
|
|
|
-
|
|
|
- csv_data = (
|
|
|
+ cls.csv_data = (
|
|
|
"name,slug",
|
|
|
"VLAN Group 4,vlan-group-4",
|
|
|
"VLAN Group 5,vlan-group-5",
|
|
|
"VLAN Group 6,vlan-group-6",
|
|
|
)
|
|
|
|
|
|
- response = self.client.post(reverse('ipam:vlangroup_import'), {'csv': '\n'.join(csv_data)})
|
|
|
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
- self.assertEqual(VLANGroup.objects.count(), 6)
|
|
|
+class VLANTestCase(StandardTestCases.Views):
|
|
|
+ model = VLAN
|
|
|
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
|
|
|
-class VLANTestCase(TestCase):
|
|
|
+ sites = (
|
|
|
+ Site(name='Site 1', slug='site-1'),
|
|
|
+ Site(name='Site 2', slug='site-2'),
|
|
|
+ )
|
|
|
+ Site.objects.bulk_create(sites)
|
|
|
|
|
|
- def setUp(self):
|
|
|
- user = create_test_user(
|
|
|
- permissions=[
|
|
|
- 'ipam.view_vlan',
|
|
|
- 'ipam.add_vlan',
|
|
|
- ]
|
|
|
+ vlangroups = (
|
|
|
+ VLANGroup(name='VLAN Group 1', slug='vlan-group-1', site=sites[0]),
|
|
|
+ VLANGroup(name='VLAN Group 2', slug='vlan-group-2', site=sites[1]),
|
|
|
)
|
|
|
- self.client = Client()
|
|
|
- self.client.force_login(user)
|
|
|
+ VLANGroup.objects.bulk_create(vlangroups)
|
|
|
|
|
|
- vlangroup = VLANGroup(name='VLAN Group 1', slug='vlan-group-1')
|
|
|
- vlangroup.save()
|
|
|
+ roles = (
|
|
|
+ Role(name='Role 1', slug='role-1'),
|
|
|
+ Role(name='Role 2', slug='role-2'),
|
|
|
+ )
|
|
|
+ Role.objects.bulk_create(roles)
|
|
|
|
|
|
VLAN.objects.bulk_create([
|
|
|
- VLAN(group=vlangroup, vid=101, name='VLAN101'),
|
|
|
- VLAN(group=vlangroup, vid=102, name='VLAN102'),
|
|
|
- VLAN(group=vlangroup, vid=103, name='VLAN103'),
|
|
|
+ VLAN(group=vlangroups[0], vid=101, name='VLAN101', site=sites[0], role=roles[0]),
|
|
|
+ VLAN(group=vlangroups[0], vid=102, name='VLAN102', site=sites[0], role=roles[0]),
|
|
|
+ VLAN(group=vlangroups[0], vid=103, name='VLAN103', site=sites[0], role=roles[0]),
|
|
|
])
|
|
|
|
|
|
- def test_vlan_list(self):
|
|
|
-
|
|
|
- url = reverse('ipam:vlan_list')
|
|
|
- params = {
|
|
|
- "group": VLANGroup.objects.first().slug,
|
|
|
+ cls.form_data = {
|
|
|
+ 'site': sites[1].pk,
|
|
|
+ 'group': vlangroups[1].pk,
|
|
|
+ 'vid': 999,
|
|
|
+ 'name': 'VLAN999',
|
|
|
+ 'tenant': None,
|
|
|
+ 'status': VLANStatusChoices.STATUS_RESERVED,
|
|
|
+ 'role': roles[1].pk,
|
|
|
+ 'description': 'A new VLAN',
|
|
|
+ 'tags': 'Alpha,Bravo,Charlie',
|
|
|
}
|
|
|
|
|
|
- response = self.client.get('{}?{}'.format(url, urllib.parse.urlencode(params)))
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_vlan(self):
|
|
|
-
|
|
|
- vlan = VLAN.objects.first()
|
|
|
- response = self.client.get(vlan.get_absolute_url())
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_vlan_import(self):
|
|
|
-
|
|
|
- csv_data = (
|
|
|
+ cls.csv_data = (
|
|
|
"vid,name,status",
|
|
|
"104,VLAN104,Active",
|
|
|
"105,VLAN105,Active",
|
|
|
"106,VLAN106,Active",
|
|
|
)
|
|
|
|
|
|
- response = self.client.post(reverse('ipam:vlan_import'), {'csv': '\n'.join(csv_data)})
|
|
|
-
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
- self.assertEqual(VLAN.objects.count(), 6)
|
|
|
-
|
|
|
-
|
|
|
-class ServiceTestCase(TestCase):
|
|
|
+ cls.bulk_edit_data = {
|
|
|
+ 'site': sites[1].pk,
|
|
|
+ 'group': vlangroups[1].pk,
|
|
|
+ 'tenant': None,
|
|
|
+ 'status': VLANStatusChoices.STATUS_RESERVED,
|
|
|
+ 'role': roles[1].pk,
|
|
|
+ 'description': 'New description',
|
|
|
+ }
|
|
|
|
|
|
- def setUp(self):
|
|
|
- user = create_test_user(permissions=['ipam.view_service'])
|
|
|
- self.client = Client()
|
|
|
- self.client.force_login(user)
|
|
|
|
|
|
- site = Site(name='Site 1', slug='site-1')
|
|
|
- site.save()
|
|
|
+class ServiceTestCase(StandardTestCases.Views):
|
|
|
+ model = Service
|
|
|
|
|
|
- manufacturer = Manufacturer(name='Manufacturer 1', slug='manufacturer-1')
|
|
|
- manufacturer.save()
|
|
|
+ # Disable inapplicable tests
|
|
|
+ test_import_objects = None
|
|
|
|
|
|
- devicetype = DeviceType(manufacturer=manufacturer, model='Device Type 1')
|
|
|
- devicetype.save()
|
|
|
+ # TODO: Resolve URL for Service creation
|
|
|
+ test_create_object = None
|
|
|
|
|
|
- devicerole = DeviceRole(name='Device Role 1', slug='device-role-1')
|
|
|
- devicerole.save()
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
|
|
|
- device = Device(name='Device 1', site=site, device_type=devicetype, device_role=devicerole)
|
|
|
- device.save()
|
|
|
+ site = Site.objects.create(name='Site 1', slug='site-1')
|
|
|
+ manufacturer = Manufacturer.objects.create(name='Manufacturer 1', slug='manufacturer-1')
|
|
|
+ devicetype = DeviceType.objects.create(manufacturer=manufacturer, model='Device Type 1')
|
|
|
+ devicerole = DeviceRole.objects.create(name='Device Role 1', slug='device-role-1')
|
|
|
+ device = Device.objects.create(name='Device 1', site=site, device_type=devicetype, device_role=devicerole)
|
|
|
|
|
|
Service.objects.bulk_create([
|
|
|
Service(device=device, name='Service 1', protocol=ServiceProtocolChoices.PROTOCOL_TCP, port=101),
|
|
|
@@ -421,18 +370,19 @@ class ServiceTestCase(TestCase):
|
|
|
Service(device=device, name='Service 3', protocol=ServiceProtocolChoices.PROTOCOL_TCP, port=103),
|
|
|
])
|
|
|
|
|
|
- def test_service_list(self):
|
|
|
-
|
|
|
- url = reverse('ipam:service_list')
|
|
|
- params = {
|
|
|
- "device_id": Device.objects.first(),
|
|
|
+ cls.form_data = {
|
|
|
+ 'device': device.pk,
|
|
|
+ 'virtual_machine': None,
|
|
|
+ 'name': 'Service X',
|
|
|
+ 'protocol': ServiceProtocolChoices.PROTOCOL_TCP,
|
|
|
+ 'port': 999,
|
|
|
+ 'ipaddresses': [],
|
|
|
+ 'description': 'A new service',
|
|
|
+ 'tags': 'Alpha,Bravo,Charlie',
|
|
|
}
|
|
|
|
|
|
- response = self.client.get('{}?{}'.format(url, urllib.parse.urlencode(params)))
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
-
|
|
|
- def test_service(self):
|
|
|
-
|
|
|
- service = Service.objects.first()
|
|
|
- response = self.client.get(service.get_absolute_url())
|
|
|
- self.assertEqual(response.status_code, 200)
|
|
|
+ cls.bulk_edit_data = {
|
|
|
+ 'protocol': ServiceProtocolChoices.PROTOCOL_UDP,
|
|
|
+ 'port': 888,
|
|
|
+ 'description': 'New description',
|
|
|
+ }
|