8. Conformance¶
The objective of this chapter is to provide an automated mechanism to validate OpenStack based cloud infrastructure against the standard set of requirements defined in Architecture Requirements. Through this validation mechanism, a provider of cloud infrastructure will be able to test their cloud infrastructure’s conformance to this reference architecture. This will ease the integration of network functions into operator environments that host compatible cloud infrastructures, thereby reducing cost, complexity, and time of integration.
The overall workstream requires the close coordination of the following:
Requirements - The agreed upon capabilities and conditions that a compliant cloud infrastructure must provide or satisfy.
Tests - The verification mechanism that determines that a given cloud infrastructure complies with one or more requirements.
Conformance Specifications - The definition of the requirements, tests, and circumstances (test case integration, etc.) that must be met to be deemed conformant.
8.1. Requirements and Testing Principles¶
If there is no clear traceability and strong links between Requirements, Tests, and Conformance Specifications, then it becomes difficult to determine if a cloud infrastructure is compliant. With this in mind, below are the set of recommended principles for each of the three components to follow. Adherence to these principles will provide the following:
Enable clear progress tracking and linkage between independent projects (i.e. know what has and has not been covered, and track changes over time)
Help users better understand if they meet requirements
Provide a stable set of point-in-time requirements and tests to achieve conformance
Reduce ambiguity in testing, requirements, and conformance
Testing Principles:
There must be traceability between test cases and requirement being validated
Failures should provide additional content to inform the user where or how the requirement was violated (e.g. which file or resource violated the requirement). Put another way, do not require the user to read the test to understand what went wrong
Testing tools should support selection of tests based on category or profile.
Tests must be available to run locally by both VNF and cloud infrastructure providers
Testing tools must produce machine-readable result formats that can be used as input into any badging program
Conformance Specifications:
Conformance specifications must refer to or define the versioned requirements that must be satisfied
Conformance specifications must refer to the versioned test implementations that must be used to validate the requirements
Conformance specifications must define the expected preconditions and environment requirements for any test tooling
Conformance specifications must define which tests must be executed in the given testing tools to achieve conformance
The conformance specifications must provide the mapping between tests and requirements to demonstrate traceability and coverage.
8.2. Test Case Integration and Tooling¶
The OpenStack based cloud infrastructure suite must utilise the Anuket test case integration toolchain to deliver overall integration, the same end user actions, and a unique test result format (e.g. Anuket test result database) needed by the end users and any test case result verification program (e.g. OVP [126]).
8.2.1. Anuket Toolchains¶
Anuket, previously named OPNFV, has built a complete CI/CD toolchain for continuously deploying and testing cloud infrastructure.
As for all installer projects, Jenkins [127] triggers scenario deployments, runs the Anuket gating test cases and then publishes all test results in the centralised test database [128] and all artifacts (reports, logs, etc.) to an S3 compatible storage service [129].
The verification, validation, and conformance processes leverage existing Anuket testing knowledge (projects) and experience (history) by utilising the toolchain design already in-place. The conformance toolchain only requires for the local deployment of the components instead of leveraging the common Anuket centralised services. However, the interfaces remain unchanged for leveraging test jobs, the common test case execution, the test result database and the S3 protocol to publish the artifacts. It’s worth mentioning that dumping all results and logs required for conformance is already in place in Functest daily jobs (see functest-wallaby-zip [130].
It should be noted that Xtesting CI [131] supports both centralised and distributed deployment models as described before. It has deployed the full toolchain in one small virtual machine to verify ONAP Openlab via Functest.
8.2.2. Test Case Integration¶
To reach all goals in terms of verification, validation, compliance, and conformance, all test cases must be delivered as Docker containers [132] to simplify the CI toolchain setup including:
the common test case execution
the unified way to manage all the interactions with the CI/CD components and with third-parties (e.g. dump all test case logs and results for conformance)
For their part, the Docker containers simply enforce that the test cases are delivered with all runtime dependencies. This prevents lots of manual operations when configuring the servers running the test cases and prevents conflicts between the test cases due to any dependencies.
It’s worth mentioning that all the conformance test cases already leverage Xtesting [133] which is a simple framework to assemble sparse test cases and to accelerate the adoption of CI/CD best practices. By managing all the interactions with the CI/CD components (test scheduler, test results database, artifact repository), it allows the developer to work only on the test suites without diving into CI/CD integration. Even more, it brings the capability to run heterogeneous test cases in the same CI toolchains thanks to a few, quickly achievable constraints [134].
The Docker containers proposed by the test projects must also embed the Xtesting Python package [135] and the related test case execution description files [136] as required by Xtesting.
8.2.3. Testing Cookbooks¶
Xtesting CI [131] leverages the common test case execution proposed by Xtesting. Thanks to a simple test case list, this tool deploys plug-and-play CI/CD toolchains in a few commands [137]. In addition, it supports multiple components such as Jenkins and Gitlab CI (test schedulers) and multiple deployment models [138] such as all-in-one or centralised services.
Xtesting [133] and Xtesting CI [131] combined meet the requirements about verification, validation, compliance, and conformance:
smoothly assemble multiple heterogeneous test cases
generate the Jenkins jobs in Anuket Releng [139] to verify conformance with Anuket specifications
deploy local CI/CD toolchains everywhere to check conformance with Anuket specifications
dump all test case results and logs [140] for third-party conformance review
Here are a couple of publicly available playbooks :
8.3. Conformance Test Suite¶
8.3.1. Functest in a nutshell¶
Functest [145] was initially created to verify OPNFV Installers and Scenarios and then to publish fair, trustable, and public results regarding the status of the different open-source technologies, especially for Neutron backends (e.g., Neutron agents, OpenDaylight, OVN, etc.). It has been continuously updated to offer the best testing coverage for any kind of OpenStack and Kubernetes deployments including production environments. It also ensures that the platforms meet Network Functions Virtualisation requirements by running and testing VNFs amongst all tests available.
Functest is driven by a true verification of the platform under test as opposed to the interoperability programs such as RefStack [146] or OPNFV Verification Program [126] which select a small subset of Functional tests passing in many different open-source software combinations:
tests are skipped if an optional support is missing (e.g. Barbican [68] or networking features such as such as BGPVPN interconnection [147] or Service Function Chaining [148])
tests are parameterised (e.g. shared vs non-shared live migration)
blacklist mechanisms are available if needed
It should be noted that the RefStack lists [146] are included as they are in Functest in the next 3 dedicated testcases:
refstack_compute (OpenStack Powered Compute)
refstack_object (OpenStack Powered Object Storage)
refstack_platform (OpenStack Powered Platform)
Then Functest conforms with the upstream rules (versions, code quality, etc.) and especially their gates [149] (a.k.a. the automatic verification prior to any code review) to preserve the quality between code and deployment. In that case, Functest can be considered as a smooth and lightweight integration of tests developed upstream (and the Functest team directly contributes in these projects: Rally [150], Tempest [151], etc.). It is worth mentioning that, as opposed to the OpenStack Gates leveraging on DevStack [152], it can check the same already deployed SUT over and over even from a Raspberry PI [153]. Here the testcases can be executed in parallel vs the same deployment instead of being executed vs different pools of virtual machines.
Here are the functional tests (>2000) running in OpenStack gates integrated in Functest Smoke (see Functest daily jobs [154] for more details):
Testcases |
Gates |
---|---|
tempest_neutron |
Neutron |
tempest_cinder |
Cinder |
tempest_keystone |
Keystone |
rally_sanity |
General |
refstack_defcore |
General |
tempest_full |
General |
tempest_slow |
General |
tempest_scenario |
General |
patrole |
Patrole |
tempest_barbican |
Barbican |
networking-bgpvpn |
Networking BGP VPN |
networking-sfc |
Networking SFC |
To complete functional testing, Functest also integrates a few performance tools [155] (2-3 hours) as proposed by OpenStack:
Testcases |
Benchmarking |
---|---|
rally_full |
Control Plane (API) testing |
rally_jobs |
Control Plane (API) testing |
vmtp |
Data Plane testing |
shaker |
Data Plane testing |
And VNFs automatically deployed and tested :
Testcases |
Benchmarking |
---|---|
cloudify |
Cloudify deployment |
cloudify_ims |
Clearwater IMS deployed via Cloudify |
heat_ims |
Clearwater IMS deployed via Heat |
vyos_vrouter |
VyOS deployed via Cloudify |
juju_epc |
OAI deployed via Juju |
Functest should be considered as a whole as it meets multiple objectives about the reference implementation:
verify all APIs (services, advances, features, etc.) exposed by the reference implementation
compare the reference implementation and local deployments from a functional standpoint and from OpenStack control plane and dataplane capabilities
Additional links:
8.3.2. Test Case traceability¶
8.3.2.1. Interfaces & APIs¶
The OpenStack Gates [149] verify all changes proposed mostly by running thousands of Tempest tests completed by Rally scenarios in a few cases. Skipping tests is allowed in all OpenStack Gates and only failures rate the review -1 because of the multiple capabilities and backends selected in the different Gate jobs. The classical Functest containers [156] conform to this model which also fits the heterogeneous user deployments.
From an OpenStack based cloud infrastructure conformance state point, the capabilities are well described in Interfaces and APIs which allows tuning the test configurations and the test lists to avoid skipping any test. It results that all tests covering optional capabilities and all upstream skipped tests due to known bugs are not executed. All remaining tests must be executed and must pass successfully.
New Functest containers [158] have been proposed for Anuket Compliance which simply override the default test configurations and the default test lists. Any optional capability or services (e.g. Barbican) can be still verified by the classical Functest containers.
The next subsections detail the Tempest tests which must not be executed from a compliance state point. The remaining tests have to pass successfully. They cover all together the API testing requirements as asked by Interfaces and APIs
The following software versions are considered here to verify OpenStack Wallaby:
Software |
Version |
---|---|
Functest |
wallaby |
Cinder Tempest plugin |
1.4.0 |
Keystone Tempest plugin |
0.7.0 |
Heat Tempest plugin |
1.2.0 |
Neutron Tempest plugin |
1.4.0 |
Rally OpenStack |
2.2.1.dev11 |
Tempest |
27.0.0 |
8.3.2.1.1. Identity - Keystone API testing¶
Keystone API is covered in the OpenStack Gates via Tempest [151] and keystone-tempest-plugin [159] as integrated in Functest Smoke CNTT [160].
According to Interfaces and APIs the following test names must not be executed:
Test rejection regular expressions |
Reasons |
---|---|
.*api.identity.v3.test_oauth1_tokens |
oauth1 |
.*scenario.test_federated_authentication |
federation |
.*identity.admin.v2 |
API v2 |
.*identity.v2 |
API v2 |
.*identity.v3.test_access_rules |
access_rules |
.*identity.v3.test_application_credentials.\ ApplicationCredentialsV3Test.\ test_create_application_credential_access_rules |
access_rules |
Keystone API is also covered by Rally [150].
Here are the mainline tasks integrated in Functest Smoke CNTT [160]:
Authenticate.keystone
KeystoneBasic.add_and_remove_user_role
KeystoneBasic.create_add_and_list_user_roles
KeystoneBasic.create_and_list_tenants
KeystoneBasic.create_and_delete_role
KeystoneBasic.create_and_delete_service
KeystoneBasic.get_entities
KeystoneBasic.create_update_and_delete_tenant
KeystoneBasic.create_user
KeystoneBasic.create_tenant
KeystoneBasic.create_and_list_users
KeystoneBasic.create_tenant_with_users
8.3.2.1.2. Image - Glance API testing¶
Glance API is covered in the OpenStack Gates via [151] as integrated in Functest Smoke CNTT [160].
According to Interfaces and APIs the following test names must not be executed:
Test rejection regular expressions |
Reasons |
---|---|
.*image.v1 |
API v1 |
.*image.v2.admin.test_images.ImportCopyImagesTest |
import_image |
.*image.v2.test_images_negative.ImagesNegativeTest.\ test_create_image_reserved_property |
os_glance_reserved |
.*image.v2.test_images_negative.ImagesNegativeTest.\ test_update_image_reserved_property |
os_glance_reserved |
.*image.v2.test_images_negative.ImportImagesNegativeTest.\ test_image_web_download_import_with_bad_url |
web-downloadimport |
.*image.v2.test_images.ImportImagesTest |
import_image |
.*image.v2.test_images.MultiStoresImportImages |
import_image |
Glance API is also covered by Rally [150].
Here are the mainline tasks integrated in Functest Smoke CNTT [160]:
Authenticate.validate_glance
GlanceImages.create_and_delete_image
GlanceImages.create_and_list_image
GlanceImages.list_images
GlanceImages.create_image_and_boot_instances
8.3.2.1.3. Block Storage - Cinder API testing¶
Cinder API is covered in the OpenStack Gates via Tempest [151] and cinder-tempest-plugin [161] as integrated in Functest Smoke CNTT [160].
According to Interfaces and APIs the following test names must not be executed:
Test rejection regular expressions |
Reasons |
---|---|
.*test_incremental_backup |
Functest review 68881 [162] |
.*test_consistencygroups |
consistency_group |
.*test_backup_crossproject_admin_negative |
Functest review 71011 [163] |
.*test_backup_crossproject_user_negative |
Functest review 71011 [163] |
.*test_volume_encrypted.TestEncryptedCinderVolumes |
attach_encrypted_volume |
.*test_encrypted_volumes_extend |
extend_attached_encrypted_volume |
.*test_group_snapshots.GroupSnapshotsV319Test.\ test_reset_group_snapshot_status |
OpenStack bug 1770179 [164] |
.*test_multi_backend |
multi-backend |
.*test_volume_retype.VolumeRetypeWithMigrationTest |
multi-backend |
.*test_volume_delete_cascade.VolumesDeleteCascade.\ test_volume_from_snapshot_cascade_delete |
OpenStack bug 1677525 [165] |
.*test_volumes_backup.VolumesBackupsTest.\ test_volume_backup_create_get_detailed_list_restore_delete |
ceph |
.*test_volumes_extend.VolumesExtendAttachedTest.\ test_extend_attached_volume |
extend_attached_volume |
.*tempest.scenario.test_volume_migrate_attached |
multi-backend |
Cinder API is also covered by Rally [150].
Here are the mainline tasks integrated in Functest Smoke CNTT [160]:
Authenticate.validate_cinder
CinderVolumes.create_and_delete_snapshot
CinderVolumes.create_and_delete_volume
CinderVolumes.create_and_extend_volume
CinderVolumes.create_from_volume_and_delete_volume
CinderQos.create_and_list_qos
CinderQos.create_and_set_qos
CinderVolumeTypes.create_and_list_volume_types
CinderVolumeTypes.create_volume_type_and_encryption_type
Quotas.cinder_update_and_delete
Quotas.cinder_update
8.3.2.1.4. Object Storage - Swift API testing¶
Swift API is covered in the OpenStack Gates via Tempest [151] as integrated in Functest Smoke CNTT [160].
According to Interfaces and APIs the following test names must not be executed:
Test rejection regular expressions |
Reasons |
---|---|
.*test_container_sync.ContainerSyncTest.\ test_container_synchronization |
OpenStack bug 1317133 [166] |
.*test_container_sync_middleware.ContainerSyncMiddlewareTest.\ test_container_synchronization |
container_sync |
.*test_object_services.ObjectTest.\ test_create_object_with_transfer_encoding |
OpenStack bug 1905432 [167] |
Swift API is also covered by Rally [150].
Here are the mainline tasks integrated in Functest Smoke CNTT [160]:
SwiftObjects.create_container_and_object_then_list_objects
SwiftObjects.list_objects_in_containers
SwiftObjects.create_container_and_object_then_download_object
SwiftObjects.create_container_and_object_then_delete_all
SwiftObjects.list_and_download_objects_in_containers
8.3.2.1.5. Networking - Neutron API testing¶
Neutron API is covered in the OpenStack Gates via Tempest [151] and neutron-tempest-plugin [168] as integrated in Functest Smoke CNTT [160].
According to Interfaces and APIs the following test names must not be executed:
Test rejection regular expressions |
Reasons |
---|---|
.*admin.test_agent_availability_zone |
DHCP agent and L3 agent |
.*admin.test_dhcp_agent_scheduler |
dhcp_agent_scheduler |
.*admin.test_l3_agent_scheduler |
l3_agent_scheduler |
.*admin.test_logging |
logging |
.*admin.test_logging_negative |
logging |
.*admin.test_network_segment_range |
network-segment-range |
.*admin.test_ports.PortTestCasesAdmin.\ test_regenerate_mac_address |
port-mac-address-regenerate |
.*admin.test_ports.PortTestCasesResourceRequest |
port-resource-request |
.*admin.test_routers_dvr |
dvr |
.*admin.test_routers_flavors |
l3-flavors |
.*admin.test_routers_ha |
l3-ha |
.*test_floating_ips.FloatingIPPoolTestJSON |
floatingip-pools |
.*test_floating_ips.FloatingIPTestJSON.\ test_create_update_floatingip_port_details |
fip-port-details |
.*test_metering_extensions |
metering |
.*test_metering_negative |
metering |
.*test_networks.NetworksSearchCriteriaTest.\ test_list_validation_filters |
filter-validation |
.*test_networks.NetworksTestAdmin.\ test_create_tenant_network_vxlan |
vxlan |
.*test_networks.NetworksTestJSON.\ test_create_update_network_dns_domain |
dns-integration |
.*test_port_forwardings |
floating-ip-port-forwarding |
.*test_port_forwarding_negative |
floating-ip-port-forwarding |
.*test_ports.PortsTaggingOnCreation |
tag-ports-during-bulk-creation |
.*test_ports.PortsTestJSON.\ test_create_port_with_propagate_uplink_status |
uplink-status-propagation |
.*test_ports.PortsTestJSON.\ test_create_port_without_propagate_uplink_status |
uplink-status-propagation |
.*test_ports.PortsTestJSON.\ test_create_update_port_with_dns_domain |
dns-domain-ports |
.*test_ports.PortsTestJSON.\ test_create_update_port_with_dns_name |
dns-integration |
.*test_ports.PortsTestJSON.\ test_create_update_port_with_no_dns_name |
dns-integration |
.*test_revisions.TestRevisions.\ test_update_dns_domain_bumps_revision |
dns-integration |
.*test_revisions.TestRevisions.\ test_update_router_extra_attributes_\ bumps_revision |
l3-ha |
.*test_router_interface_fip |
router-interface-fip |
.*test_routers.DvrRoutersTest |
dvr |
.*test_routers.HaRoutersTest |
l3-ha |
.*test_routers.RoutersIpV6Test.\ test_extra_routes_atomic |
extraroute-atomic |
.*test_routers.RoutersTest.\ test_extra_routes_atomic |
extraroute-atomic |
.*test_routers_negative.DvrRoutersNegativeTest |
dvr |
.*test_routers_negative.\ DvrRoutersNegativeTestExtended |
dvr |
.*test_routers_negative.HaRoutersNegativeTest |
l3-ha |
.*test_security_groups.RbacSharedSecurityGroupTest |
rbac-security-groups |
.*test_subnetpool_prefix_ops |
subnetpool-prefix-ops |
.*test_subnetpools.RbacSubnetPoolTest |
rbac-subnetpool |
.*test_subnetpools_negative.SubnetPoolsNegativeTestJSON.\ test_tenant_create_subnetpool_associate_shared_address_scope |
rbac-subnetpool |
.*test_subnetpools.SubnetPoolsSearchCriteriaTest.\ test_list_validation_filters |
filter-validation |
.*test_subnets.SubnetsSearchCriteriaTest.\ test_list_validation_filters |
filter-validation |
.*test_timestamp.TestTimeStamp.\ test_segment_with_timestamp |
standard-attr-segment |
.*test_trunk.TrunkTestInheritJSONBase.\ test_add_subport |
OpenStack bug 1863707 [169] |
.*test_trunk.TrunkTestMtusJSON |
vxlan |
.*test_trunk_negative.TrunkTestJSON.\ test_create_subport_invalid_inherit_network_\ segmentation_type |
vxlan |
.*test_trunk_negative.TrunkTestMtusJSON |
vxlan |
.*test_qos.QosMinimumBandwidthRuleTestJSON |
Functest review 69105 [170] |
.*network.test_tags |
tag-ext |
.*test_routers.RoutersIpV6Test.\ test_create_router_set_gateway_with_fixed_ip |
OpenStack bug 1863707 [171] |
.*test_routers.RoutersTest.\ test_create_router_set_gateway_with_fixed_ip |
OpenStack bug 1863707 [171] |
.*test_network_basic_ops.\ TestNetworkBasicOps.test_router_rescheduling |
l3_agent_scheduler |
.*test_network_advanced_server_ops.\ TestNetworkAdvancedServerOps.\ test_server_connectivity_cold_migration_revert |
OpenStack bug 1836595 [172] |
Neutron API is also covered by Rally [150].
Here are the mainline tasks integrated in Functest Smoke CNTT [160]:
Authenticate.validate_neutron
NeutronNetworks.create_and_delete_networks
NeutronNetworks.create_and_delete_ports
NeutronNetworks.create_and_delete_routers
NeutronNetworks.create_and_delete_subnets
NeutronNetworks.create_and_list_networks
NeutronNetworks.create_and_list_ports
NeutronNetworks.create_and_list_routers
NeutronNetworks.create_and_list_subnets
NeutronSecurityGroup.create_and_delete_security_groups
NeutronSecurityGroup.create_and_delete_security_group_rule
NeutronNetworks.set_and_clear_router_gateway
Quotas.neutron_update
8.3.2.1.6. Compute - Nova API testing¶
Nova API is covered in the OpenStack Gates via Tempest [151] as integrated in Functest Smoke CNTT [160].
According to Interfaces and APIs the following test names must not be executed:
Test rejection regular expressions |
Reasons |
---|---|
.*admin.test_agents |
xenapi_apis |
.*test_fixed_ips |
neutron |
.*test_fixed_ips_negative |
neutron |
.*test_auto_allocate_network |
shared networks |
.*test_flavors_microversions.FlavorsV255TestJSON |
max_microversion: 2.53 |
.*test_flavors_microversions.FlavorsV261TestJSON |
max_microversion: 2.53 |
.*test_floating_ips_bulk |
nova-network |
.*test_live_migration.\ LiveAutoBlockMigrationV225Test.test_iscsi_volume |
block live migration |
.*test_live_migration.\ LiveAutoBlockMigrationV225Test.\ test_live_block_migration |
block live migration |
.*test_live_migration.\ LiveAutoBlockMigrationV225Test.\ test_live_block_migration_paused |
block live migration |
.*test_live_migration.\ LiveAutoBlockMigrationV225Test.\ test_volume_backed_live_migration |
volume-backed live migration |
.*test_live_migration.LiveMigrationTest.\ test_iscsi_volume |
block live migration |
.*test_live_migration.LiveMigrationTest.\ test_live_block_migration |
block live migration |
.*test_live_migration.LiveMigrationTest.\ test_live_block_migration_paused |
block live migration |
.*test_live_migration.LiveMigrationTest.\ test_volume_backed_live_migration |
volume-backed live migration |
.*test_live_migration.\ LiveMigrationRemoteConsolesV26Test |
serial_console |
.*test_quotas.QuotasAdminTestV257 |
max_microversion: 2.53 |
.*test_servers.ServersAdminTestJSON.\ test_reset_network_inject_network_info |
xenapi_apis |
.*certificates.test_certificates |
cert |
.*test_quotas_negative.\ QuotasSecurityGroupAdminNegativeTest |
OpenStack bug 1186354 [173] |
.*test_novnc |
vnc_console |
.*test_server_personality |
personality |
.*test_servers.ServerShowV263Test.\ test_show_update_rebuild_list_server |
certified_image_ref |
.*test_servers_microversions.ServerShowV254Test |
max_microversion: 2.53 |
.*test_servers_microversions.ServerShowV257Test |
max_microversion: 2.53 |
.*test_servers_negative.ServersNegativeTestJSON.\ test_personality_file_contents_not_encoded |
personality |
.*test_server_actions.ServerActionsTestJSON.\ test_change_server_password |
change_password |
.*test_server_actions.ServerActionsTestJSON.\ test_get_vnc_console |
vnc_console |
.*test_server_actions.ServerActionsTestJSON.\ test_reboot_server_soft |
OpenStack bug 1014647 [174] |
.*test_server_rescue.\ ServerBootFromVolumeStableRescueTest |
stable_rescue |
.*test_server_rescue.ServerStableDeviceRescueTest |
stable_rescue |
.*test_security_group_default_rules |
OpenStack bug 1311500 [175] |
.*test_security_groups_negative.\
|
neutron |
.*test_security_groups_negative.\ SecurityGroupsNegativeTestJSON.\ test_security_group_create_with_\ invalid_group_description |
OpenStack bug 1161411 [176] |
.*test_security_groups_negative.\ SecurityGroupsNegativeTestJSON.\ test_security_group_create_with_invalid_group_name |
OpenStack bug 1161411 [176] |
.*test_security_groups_negative.\ SecurityGroupsNegativeTestJSON.\ test_update_security_group_with_invalid_sg_description |
neutron |
.*test_security_groups_negative.\ SecurityGroupsNegativeTestJSON.\ test_update_security_group_with_invalid_sg_description |
neutron |
.*test_security_groups_negative.\ SecurityGroupsNegativeTestJSON.\ test_update_security_group_with_invalid_sg_id |
neutron |
.*test_security_groups_negative.\ SecurityGroupsNegativeTestJSON.\ test_update_security_group_with_invalid_sg_name |
neutron |
.*test_server_metadata.ServerMetadataTestJSON |
xenapi_apis |
.*test_server_metadata_negative.\ ServerMetadataNegativeTestJSON.\ test_delete_metadata_non_existent_server |
xenapi_apis |
.*test_server_metadata_negative.\ ServerMetadataNegativeTestJSON.\ test_metadata_items_limit |
xenapi_apis |
.*test_server_metadata_negative.\ ServerMetadataNegativeTestJSON.\ test_set_metadata_invalid_key |
xenapi_apis |
.*test_server_metadata_negative.\ ServerMetadataNegativeTestJSON.\ test_set_metadata_non_existent_server |
xenapi_apis |
.*test_server_metadata_negative.\ ServerMetadataNegativeTestJSON.\ test_set_server_metadata_blank_key |
xenapi_apis |
.*test_server_metadata_negative.\ ServerMetadataNegativeTestJSON.\ test_set_server_metadata_missing_metadata |
xenapi_apis |
.*test_server_metadata_negative.\ ServerMetadataNegativeTestJSON.\ test_update_metadata_non_existent_server |
xenapi_apis |
.*test_server_metadata_negative.\ ServerMetadataNegativeTestJSON.\ test_update_metadata_with_blank_key |
xenapi_apis |
.*test_list_server_filters.\ ListServerFiltersTestJSON.\ test_list_servers_filtered_by_ip_regex |
OpenStack bug 1540645 [177] |
.*servers.test_virtual_interfaces |
nova-network |
.*compute.test_virtual_interfaces_negative |
nova-network |
.*compute.test_networks |
nova-network |
.*test_attach_volume.AttachVolumeMultiAttach |
volume_multiattach |
.*test_volume_boot_pattern.\ TestVolumeBootPattern.\ test_boot_server_from_encrypted_volume_luks |
attach_encrypted_volume |
.*test_volume_swap |
swap_volume |
.*test_encrypted_cinder_volumes |
attach_encrypted_volume |
.*test_minbw_allocation_placement |
microversion |
.*test_volumes_negative.\ UpdateMultiattachVolumeNegativeTest.\ test_multiattach_rw_volume_update_failure |
volume_multiattach |
.*test_shelve_instance.TestShelveInstance.\ test_cold_migrate_unshelved_instance |
shelve_migrate |
Nova API is also covered by Rally [150].
Here are the mainline tasks integrated in Functest Smoke CNTT [160]:
Authenticate.validate_nova
NovaServers.boot_and_live_migrate_server
NovaServers.boot_server_attach_created_volume_and_live_migrate
NovaServers.boot_server_from_volume_and_live_migrate
NovaKeypair.boot_and_delete_server_with_keypair
NovaServers.boot_server_from_volume_and_delete
NovaServers.pause_and_unpause_server
NovaServers.boot_and_migrate_server
NovaServers.boot_server_and_list_interfaces
NovaServers.boot_server_associate_and_dissociate_floating_ip
NovaServerGroups.create_and_delete_server_group
Quotas.nova_update
8.3.2.1.7. Orchestration - Heat API testing¶
Heat API is covered in the OpenStack Gates via heat-tempest-plugin [178] as integrated in Functest Smoke CNTT [160].
According to Interfaces and APIs the following test names must not be executed:
Test rejection regular expressions |
Reasons |
---|---|
.*functional.test_lbaasv2 |
lbaasv2 |
.*functional.test_encryption_vol_type |
OpenStack story [179] |
.*RemoteStackTest.\ test_stack_create_with_cloud_credential |
Functest review 69926 [180] |
.*scenario.test_aodh_alarm |
aodh |
.*tests.scenario.test_autoscaling_lb |
lbaas |
.*scenario.test_autoscaling_lbv2 |
lbaasv2 |
.*scenario.test_server_software_config |
Functest review 69926 [180] |
.*test_volumes.\ VolumeBackupRestoreIntegrationTest |
Functest review 69926 [181] |
.*scenario.test_octavia_lbaas |
octavia |
.*scenario.test_server_cfn_init |
Functest review 70004 [182] |
Heat API is also covered by Rally [150].
Here are the mainline tasks integrated in Functest Smoke CNTT [160]:
Authenticate.validate_heat
HeatStacks.create_update_delete_stack
HeatStacks.create_check_delete_stack
HeatStacks.create_suspend_resume_delete_stack
HeatStacks.list_stacks_and_resources
8.3.2.2. Dashboard¶
Horizon is covered in the OpenStack Gates via tempest-horizon [183] as integrated in Functest Healthcheck [184].
8.3.2.3. OpenStack API benchmarking¶
Rally [150] is tool and framework that allows to perform OpenStack API benchmarking.
Here are the Rally-based test cases proposed by Functest Benchmarking CNTT [185]:
rally_full [186]: Functest scenarios iterating 10 times the mainline Rally scenarios
rally_jobs [187]: Neutron scenarios executed in the OpenStack gates
The default SLA proposed in Functest Benchmarking CNTT [185] is a maximum failure rate of 0%.
8.3.2.3.1. Identity - Keystone API benchmarking¶
Functest rally_full_cntt [186]:
Scenarios |
Iterations |
---|---|
Authenticate.keystone |
10 |
KeystoneBasic.add_and_remove_user_role |
10 |
KeystoneBasic.create_add_and_list_user_roles |
10 |
KeystoneBasic.create_and_list_tenants |
10 |
KeystoneBasic.create_and_delete_role |
10 |
KeystoneBasic.create_and_delete_service |
10 |
KeystoneBasic.get_entities |
10 |
KeystoneBasic.create_update_and_delete_tenant |
10 |
KeystoneBasic.create_user |
10 |
KeystoneBasic.create_tenant |
10 |
KeystoneBasic.create_and_list_users |
10 |
KeystoneBasic.create_tenant_with_users |
10 |
8.3.2.3.2. Image - Glance API benchmarking¶
Functest rally_full_cntt [186]:
Scenarios |
Iterations |
---|---|
Authenticate.validate_glance |
10 |
GlanceImages.create_and_delete_image |
10 |
GlanceImages.create_and_list_image |
10 |
GlanceImages.list_images |
10 |
GlanceImages.create_image_and_boot_instances |
10 |
GlanceImages.create_and_deactivate_image |
10 |
GlanceImages.create_and_download_image |
10 |
GlanceImages.create_and_get_image |
10 |
GlanceImages.create_and_update_image |
10 |
8.3.2.3.3. Block Storage - Cinder API benchmarking¶
Functest rally_full_cntt [186]:
Scenarios |
Iterations |
---|---|
Authenticate.validate_glance |
10 |
CinderVolumes.create_and_attach_volume |
10 |
CinderVolumes.create_and_list_snapshots |
10 |
CinderVolumes.create_and_list_volume |
10 |
CinderVolumes.create_and_upload_volume_to_image |
10 |
CinderVolumes.create_nested_snapshots_and_attach_volume |
10 |
CinderVolumes.create_snapshot_and_attach_volume |
10 |
CinderVolumes.create_volume |
10 |
CinderVolumes.list_volumes |
10 |
CinderVolumes.create_and_delete_snapshot |
10 |
CinderVolumes.create_and_delete_volume |
10 |
CinderVolumes.create_and_extend_volume |
10 |
CinderVolumes.create_from_volume_and_delete_volume |
10 |
CinderQos.create_and_get_qos |
10 |
CinderQos.create_and_list_qos |
10 |
CinderQos.create_and_set_qos |
10 |
CinderVolumeTypes.create_and_get_volume_type |
10 |
CinderVolumeTypes.create_and_list_volume_types |
10 |
CinderVolumeTypes.create_and_update_volume_type |
10 |
CinderVolumeTypes.create_volume_type_and_encryption_type |
10 |
CinderVolumeTypes.create_volume_type_add_and_list_type_access |
10 |
Quotas.cinder_update_and_delete |
10 |
Quotas.cinder_update |
10 |
8.3.2.3.4. Object Storage - Swift API benchmarking¶
Functest rally_full_cntt [186]:
Scenarios |
Iterations |
---|---|
SwiftObjects.create_container_and_object_then_list_objects |
10 |
SwiftObjects.list_objects_in_containers |
10 |
SwiftObjects.create_container_and_object_then_download_object |
10 |
SwiftObjects.create_container_and_object_then_delete_all |
10 |
SwiftObjects.list_and_download_objects_in_containers |
10 |
8.3.2.3.5. Networking - Neutron API benchmarking¶
Functest rally_full_cntt [186]:
Scenarios |
Iterations |
---|---|
Authenticate.validate_neutron |
10 |
NeutronNetworks.create_and_update_networks |
10 |
NeutronNetworks.create_and_update_ports |
10 |
NeutronNetworks.create_and_update_routers |
10 |
NeutronNetworks.create_and_update_subnets |
10 |
NeutronNetworks.create_and_delete_networks |
10 |
NeutronNetworks.create_and_delete_ports |
10 |
NeutronNetworks.create_and_delete_routers |
10 |
NeutronNetworks.create_and_delete_subnets |
10 |
NeutronNetworks.create_and_list_networks |
10 |
NeutronNetworks.create_and_list_ports |
10 |
NeutronNetworks.create_and_list_routers |
10 |
NeutronNetworks.create_and_list_subnets |
10 |
NeutronSecurityGroup.create_and_delete_security_groups |
10 |
NeutronSecurityGroup.create_and_delete_security_group_rule |
10 |
NeutronSecurityGroup.create_and_list_security_group_rules |
10 |
NeutronSecurityGroup.create_and_show_security_group |
10 |
NeutronNetworks.set_and_clear_router_gateway |
10 |
NeutronNetworks.create_and_show_ports |
10 |
NeutronNetworks.create_and_show_routers |
10 |
NeutronNetworks.create_and_show_subnets |
10 |
Quotas.neutron_update |
10 |
Functest rally_jobs_cntt [187]:
Scenarios |
Iterations |
---|---|
NeutronNetworks.create_and_delete_networks |
40 |
NeutronNetworks.create_and_delete_ports |
40 |
NeutronNetworks.create_and_delete_routers |
40 |
NeutronNetworks.create_and_delete_subnets |
40 |
NeutronNetworks.create_and_list_networks |
100 |
NeutronNetworks.create_and_list_ports |
8 |
NeutronNetworks.create_and_list_routers |
40 |
NeutronNetworks.create_and_list_subnets |
40 |
NeutronNetworks.create_and_update_networks |
40 |
NeutronNetworks.create_and_update_ports |
40 |
NeutronNetworks.create_and_update_routers |
40 |
NeutronNetworks.create_and_update_subnets |
100 |
NeutronTrunks.create_and_list_trunks |
4 |
Quotas.neutron_update |
40 |
8.3.2.3.6. Compute - Nova API benchmarking¶
Functest rally_full_cntt [186]:
Scenarios |
Iterations |
---|---|
Authenticate.validate_nova |
10 |
NovaKeypair.create_and_delete_keypair |
10 |
NovaKeypair.create_and_list_keypairs |
10 |
NovaServers.boot_and_bounce_server |
10 |
NovaServers.boot_and_delete_server |
10 |
NovaServers.boot_and_list_server |
10 |
NovaServers.boot_and_rebuild_server |
10 |
NovaServers.snapshot_server |
10 |
NovaServers.boot_server_from_volume |
10 |
NovaServers.boot_server |
10 |
NovaServers.list_servers |
10 |
NovaServers.resize_server |
10 |
NovaServers.boot_and_live_migrate_server |
10 |
NovaServers.boot_server_attach_created_volume_and_live_migrate |
10 |
NovaServers.boot_server_from_volume_and_live_migrate |
10 |
NovaKeypair.boot_and_delete_server_with_keypair |
10 |
NovaServers.boot_server_from_volume_and_delete |
10 |
NovaServers.pause_and_unpause_server |
10 |
NovaServers.boot_and_migrate_server |
10 |
NovaServers.boot_server_and_list_interfaces |
10 |
NovaServers.boot_and_get_console_url |
10 |
NovaServers.boot_server_and_attach_interface |
10 |
NovaServers.boot_server_attach_volume_and_list_attachments |
10 |
NovaServers.boot_server_associate_and_dissociate_floating_ip |
10 |
NovaServers.boot_and_associate_floating_ip |
10 |
NovaServerGroups.create_and_delete_server_group |
10 |
NovaServerGroups.create_and_get_server_group |
10 |
NovaServerGroups.create_and_list_server_groups |
10 |
Quotas.nova_update |
10 |
8.3.2.3.7. Orchestration - Heat API benchmarking¶
Functest rally_full_cntt [186]:
Scenarios |
Iterations |
---|---|
Authenticate.validate_heat |
10 |
HeatStacks.create_and_delete_stack |
10 |
HeatStacks.create_and_list_stack |
10 |
HeatStacks.create_update_delete_stack |
10 |
HeatStacks.create_check_delete_stack |
10 |
HeatStacks.create_suspend_resume_delete_stack |
10 |
HeatStacks.list_stacks_and_resources |
10 |
8.3.2.4. Dataplane benchmarking¶
Functest Benchmarking CNTT [185] offers two benchmarking dataplane test cases leveraging on:
VMTP [188] is a small python application that will automatically perform ping connectivity, round trip time measurement (latency) and TCP/UDP throughput measurement on any OpenStack deployment.
:cite:p:`shaker wraps around popular system network testing tools like iperf, iperf3 and netperf (with help of flent). [189] is able to deploy OpenStack instances and networks in different topologies. [189] scenario specifies the deployment and list of tests to execute.
The SLA is the default SLA proposed in Functest Benchmarking CNTT [185].
8.3.2.4.1. VMTP¶
Here are the scenarios [190] executed by Functest [191]: - VM to VM same network fixed IP (intra-node) - VM to VM different network fixed IP (intra-node) - VM to VM different network floating IP (intra-node) - VM to VM same network fixed IP (inter-node) - VM to VM different network fixed IP (inter-node) - VM to VM different network floating IP (inter-node)
Here are all results per scenario:
protocol |
pkt_size |
results |
---|---|---|
ICMP |
64 |
rtt_avg_ms |
ICMP |
64 |
rtt_max_ms |
ICMP |
64 |
rtt_min_ms |
ICMP |
64 |
rtt_stddev |
ICMP |
391 |
rtt_avg_ms |
ICMP |
391 |
rtt_max_ms |
ICMP |
391 |
rtt_min_ms |
ICMP |
391 |
rtt_stddev |
ICMP |
1500 |
rtt_avg_ms |
ICMP |
1500 |
rtt_max_ms |
ICMP |
1500 |
rtt_min_ms |
ICMP |
1500 |
rtt_stddev |
UDP |
128 |
loss_rate |
UDP |
128 |
throughput_kbps |
UDP |
1024 |
loss_rate |
UDP |
1024 |
throughput_kbps |
UDP |
8192 |
loss_rate |
UDP |
8192 |
throughput_kbps |
TCP |
65536 |
rtt_ms |
TCP |
65536 |
throughput_kbps |
8.3.2.4.2. Shaker¶
Here are the scenarios [192] executed by Shaker:
OpenStack L2
OpenStack L3 East-West
OpenStack L3 North-South
OpenStack L3 North-South Performance
Here are all samples:
test |
samples |
---|---|
Bi-directional |
ping_icmp (ms) |
Bi-directional |
tcp_download (Mbits/s) |
Bi-directional |
tcp_upload (Mbits/s) |
Download |
ping_icmp (ms) |
Download |
tcp_download (Mbits/s) |
Upload |
ping_icmp (ms) |
Upload |
tcp_upload (Mbits/s) |
Ping |
ping_icmp (ms) |
Ping |
ping_udp (ms) |
TCP |
bandwidth (bit/s) |
TCP |
retransmits |
UDP |
packets (pps) |
8.3.2.5. Open-source VNF onboarding and testing¶
Running open-source VNFs is a key technical solution to ensure that the platforms meet Network Functions Virtualisation requirements. Functest VNF [193] offers 5 test cases which automatically onboard and test the following 3 open-source VNFs:
Here are the full list of orchestrators used for all these deployments:
The VNF are covered by upstream tests when possible (see clearwater-live-test [199]) and by Functest VNF tests in the other cases.
8.4. Test Cases Traceability to Requirements¶
8.4.1. RM/RA-1 Requirements¶
The following test cases must pass as they are for OpenStack based cloud infrastructure Conformance:
container |
test case |
criteria |
---|---|---|
opnfv/functest-healthcheck:wallaby |
tempest_horizon |
PASS |
opnfv/functest-smoke-cntt:wallaby |
tempest_neutron_cntt |
PASS |
opnfv/functest-smoke-cntt:wallaby |
tempest_cinder_cntt |
PASS |
opnfv/functest-smoke-cntt:wallaby |
tempest_keystone_cntt |
PASS |
opnfv/functest-smoke-cntt:wallaby |
rally_sanity_cntt |
PASS |
opnfv/functest-smoke-cntt:wallaby |
tempest_full_cntt |
PASS |
opnfv/functest-smoke-cntt:wallaby |
tempest_scenario_cntt |
PASS |
opnfv/functest-smoke-cntt:wallaby |
tempest_slow_cntt |
PASS |
opnfv/functest-benchmarking-cntt:wallaby |
rally_full_cntt |
PASS |
opnfv/functest-benchmarking-cntt:wallaby |
rally_jobs_cntt |
PASS |
opnfv/functest-benchmarking-cntt:wallaby |
vmtp |
PASS |
opnfv/functest-benchmarking-cntt:wallaby |
shaker |
PASS |
opnfv/functest-vnf:wallaby |
cloudify |
PASS |
opnfv/functest-vnf:wallaby |
cloudify_ims |
PASS |
opnfv/functest-vnf:wallaby |
heat_ims |
PASS |
opnfv/functest-vnf:wallaby |
vyos_vrouter |
PASS |
opnfv/functest-vnf:wallaby |
juju_epc |
PASS |
8.4.2. TC Mapping to Requirements¶
test case |
requirements |
---|---|
tempest_horizon |
Horizon testing |
tempest_neutron_cntt |
Neutron API testing |
tempest_cinder_cntt |
Cinder API testing |
tempest_keystone_cntt |
Keystone API testing |
rally_sanity_cntt |
Keystone, Glance, Cinder, Swift, Neutron, Nova and Heat API testing |
tempest_full_cntt |
Keystone, Glance, Cinder, Swift, Neutron and Nova API testing |
tempest_scenario_cntt |
Keystone, Glance, Cinder, Swift, Neutron and Nova API testing |
tempest_slow_cntt |
Keystone, Glance, Cinder, Swift, Neutron and Nova API testing |
rally_full_cntt |
Keystone, Glance, Cinder, Swift, Neutron, Nova and Heat API benchmarking |
rally_jobs_cntt |
Neutron API benchmarking |
vmtp |
Dataplane benchmarking |
shaker |
Dataplane benchmarking |
cloudify |
open-source VNF onboarding and testing |
cloudify_ims |
open-source VNF onboarding and testing |
heat_ims |
open-source VNF onboarding and testing |
vyos_vrouter |
open-source VNF onboarding and testing |
juju_epc |
open-source VNF onboarding and testing |
8.5. OpenStack Testing Cookbook¶
Please note the next two points depending on the GNU/Linux distributions and the network settings:
SELinux: you may have to add –system-site-packages when creating the virtualenv (“Aborting, target uses selinux but python bindings (libselinux-python) aren’t installed!”)
Proxy: you may set your proxy in env for Ansible and in systemd for Docker [200]
To deploy your own CI toolchain running OpenStack based cloud infrastructure Conformance:
virtualenv functest --system-site-packages
. functest/bin/activate
pip install ansible
ansible-galaxy install collivier.xtesting
ansible-galaxy collection install ansible.posix community.general community.grafana kubernetes.core community.docker community.postgresql
git clone https://gerrit.opnfv.org/gerrit/functest functest-src
(cd functest-src && git checkout -b stable/wallaby origin/stable/wallaby)
ansible-playbook functest-src/ansible/site.cntt.yml
8.5.1. OpenStack API testing configuration¶
Here is the default Functest tree as proposed in Functest Wallaby [156]:
/home/opnfv/functest/openstack.creds
/home/opnfv/functest/images
Download the images and fill /home/opnfv/functest/openstack.creds as proposed in Functest Wallaby [156].
You may have to modify a few Functest env vars according to the SUT (see env in Functest Wallaby [156]). Be free to modify functest-src/ansible/host_vars/127.0.0.1 at your convenience and then to reconfigure the toolchain:
ansible-playbook functest-src/ansible/site.cntt.yml
8.5.2. Run OpenStack based cloud infrastructure Conformance¶
Open http://127.0.0.1:8080/job/functest-wallaby-daily/ in a web browser, login as admin/admin and click on “Build with Parameters” (keep the default build_tag value).
If the System under test (SUT) is compliant, a link to the full archive containing all test results and artifacts will be printed in functest-wallaby-zip’s console. Be free to download it and then to send it to any reviewer committee.
To clean your working directory:
deactivate
rm -rf functest-src functest