def test_validate_no_nodes(self, deckhand_ingester, drydock_state, input_files, mock_get_build_data): """Test that a design with no baremetal nodes validates.""" input_file = input_files.join("deckhand_fullsite_no_nodes.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) val = Validator(orch) response = val.validate_design(site_design) assert response.status == hd_fields.ValidationResult.Success
def test_invalid_rational_network_trunking(self, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("invalid_rational_network_trunking.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.network_trunking_rational(site_design) regex = re.compile( 'Rational Network Trunking Error: Trunking mode is disabled, a trunking' 'default_network must be defined; on NetworkLink .+') regex_1 = re.compile( 'Rational Network Trunking Error: If there is more than 1 allowed network,' 'trunking mode must be enabled; on NetworkLink .+') for msg in message_list: msg = msg.to_dict() assert msg.get('error') assert regex.match( msg.get('message')) is not None or regex_1.match( msg.get('message')) is not None assert len(message_list) == 2
def test_invalid_ip_locality_invalid_network(self, input_files, drydock_state, deckhand_ingester): input_file = input_files.join("invalid_validation.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.ip_locality_check(site_design) regex = re.compile( 'IP Locality Error: The gateway IP Address .+ is not within the defined CIDR: .+ of .+' ) regex_1 = re.compile('IP Locality Error: .+ is not a valid network.') regex_2 = re.compile( 'IP Locality Error: The IP Address .+ is not within the defined CIDR: .+ of .+ .' ) assert len(message_list) == 3 for msg in message_list: msg = msg.to_dict() assert msg.get('error') assert (regex.match(msg.get('message')) is not None or regex_1.match(msg.get('message')) is not None or regex_2.match(msg.get('message')) is not None)
def test_invalid_storage_sizing(self, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("invalid_validation.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.storage_sizing(site_design) regex = re.compile( 'Storage Sizing Error: Storage .+ size is < 0 on Baremetal Node .+' ) regex_1 = re.compile( 'Storage Sizing Error: Storage .+ size is greater than 99 on Baremetal Node .+' ) assert len(message_list) == 6 for msg in message_list: msg = msg.to_dict() assert regex.match( msg.get('message')) is not None or regex_1.match( msg.get('message')) is not None assert msg.get('error') is True
def test_invalid_mtu(self, mocker, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("invalid_mtu.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.mtu_rational(site_design) regex = re.compile( 'Mtu Error: Mtu must be between 1400 and 64000; on Network .+') regex_1 = re.compile( 'Mtu Error: Mtu must be <= the parent Network Link; for Network .+' ) for msg in message_list: msg = msg.to_dict() assert msg.get('error') assert regex.match( msg.get('message')) is not None or regex_1.match( msg.get('message')) is not None assert len(message_list) == 4
def test_invalid_rational_network_bond(self, mocker, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("invalid_validation.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.rational_network_bond(site_design) regex = re.compile( 'Network Link Bonding Error: Down delay is less than mon rate on BaremetalNode .+' ) regex_1 = re.compile( 'Network Link Bonding Error: Up delay is less than mon rate on BaremetalNode .+' ) for msg in message_list: msg = msg.to_dict() assert msg.get('error') is True assert regex.match( msg.get('message')) is not None or regex_1.match( msg.get('message')) is not None assert len(message_list) == 2
def test_validate_design(self, deckhand_ingester, drydock_state, input_files): """Test the basic validation engine.""" input_file = input_files.join("deckhand_fullsite.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) val = Validator() response = val.validate_design(site_design) for msg in response.message_list: assert msg.error is False assert response.error_count == 0 assert response.status == hd_fields.ValidationResult.Success
def test_invalid_ip_locality_address_not_in_network(self, input_files, drydock_state, deckhand_ingester): input_file = input_files.join("invalid_ip_locality_address_not_in_network.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.ip_locality_check(site_design) msg = message_list[0].to_dict() assert 'IP Locality Error: The IP Address' in msg.get('message') assert msg.get('error') is True
def test_no_baremetal_node(self, input_files, drydock_state, deckhand_ingester): input_file = input_files.join("ip_locality_no_baremetal_node.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.ip_locality_check(site_design) msg = message_list[0].to_dict() assert msg.get('message') == 'No baremetal_nodes found.' assert msg.get('error') is False
def test_rational_network_trunking(self, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("rational_network_trunking.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.network_trunking_rational(site_design) msg = message_list[0].to_dict() assert msg.get('message') == 'Rational Network Trunking' assert msg.get('error') is False
def test_no_duplicate_IPs_no_addressing(self, input_files, drydock_state, deckhand_ingester): input_file = input_files.join("no_duplicate_IPs_no_addressing.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.no_duplicate_IPs_check(site_design) msg = message_list[0].to_dict() assert msg.get('message') == 'No BaremetalNodes Found.' assert msg.get('error') is False
def test_mtu(self, mocker, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("mtu_rational.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.mtu_rational(site_design) msg = message_list[0].to_dict() assert msg.get('message') == 'Mtu' assert msg.get('error') is False assert len(message_list) == 1
def test_storage_partitioning(self, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("validation.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.storage_partitioning(site_design) msg = message_list[0].to_dict() assert len(message_list) == 1 assert msg.get('message') == 'Storage Partitioning' assert msg.get('error') is False
def test_invalid_no_duplicate_IPs(self, input_files, drydock_state, deckhand_ingester): input_file = input_files.join( "invalid_no_duplicate_IPs_addresses_duplicated.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.no_duplicate_IPs_check(site_design) msg = message_list[0].to_dict() assert msg.get('error') is True assert 'Error! Duplicate IP Address Found:' in msg.get('message')
def test_invalid_no_duplicate_IPs(self, input_files, drydock_state, deckhand_ingester): input_file = input_files.join("invalid_validation.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator( state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.no_duplicate_IPs_check(site_design) regex = re.compile( 'Error! Duplicate IP Address Found: .+ is in use by both .+ and .+.' ) for msg in message_list: msg = msg.to_dict() assert msg.get('error') is True assert regex.match(msg.get('message')) is not None
def test_invalid_boot_storage_small(self, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("invalid_boot_storage_small.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.boot_storage_rational(site_design) regex = re.compile( 'Boot Storage Error: .+ volume must be > .+GB on BaremetalNode .+') for msg in message_list: msg = msg.to_dict() assert regex.match(msg.get('message')) is not None assert msg.get('error') assert len(message_list) == 4
def test_invalid_unique_network(self, mocker, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("invalid_unique_network.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.unique_network_check(site_design) regex = re.compile( 'Unique Network Error: Allowed network .+ duplicated on NetworkLink .+ and NetworkLink .+' ) for msg in message_list: msg = msg.to_dict() assert msg.get('error') assert regex.match(msg.get('message')) is not None assert len(message_list) == 1
def test_invalid_storage_partitioning(self, deckhand_ingester, drydock_state, input_files): input_file = input_files.join("invalid_storage_partitioning.yaml") design_ref = "file://%s" % str(input_file) orch = Orchestrator(state_manager=drydock_state, ingester=deckhand_ingester) status, site_design = Orchestrator.get_effective_site(orch, design_ref) message_list = Validator.storage_partitioning(site_design) regex = re.compile( 'Storage Partitioning Error: A volume group must be assigned to a storage device or ' 'partition; volume group .+ on BaremetalNode .+') for msg in message_list: msg = msg.to_dict() assert msg.get('error') assert regex.match(msg.get('message')) is not None assert len(message_list) == 2