|
|
@@ -2,6 +2,7 @@ from django.test import TestCase
|
|
|
|
|
|
from dcim.forms import *
|
|
|
from dcim.models import *
|
|
|
+from virtualization.models import Cluster, ClusterGroup, ClusterType
|
|
|
|
|
|
|
|
|
def get_id(model, slug):
|
|
|
@@ -10,83 +11,108 @@ def get_id(model, slug):
|
|
|
|
|
|
class DeviceTestCase(TestCase):
|
|
|
|
|
|
- fixtures = ['dcim', 'ipam', 'virtualization']
|
|
|
+ @classmethod
|
|
|
+ def setUpTestData(cls):
|
|
|
+
|
|
|
+ site = Site.objects.create(name='Site 1', slug='site-1')
|
|
|
+ rack = Rack.objects.create(name='Rack 1', site=site)
|
|
|
+ manufacturer = Manufacturer.objects.create(name='Manufacturer 1', slug='manufacturer-1')
|
|
|
+ device_type = DeviceType.objects.create(
|
|
|
+ manufacturer=manufacturer, model='Device Type 1', slug='device-type-1', u_height=1
|
|
|
+ )
|
|
|
+ device_role = DeviceRole.objects.create(
|
|
|
+ name='Device Role 1', slug='device-role-1', color='ff0000'
|
|
|
+ )
|
|
|
+ Platform.objects.create(name='Platform 1', slug='platform-1')
|
|
|
+ Device.objects.create(
|
|
|
+ name='Device 1', device_type=device_type, device_role=device_role, site=site, rack=rack, position=1
|
|
|
+ )
|
|
|
+ cluster_type = ClusterType.objects.create(name='Cluster Type 1', slug='cluster-type-1')
|
|
|
+ cluster_group = ClusterGroup.objects.create(name='Cluster Group 1', slug='cluster-group-1')
|
|
|
+ Cluster.objects.create(name='Cluster 1', type=cluster_type, group=cluster_group)
|
|
|
|
|
|
def test_racked_device(self):
|
|
|
- test = DeviceForm(data={
|
|
|
- 'name': 'test',
|
|
|
- 'device_role': get_id(DeviceRole, 'leaf-switch'),
|
|
|
+ form = DeviceForm(data={
|
|
|
+ 'name': 'New Device',
|
|
|
+ 'device_role': DeviceRole.objects.first().pk,
|
|
|
'tenant': None,
|
|
|
- 'manufacturer': get_id(Manufacturer, 'juniper'),
|
|
|
- 'device_type': get_id(DeviceType, 'qfx5100-48s'),
|
|
|
- 'site': get_id(Site, 'test1'),
|
|
|
- 'rack': '1',
|
|
|
+ 'manufacturer': Manufacturer.objects.first().pk,
|
|
|
+ 'device_type': DeviceType.objects.first().pk,
|
|
|
+ 'site': Site.objects.first().pk,
|
|
|
+ 'rack': Rack.objects.first().pk,
|
|
|
'face': DeviceFaceChoices.FACE_FRONT,
|
|
|
- 'position': 41,
|
|
|
- 'platform': get_id(Platform, 'juniper-junos'),
|
|
|
+ 'position': 2,
|
|
|
+ 'platform': Platform.objects.first().pk,
|
|
|
'status': DeviceStatusChoices.STATUS_ACTIVE,
|
|
|
})
|
|
|
- self.assertTrue(test.is_valid(), test.fields['position'].choices)
|
|
|
- self.assertTrue(test.save())
|
|
|
+ self.assertTrue(form.is_valid())
|
|
|
+ self.assertTrue(form.save())
|
|
|
|
|
|
def test_racked_device_occupied(self):
|
|
|
- test = DeviceForm(data={
|
|
|
+ form = DeviceForm(data={
|
|
|
'name': 'test',
|
|
|
- 'device_role': get_id(DeviceRole, 'leaf-switch'),
|
|
|
+ 'device_role': DeviceRole.objects.first().pk,
|
|
|
'tenant': None,
|
|
|
- 'manufacturer': get_id(Manufacturer, 'juniper'),
|
|
|
- 'device_type': get_id(DeviceType, 'qfx5100-48s'),
|
|
|
- 'site': get_id(Site, 'test1'),
|
|
|
- 'rack': '1',
|
|
|
+ 'manufacturer': Manufacturer.objects.first().pk,
|
|
|
+ 'device_type': DeviceType.objects.first().pk,
|
|
|
+ 'site': Site.objects.first().pk,
|
|
|
+ 'rack': Rack.objects.first().pk,
|
|
|
'face': DeviceFaceChoices.FACE_FRONT,
|
|
|
'position': 1,
|
|
|
- 'platform': get_id(Platform, 'juniper-junos'),
|
|
|
+ 'platform': Platform.objects.first().pk,
|
|
|
'status': DeviceStatusChoices.STATUS_ACTIVE,
|
|
|
})
|
|
|
- self.assertFalse(test.is_valid())
|
|
|
+ self.assertFalse(form.is_valid())
|
|
|
+ self.assertIn('position', form.errors)
|
|
|
|
|
|
def test_non_racked_device(self):
|
|
|
- test = DeviceForm(data={
|
|
|
- 'name': 'test',
|
|
|
- 'device_role': get_id(DeviceRole, 'pdu'),
|
|
|
+ form = DeviceForm(data={
|
|
|
+ 'name': 'New Device',
|
|
|
+ 'device_role': DeviceRole.objects.first().pk,
|
|
|
'tenant': None,
|
|
|
- 'manufacturer': get_id(Manufacturer, 'servertech'),
|
|
|
- 'device_type': get_id(DeviceType, 'cwg-24vym415c9'),
|
|
|
- 'site': get_id(Site, 'test1'),
|
|
|
- 'rack': '1',
|
|
|
- 'face': '',
|
|
|
+ 'manufacturer': Manufacturer.objects.first().pk,
|
|
|
+ 'device_type': DeviceType.objects.first().pk,
|
|
|
+ 'site': Site.objects.first().pk,
|
|
|
+ 'rack': None,
|
|
|
+ 'face': None,
|
|
|
'position': None,
|
|
|
- 'platform': None,
|
|
|
+ 'platform': Platform.objects.first().pk,
|
|
|
'status': DeviceStatusChoices.STATUS_ACTIVE,
|
|
|
})
|
|
|
- self.assertTrue(test.is_valid())
|
|
|
- self.assertTrue(test.save())
|
|
|
+ self.assertTrue(form.is_valid())
|
|
|
+ self.assertTrue(form.save())
|
|
|
|
|
|
- def test_non_racked_device_with_face(self):
|
|
|
- test = DeviceForm(data={
|
|
|
- 'name': 'test',
|
|
|
- 'device_role': get_id(DeviceRole, 'pdu'),
|
|
|
+ def test_non_racked_device_with_face_position(self):
|
|
|
+ form = DeviceForm(data={
|
|
|
+ 'name': 'New Device',
|
|
|
+ 'device_role': DeviceRole.objects.first().pk,
|
|
|
'tenant': None,
|
|
|
- 'manufacturer': get_id(Manufacturer, 'servertech'),
|
|
|
- 'device_type': get_id(DeviceType, 'cwg-24vym415c9'),
|
|
|
- 'site': get_id(Site, 'test1'),
|
|
|
- 'rack': '1',
|
|
|
+ 'manufacturer': Manufacturer.objects.first().pk,
|
|
|
+ 'device_type': DeviceType.objects.first().pk,
|
|
|
+ 'site': Site.objects.first().pk,
|
|
|
+ 'rack': None,
|
|
|
'face': DeviceFaceChoices.FACE_REAR,
|
|
|
- 'position': None,
|
|
|
+ 'position': 10,
|
|
|
'platform': None,
|
|
|
'status': DeviceStatusChoices.STATUS_ACTIVE,
|
|
|
})
|
|
|
- self.assertTrue(test.is_valid())
|
|
|
- self.assertTrue(test.save())
|
|
|
+ self.assertFalse(form.is_valid())
|
|
|
+ self.assertIn('face', form.errors)
|
|
|
+ self.assertIn('position', form.errors)
|
|
|
|
|
|
- def test_cloned_cluster_device_initial_data(self):
|
|
|
+ def test_initial_data_population(self):
|
|
|
+ device_type = DeviceType.objects.first()
|
|
|
+ cluster = Cluster.objects.first()
|
|
|
test = DeviceForm(initial={
|
|
|
- 'device_type': get_id(DeviceType, 'poweredge-r640'),
|
|
|
- 'device_role': get_id(DeviceRole, 'server'),
|
|
|
+ 'device_type': device_type.pk,
|
|
|
+ 'device_role': DeviceRole.objects.first().pk,
|
|
|
'status': DeviceStatusChoices.STATUS_ACTIVE,
|
|
|
- 'site': get_id(Site, 'test1'),
|
|
|
- "cluster": Cluster.objects.get(id=4).id,
|
|
|
+ 'site': Site.objects.first().pk,
|
|
|
+ 'cluster': cluster.pk,
|
|
|
})
|
|
|
- self.assertEqual(test.initial['manufacturer'], get_id(Manufacturer, 'dell'))
|
|
|
- self.assertIn('cluster_group', test.initial)
|
|
|
- self.assertEqual(test.initial['cluster_group'], get_id(ClusterGroup, 'vm-host'))
|
|
|
+
|
|
|
+ # Check that the initial value for the manufacturer is set automatically when assigning the device type
|
|
|
+ self.assertEqual(test.initial['manufacturer'], device_type.manufacturer.pk)
|
|
|
+
|
|
|
+ # Check that the initial value for the cluster group is set automatically when assigning the cluster
|
|
|
+ self.assertEqual(test.initial['cluster_group'], cluster.group.pk)
|