Skip to content

Commit

Permalink
wip - test netbox server creation:
Browse files Browse the repository at this point in the history
  • Loading branch information
Solvik committed Mar 22, 2020
1 parent dc4f90d commit 0f8a09d
Show file tree
Hide file tree
Showing 9 changed files with 140 additions and 19 deletions.
2 changes: 2 additions & 0 deletions dev-requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,5 @@ pytest-cov
flake8
flake8-isort
tox
mock
pyfakefs
12 changes: 9 additions & 3 deletions netbox_agent/ipmi.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,14 +35,20 @@ class IPMI():
"""

def __init__(self):
self.ret, self.output = subprocess.getstatusoutput('ipmitool lan print')
try:
self.ret, self.output = subprocess.getstatusoutput('ipmitool lan print')
except Exception as e:
self.ret = 42
self.output = str(e)

if self.ret != 0:
logging.error('Cannot get ipmi info: {}'.format(self.output))

def parse(self):
ret = {}
if self.ret != 0:
return ret
return None

ret = {}
for line in self.output.splitlines():
key = line.split(':')[0].strip()
value = ':'.join(line.split(':')[1:]).strip()
Expand Down
3 changes: 3 additions & 0 deletions netbox_agent/network.py
Original file line number Diff line number Diff line change
Expand Up @@ -234,6 +234,9 @@ def reset_vlan_on_interface(self, nic, interface):

def create_or_update_ipmi(self):
ipmi = self.get_ipmi()
if ipmi is None:
return None

mac = ipmi['MAC Address']
ip = ipmi['IP Address']
netmask = ipmi['Subnet Mask']
Expand Down
2 changes: 1 addition & 1 deletion tests/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ def get_fixture_paths(path):


def parametrize_with_fixtures(path, base_path='tests/fixtures',
argname='fixture', only_filenames=None):
argname='dmi_fixture', only_filenames=None):
path = os.path.join(base_path, path)
fixture_paths = get_fixture_paths(path)
argvalues = []
Expand Down
1 change: 1 addition & 0 deletions tests/constants.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
DEFAULT_DATACENTER = 'DC1'
6 changes: 3 additions & 3 deletions tests/fixtures/dmidecode/HP_SL4540_Gen8
Original file line number Diff line number Diff line change
Expand Up @@ -829,7 +829,7 @@ System Power Supply
Location: Not Specified
Name: Power Supply 2
Manufacturer: HP
Serial Number: 4242
Serial Number: 4243
Asset Tag: Not Specified
Model Part Number: 656364-B21
Revision: Not Specified
Expand All @@ -846,7 +846,7 @@ System Power Supply
Location: Not Specified
Name: Power Supply 3
Manufacturer: HP
Serial Number: 4242
Serial Number: 4244
Asset Tag: Not Specified
Model Part Number: 656364-B21
Revision: Not Specified
Expand All @@ -863,7 +863,7 @@ System Power Supply
Location: Not Specified
Name: Power Supply 4
Manufacturer: HP
Serial Number: 4242
Serial Number: 4245
Asset Tag: Not Specified
Model Part Number: 656364-B21
Revision: Not Specified
Expand Down
8 changes: 4 additions & 4 deletions tests/network.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,15 @@
'lldp/', only_filenames=[
'dedibox1.txt',
])
def test_lldp_parse_with_port_desc(fixture):
lldp = LLDP(fixture)
def test_lldp_parse_with_port_desc(dmi_fixture):
lldp = LLDP(dmi_fixture)
assert lldp.get_switch_port('enp1s0f0') == 'RJ-9'


@parametrize_with_fixtures(
'lldp/', only_filenames=[
'qfx.txt',
])
def test_lldp_parse_without_ifname(fixture):
lldp = LLDP(fixture)
def test_lldp_parse_without_ifname(dmi_fixture):
lldp = LLDP(dmi_fixture)
assert lldp.get_switch_port('eth0') == 'xe-0/0/1'
74 changes: 66 additions & 8 deletions tests/server.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,20 @@

import mock
import netifaces

from netbox_agent.config import config
from netbox_agent.config import netbox_instance as nb
from netbox_agent.dmidecode import parse
from netbox_agent.server import ServerBase
from netbox_agent.vendors.hp import HPHost
from tests.conftest import parametrize_with_fixtures
from tests.constants import DEFAULT_DATACENTER
from tests.utils import setup_netbox


@parametrize_with_fixtures('dmidecode/')
def test_init(fixture):
dmi = parse(fixture)
def test_init(dmi_fixture):
dmi = parse(dmi_fixture)
server = ServerBase(dmi)
assert server

Expand All @@ -17,8 +26,8 @@ def test_init(fixture):
'HP_DL380p_Gen8',
'HP_SL4540_Gen8'
])
def test_hp_service_tag(fixture):
dmi = parse(fixture)
def test_hp_service_tag(dmi_fixture):
dmi = parse(dmi_fixture)
server = ServerBase(dmi)
assert server.get_service_tag() == '4242'

Expand All @@ -27,8 +36,8 @@ def test_hp_service_tag(fixture):
'dmidecode/', only_filenames=[
'unknown.txt'
])
def test_generic_host_service_tag(fixture):
dmi = parse(fixture)
def test_generic_host_service_tag(dmi_fixture):
dmi = parse(dmi_fixture)
server = ServerBase(dmi)
assert server.get_service_tag() == '42'

Expand All @@ -37,7 +46,56 @@ def test_generic_host_service_tag(fixture):
'dmidecode/', only_filenames=[
'unknown.txt'
])
def test_generic_host_product_name(fixture):
dmi = parse(fixture)
def test_generic_host_product_name(dmi_fixture):
dmi = parse(dmi_fixture)
server = ServerBase(dmi)
assert server.get_product_name() == 'SR'


@mock.patch('netifaces.ifaddresses')
@mock.patch('netifaces.interfaces')
@parametrize_with_fixtures(
'dmidecode/', only_filenames=[
'HP_SL4540_Gen8',
], argname='dmi_fixture')
def test_create_server(
mock_interfaces,
mock_ifaddresses,
fs,
dmi_fixture,
):
fake_addresses = {}
fake_addresses[netifaces.AF_INET] = [{'addr': '42.42.42.42', 'netmask': '255.255.255.0'}]
fake_addresses[netifaces.AF_LINK] = [{'addr': 'a8:1e:84:f2:9e:69'}]

mock_interfaces.return_value = ['enp1s0f0']
mock_ifaddresses.return_value = fake_addresses

dmi = parse(dmi_fixture)
server = HPHost(dmi)

setup_netbox(
DEFAULT_DATACENTER,
'Server',
'HP',
server.get_product_name(),
)

# Create fake /sys/class/net directory with fake interface and MAC addr
fs.create_file('/tmp/enp1s0f0/address', contents='a8:1e:84:f2:9e:69')
fs.create_symlink('/sys/class/net/enp1s0f0', '/tmp/enp1s0f0')

server.netbox_create(config)

# Check serial tag is correct
assert server.get_service_tag() == '4242'
network_card = server.network.get_netbox_network_card({'name': 'enp1s0f0', 'mac': None})

# Check network card is correct
assert network_card.name == 'enp1s0f0'

# Check IP on network card
ips = nb.ipam.ip_addresses.filter(
interface_id=network_card.id
)
assert ips[0].address == '42.42.42.42/24'
51 changes: 51 additions & 0 deletions tests/utils.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@

import pynetbox

from netbox_agent.config import netbox_instance as nb


def setup_netbox(dc, device_role, manufacturer, model):
try:
nb_dc = nb.dcim.sites.create(
name=dc,
slug=dc.lower(),
)
except pynetbox.RequestError:
nb_dc = nb.dcim.sites.get(
slug=dc.lower()
)

try:
nb_manufacturer = nb.dcim.manufacturers.create(
name=manufacturer,
slug=manufacturer.lower(),
)
except pynetbox.RequestError:
nb_manufacturer = nb.dcim.manufacturers.get(
slug=manufacturer.lower()
)

try:
nb_device_role = nb.dcim.device_roles.create(
name=device_role,
slug=device_role.lower(),
color='f44336',
)
except pynetbox.RequestError:
nb_device_role = nb.dcim.device_roles.get(
slug=device_role.lower(),
)

try:
nb_device_type = nb.dcim.device_types.create(
model=model,
slug=model.lower().replace(' ', '_'),
device_role=nb_device_role.id,
manufacturer=nb_manufacturer.id,
)
except pynetbox.RequestError:
nb_device_type = nb.dcim.device_types.get(
slug=model.lower().replace(' ', '_'),
)

return nb_dc, nb_manufacturer, nb_device_role, nb_device_type

0 comments on commit 0f8a09d

Please sign in to comment.