[CI] Support for running with shards

Adds support for creating nodes with shards.
Adds multinode job to test >1 n-cpus against shards.

Change-Id: I269568d83f17879fed5ac1dd5916935aea1f7fbf
This commit is contained in:
Jay Faulkner 2023-09-10 16:31:58 -07:00
parent 50ced3a3fa
commit 5606c431f2
3 changed files with 39 additions and 0 deletions

View File

@ -111,6 +111,14 @@ IRONIC_HW_NODE_DISK=${IRONIC_HW_NODE_DISK:-10}
IRONIC_HW_EPHEMERAL_DISK=${IRONIC_HW_EPHEMERAL_DISK:-0}
IRONIC_HW_ARCH=${IRONIC_HW_ARCH:-x86_64}
# Deploy Ironic Nodes & configure n-cpu for sharding
# Currently only supports 0 (old behavior) or 1 (adds all nodes
# to the same shard). You can still use this with multinode to
# get multiple shards in one Ironic install.
# IRONIC_SHARD_1_NAME + IRONIC_SHARDS will also configure n-cpu
IRONIC_SHARDS=${IRONIC_SHARDS:-0}
IRONIC_SHARD_1_NAME=${IRONIC_SHARD_1_NAME:-ds_shard_1}
# The file is composed of multiple lines, each line includes fields
# separated by white space, in the format:
#
@ -699,6 +707,10 @@ if [[ "$IRONIC_BOOT_MODE" == "uefi" ]]; then
fi
fi
if [[ "$IRONIC_SHARDS" != "0" ]] && [[ "$IRONIC_SHARDS" != "1" ]]; then
die $LINENO "Only support 0 or 1 shards at this time."
fi
# TODO(pas-ha) find a way to (cross-)sign the custom CA bundle used by tls-proxy
# with default iPXE cert - for reference see http://ipxe.org/crypto
if is_service_enabled tls-proxy && [[ "$IRONIC_IPXE_USE_SWIFT" == "True" ]]; then
@ -2643,6 +2655,10 @@ function enroll_nodes {
root_device='{"vendor": "0x1af4"}'
fi
if [[ $IRONIC_SHARDS == "1" ]]; then
openstack --os-cloud devstack-system-admin baremetal node set $node_id --shard $IRONIC_SHARD_1_NAME
fi
# In case we using portgroups, we should API version that support them.
# Othervise API will return 406 ERROR
# NOTE(vsaienko) interface_info is in the following format here:

View File

@ -274,6 +274,8 @@
IRONIC_BOOT_MODE: bios
# Make sure this feature works even with the minumum implementation
IRONIC_REDFISH_EMULATOR_FEATURE_SET: minimum
# Test sharding support
IRONIC_SHARDS: 1
devstack_services:
# Parent job uses swift, this one does not, thus we can turn it off.
s-account: False
@ -732,6 +734,25 @@
q-ovn-metadata-agent: False
n-cpu: True
- job:
# NOTE(JayF) This job sets up two nova-computes with two different shards
# TODO(JayF) Add a post-run validation to ensure the two n-cpus did not
# see each others' nodes
name: ironic-tempest-ipa-wholedisk-direct-tinyipa-multinode-shard
description: ironic-tempest-ipa-wholedisk-direct-tinyipa-multinode-shard
parent: ironic-tempest-ipa-wholedisk-direct-tinyipa-multinode
nodeset: openstack-two-node-jammy
vars:
tempest_test_regex: "BaremetalBasicOps"
devstack_localrc:
IRONIC_SHARDS: 1
IRONIC_SHARD_1_NAME: "main-node"
group-vars:
subnode:
devstack_localrc:
IRONIC_SHARDS: 1
IRONIC_SHARD_1_NAME: "subnode"
- job:
name: ironic-tox-unit-with-driver-libs
parent: openstack-tox

View File

@ -37,6 +37,8 @@
# understand it in mind for the upcoming release.
- ironic-tempest-ipa-wholedisk-direct-tinyipa-multinode:
voting: false
- ironic-tempest-ipa-wholedisk-direct-tinyipa-multinode-shard:
voting: false
- ironic-tempest-bios-ipmi-direct-tinyipa
- ironic-tempest-bfv
- ironic-tempest-ipa-partition-uefi-pxe-grub2