mirror of
https://github.com/netbox-community/netbox.git
synced 2025-07-17 20:46:30 -06:00
Merge pull request #1925 from lampwins/bug/1921
fixed #1921 - create interfaces with 802.1q in api
This commit is contained in:
commit
d48c450018
@ -743,7 +743,7 @@ class WritableInterfaceSerializer(ValidatedModelSerializer):
|
|||||||
if vlan.site not in [device.site, None]:
|
if vlan.site not in [device.site, None]:
|
||||||
raise serializers.ValidationError({
|
raise serializers.ValidationError({
|
||||||
'tagged_vlans': "VLAN {} must belong to the same site as the interface's parent device, or it must "
|
'tagged_vlans': "VLAN {} must belong to the same site as the interface's parent device, or it must "
|
||||||
"be global.".format(vlan)
|
"be global.".format(vlan)
|
||||||
})
|
})
|
||||||
|
|
||||||
return super(WritableInterfaceSerializer, self).validate(data)
|
return super(WritableInterfaceSerializer, self).validate(data)
|
||||||
|
@ -12,6 +12,7 @@ from dcim.models import (
|
|||||||
InventoryItem, Platform, PowerPort, PowerPortTemplate, PowerOutlet, PowerOutletTemplate, Rack, RackGroup,
|
InventoryItem, Platform, PowerPort, PowerPortTemplate, PowerOutlet, PowerOutletTemplate, Rack, RackGroup,
|
||||||
RackReservation, RackRole, Region, Site, VirtualChassis,
|
RackReservation, RackRole, Region, Site, VirtualChassis,
|
||||||
)
|
)
|
||||||
|
from ipam.models import VLAN
|
||||||
from extras.models import Graph, GRAPH_TYPE_INTERFACE, GRAPH_TYPE_SITE
|
from extras.models import Graph, GRAPH_TYPE_INTERFACE, GRAPH_TYPE_SITE
|
||||||
from users.models import Token
|
from users.models import Token
|
||||||
from utilities.tests import HttpStatusMixin
|
from utilities.tests import HttpStatusMixin
|
||||||
@ -2258,6 +2259,10 @@ class InterfaceTest(HttpStatusMixin, APITestCase):
|
|||||||
self.interface2 = Interface.objects.create(device=self.device, name='Test Interface 2')
|
self.interface2 = Interface.objects.create(device=self.device, name='Test Interface 2')
|
||||||
self.interface3 = Interface.objects.create(device=self.device, name='Test Interface 3')
|
self.interface3 = Interface.objects.create(device=self.device, name='Test Interface 3')
|
||||||
|
|
||||||
|
self.vlan1 = VLAN.objects.create(name="Test VLAN 1", vid=1)
|
||||||
|
self.vlan2 = VLAN.objects.create(name="Test VLAN 2", vid=2)
|
||||||
|
self.vlan3 = VLAN.objects.create(name="Test VLAN 3", vid=3)
|
||||||
|
|
||||||
def test_get_interface(self):
|
def test_get_interface(self):
|
||||||
|
|
||||||
url = reverse('dcim-api:interface-detail', kwargs={'pk': self.interface1.pk})
|
url = reverse('dcim-api:interface-detail', kwargs={'pk': self.interface1.pk})
|
||||||
@ -2309,6 +2314,26 @@ class InterfaceTest(HttpStatusMixin, APITestCase):
|
|||||||
self.assertEqual(interface4.device_id, data['device'])
|
self.assertEqual(interface4.device_id, data['device'])
|
||||||
self.assertEqual(interface4.name, data['name'])
|
self.assertEqual(interface4.name, data['name'])
|
||||||
|
|
||||||
|
def test_create_interface_with_802_1q(self):
|
||||||
|
|
||||||
|
data = {
|
||||||
|
'device': self.device.pk,
|
||||||
|
'name': 'Test Interface 4',
|
||||||
|
'tagged_vlans': [self.vlan1.id, self.vlan2.id],
|
||||||
|
'untagged_vlan': self.vlan3.id
|
||||||
|
}
|
||||||
|
|
||||||
|
url = reverse('dcim-api:interface-list')
|
||||||
|
response = self.client.post(url, data, format='json', **self.header)
|
||||||
|
|
||||||
|
self.assertHttpStatus(response, status.HTTP_201_CREATED)
|
||||||
|
self.assertEqual(Interface.objects.count(), 4)
|
||||||
|
interface5 = Interface.objects.get(pk=response.data['id'])
|
||||||
|
self.assertEqual(interface5.device_id, data['device'])
|
||||||
|
self.assertEqual(interface5.name, data['name'])
|
||||||
|
self.assertEqual(interface5.tagged_vlans.count(), 2)
|
||||||
|
self.assertEqual(interface5.untagged_vlan.id, data['untagged_vlan'])
|
||||||
|
|
||||||
def test_create_interface_bulk(self):
|
def test_create_interface_bulk(self):
|
||||||
|
|
||||||
data = [
|
data = [
|
||||||
@ -2335,6 +2360,44 @@ class InterfaceTest(HttpStatusMixin, APITestCase):
|
|||||||
self.assertEqual(response.data[1]['name'], data[1]['name'])
|
self.assertEqual(response.data[1]['name'], data[1]['name'])
|
||||||
self.assertEqual(response.data[2]['name'], data[2]['name'])
|
self.assertEqual(response.data[2]['name'], data[2]['name'])
|
||||||
|
|
||||||
|
def test_create_interface_802_1q_bulk(self):
|
||||||
|
|
||||||
|
data = [
|
||||||
|
{
|
||||||
|
'device': self.device.pk,
|
||||||
|
'name': 'Test Interface 4',
|
||||||
|
'tagged_vlans': [self.vlan1.id],
|
||||||
|
'untagged_vlan': self.vlan2.id,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'device': self.device.pk,
|
||||||
|
'name': 'Test Interface 5',
|
||||||
|
'tagged_vlans': [self.vlan1.id],
|
||||||
|
'untagged_vlan': self.vlan2.id,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'device': self.device.pk,
|
||||||
|
'name': 'Test Interface 6',
|
||||||
|
'tagged_vlans': [self.vlan1.id],
|
||||||
|
'untagged_vlan': self.vlan2.id,
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
url = reverse('dcim-api:interface-list')
|
||||||
|
response = self.client.post(url, data, format='json', **self.header)
|
||||||
|
|
||||||
|
self.assertHttpStatus(response, status.HTTP_201_CREATED)
|
||||||
|
self.assertEqual(Interface.objects.count(), 6)
|
||||||
|
self.assertEqual(response.data[0]['name'], data[0]['name'])
|
||||||
|
self.assertEqual(response.data[1]['name'], data[1]['name'])
|
||||||
|
self.assertEqual(response.data[2]['name'], data[2]['name'])
|
||||||
|
self.assertEqual(len(response.data[0]['tagged_vlans']), 1)
|
||||||
|
self.assertEqual(len(response.data[1]['tagged_vlans']), 1)
|
||||||
|
self.assertEqual(len(response.data[2]['tagged_vlans']), 1)
|
||||||
|
self.assertEqual(response.data[0]['untagged_vlan'], self.vlan2.id)
|
||||||
|
self.assertEqual(response.data[1]['untagged_vlan'], self.vlan2.id)
|
||||||
|
self.assertEqual(response.data[2]['untagged_vlan'], self.vlan2.id)
|
||||||
|
|
||||||
def test_update_interface(self):
|
def test_update_interface(self):
|
||||||
|
|
||||||
lag_interface = Interface.objects.create(
|
lag_interface = Interface.objects.create(
|
||||||
|
Loading…
Reference in New Issue
Block a user