From 58d53f994223f323ccd52e7a5005caed49391c93 Mon Sep 17 00:00:00 2001 From: Fabricio Aguiar Date: Mon, 25 Mar 2024 20:44:14 +0000 Subject: [PATCH] Test samples from inline docs Signed-off-by: Fabricio Aguiar --- .pre-commit-config.yaml | 4 + docs/assemblies/creating-the-data-plane.adoc | 4 +- ...aPlaneNodeSet-CR-for-bare-metal-nodes.adoc | 58 ++++--- ...neNodeSet-CR-for-preprovisioned-nodes.adoc | 79 ++++----- docs/docs_to_sample.sh | 10 ++ tests/kuttl/tests/docs-test-00/00-prereq.yaml | 13 ++ tests/kuttl/tests/docs-test-00/01-assert.yaml | 148 +++++++++++++++++ ...aPlaneNodeSet-CR-for-bare-metal-nodes.yaml | 105 ++++++++++++ tests/kuttl/tests/docs-test-01/00-prereq.yaml | 13 ++ tests/kuttl/tests/docs-test-01/01-assert.yaml | 153 ++++++++++++++++++ ...neNodeSet-CR-for-preprovisioned-nodes.yaml | 101 ++++++++++++ 11 files changed, 607 insertions(+), 81 deletions(-) rename docs/assemblies/{ => samples}/ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.adoc (84%) rename docs/assemblies/{ => samples}/ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.adoc (77%) create mode 100755 docs/docs_to_sample.sh create mode 100644 tests/kuttl/tests/docs-test-00/00-prereq.yaml create mode 100644 tests/kuttl/tests/docs-test-00/01-assert.yaml create mode 100644 tests/kuttl/tests/docs-test-00/01-ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.yaml create mode 100644 tests/kuttl/tests/docs-test-01/00-prereq.yaml create mode 100644 tests/kuttl/tests/docs-test-01/01-assert.yaml create mode 100644 tests/kuttl/tests/docs-test-01/01-ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.yaml diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 031ebb4bc..7c8185757 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -1,6 +1,10 @@ repos: - repo: local hooks: + - id: doc-sample + name: doc-sample + language: system + entry: docs/docs_to_sample.sh - id: gotidy name: gotidy language: system diff --git a/docs/assemblies/creating-the-data-plane.adoc b/docs/assemblies/creating-the-data-plane.adoc index e1c6b6fa7..6af41a5d7 100644 --- a/docs/assemblies/creating-the-data-plane.adoc +++ b/docs/assemblies/creating-the-data-plane.adoc @@ -35,8 +35,8 @@ include::proc_creating-a-custom-service.adoc[leveloffset=+2] include::proc_configuring-a-node-set-for-a-Compute-feature-or-workload.adoc[leveloffset=+2] include::proc_building-a-custom-ansible-runner-image.adoc[leveloffset=+2] -include::ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.adoc[leveloffset=+1] -include::ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.adoc[leveloffset=+1] +include::samples/ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.adoc[leveloffset=+1] +include::samples/ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.adoc[leveloffset=+1] include::ref_data-plane-conditions-and-states.adoc[leveloffset=+1] diff --git a/docs/assemblies/ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.adoc b/docs/assemblies/samples/ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.adoc similarity index 84% rename from docs/assemblies/ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.adoc rename to docs/assemblies/samples/ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.adoc index 00b38529d..2e14e22ea 100644 --- a/docs/assemblies/ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.adoc +++ b/docs/assemblies/samples/ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.adoc @@ -10,53 +10,59 @@ kind: OpenStackDataPlaneNodeSet metadata: name: openstack-edpm-ipam spec: - env: <1> + env: #<1> - name: ANSIBLE_FORCE_COLOR value: "True" - services: <2> + services: #<2> + - bootstrap + - download-cache - configure-network - validate-network - install-os - configure-os + - ssh-known-hosts - run-os + - reboot-os + - install-certs - ovn + - neutron-metadata - libvirt - nova - telemetry - baremetalSetTemplate: <3> + baremetalSetTemplate: #<3> bmhLabelSelector: app: openstack ctlplaneInterface: enp1s0 cloudUserName: cloud-admin nodes: - edpm-compute-0: <4> + edpm-compute-0: #<4> hostName: edpm-compute-0 - networkAttachments: <5> + networkAttachments: #<5> - ctlplane - nodeTemplate: <6> - ansibleSSHPrivateKeySecret: dataplane-ansible-ssh-private-key-secret <7> - networks: <8> - - name: CtlPlane + nodeTemplate: #<6> + ansibleSSHPrivateKeySecret: dataplane-ansible-ssh-private-key-secret #<7> + networks: #<8> + - name: ctlplane subnetName: subnet1 defaultRoute: true - - name: InternalApi + fixedIP: 192.168.122.100 + - name: internalapi subnetName: subnet1 - - name: Storage + - name: storage subnetName: subnet1 - - name: Tenant + - name: tenant subnetName: subnet1 managementNetwork: ctlplane ansible: - ansibleUser: cloud-admin <9> + ansibleUser: cloud-admin #<9> ansiblePort: 22 - ansibleVars: <10> + ansibleVars: #<10> service_net_map: - nova_api_network: internal_api - nova_libvirt_network: internal_api - edpm_chrony_ntp_servers: - - pool.ntp.org - edpm_network_config_hide_sensitive_logs: false - edpm_network_config_template: | <11> + nova_api_network: internalapi + nova_libvirt_network: internalapi + timesync_ntp_servers: + - hostname: pool.ntp.org + edpm_network_config_template: | #<11> --- {% set mtu_list = [ctlplane_mtu] %} {% for network in role_networks %} @@ -93,15 +99,6 @@ spec: # considered EDPM network defaults. neutron_physical_bridge_name: br-ex neutron_public_interface_name: eth0 - role_networks: - - InternalApi - - Storage - - Tenant - networks_lower: - External: external - InternalApi: internal_api - Storage: storage - Tenant: tenant # edpm_nodes_validation edpm_nodes_validation_validate_controllers_icmp: false edpm_nodes_validation_validate_gateway_icmp: false @@ -109,7 +106,8 @@ spec: enable_debug: false # edpm firewall, change the allowed CIDR if needed edpm_sshd_configure_firewall: true - edpm_sshd_allowed_ranges: ['192.168.122.0/24'] + edpm_sshd_allowed_ranges: + - 192.168.111.0/24 # SELinux module edpm_selinux_mode: enforcing ---- diff --git a/docs/assemblies/ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.adoc b/docs/assemblies/samples/ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.adoc similarity index 77% rename from docs/assemblies/ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.adoc rename to docs/assemblies/samples/ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.adoc index e17706df2..38967d4c8 100644 --- a/docs/assemblies/ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.adoc +++ b/docs/assemblies/samples/ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.adoc @@ -10,66 +10,56 @@ kind: OpenStackDataPlaneNodeSet metadata: name: openstack-edpm-ipam spec: - env: <1> + env: #<1> - name: ANSIBLE_FORCE_COLOR value: "True" - preProvisioned: true <2> - services: <3> + preProvisioned: true #<2> + services: #<3> + - bootstrap + - download-cache - configure-network - validate-network - install-os - configure-os + - ssh-known-hosts - run-os + - reboot-os + - install-certs - ovn + - neutron-metadata - libvirt - nova - telemetry nodes: - edpm-compute-0: <4> + edpm-compute-0: #<4> hostName: edpm-compute-0 - ansible: - ansibleHost: 192.168.122.100 - networks: - - name: CtlPlane - subnetName: subnet1 - defaultRoute: true - fixedIP: 192.168.122.100 - - name: InternalApi - subnetName: subnet1 - - name: Storage - subnetName: subnet1 - - name: Tenant - subnetName: subnet1 edpm-compute-1: hostName: edpm-compute-1 - ansible: - ansibleHost: 192.168.122.101 - networks: - - name: CtlPlane - subnetName: subnet1 - defaultRoute: true - fixedIP: 192.168.122.101 - - name: InternalApi - subnetName: subnet1 - - name: Storage - subnetName: subnet1 - - name: Tenant - subnetName: subnet1 - networkAttachments: <5> + networkAttachments: #<5> - ctlplane - nodeTemplate: <6> - ansibleSSHPrivateKeySecret: dataplane-ansible-ssh-private-key-secret <7> + nodeTemplate: #<6> + ansibleSSHPrivateKeySecret: dataplane-ansible-ssh-private-key-secret #<7> + networks: + - defaultRoute: true + name: ctlplane + subnetName: subnet1 + - name: internalapi + subnetName: subnet1 + - name: storage + subnetName: subnet1 + - name: tenant + subnetName: subnet1 managementNetwork: ctlplane ansible: - ansibleUser: cloud-admin <8> + ansibleUser: cloud-admin #<8> ansiblePort: 22 - ansibleVars: <9> + ansibleVars: #<9> service_net_map: - nova_api_network: internal_api - nova_libvirt_network: internal_api - edpm_chrony_ntp_servers: - - pool.ntp.org - edpm_network_config_template: | <10> + nova_api_network: internalapi + nova_libvirt_network: internalapi + timesync_ntp_servers: + - hostname: pool.ntp.org + edpm_network_config_template: | #<10> --- {% set mtu_list = [ctlplane_mtu] %} {% for network in role_networks %} @@ -106,15 +96,6 @@ spec: # considered EDPM network defaults. neutron_physical_bridge_name: br-ex neutron_public_interface_name: eth0 - role_networks: - - InternalApi - - Storage - - Tenant - networks_lower: - External: external - InternalApi: internal_api - Storage: storage - Tenant: tenant # edpm_nodes_validation edpm_nodes_validation_validate_controllers_icmp: false edpm_nodes_validation_validate_gateway_icmp: false diff --git a/docs/docs_to_sample.sh b/docs/docs_to_sample.sh new file mode 100755 index 000000000..f01a32296 --- /dev/null +++ b/docs/docs_to_sample.sh @@ -0,0 +1,10 @@ +#!/usr/bin/env bash +set -ex + +COUNT=0 +for sample in */assemblies/samples/* ; do + FILENAME=$(basename $sample) + mkdir -p tests/kuttl/tests/docs-test-0${COUNT} + sed "0,/----/d" $sample | sed -e '/----/,$d' > tests/kuttl/tests/docs-test-0${COUNT}/01-${FILENAME/adoc/yaml} + COUNT=$((COUNT + 1)) +done diff --git a/tests/kuttl/tests/docs-test-00/00-prereq.yaml b/tests/kuttl/tests/docs-test-00/00-prereq.yaml new file mode 100644 index 000000000..4729de56b --- /dev/null +++ b/tests/kuttl/tests/docs-test-00/00-prereq.yaml @@ -0,0 +1,13 @@ +--- +apiVersion: network.openstack.org/v1beta1 +kind: DNSMasq +metadata: + name: dnsmasq +spec: + replicas: 1 + options: + - key: server + values: + - 192.168.122.1 + debug: + service: false diff --git a/tests/kuttl/tests/docs-test-00/01-assert.yaml b/tests/kuttl/tests/docs-test-00/01-assert.yaml new file mode 100644 index 000000000..ae0a891d6 --- /dev/null +++ b/tests/kuttl/tests/docs-test-00/01-assert.yaml @@ -0,0 +1,148 @@ +apiVersion: dataplane.openstack.org/v1beta1 +kind: OpenStackDataPlaneNodeSet +metadata: + name: openstack-edpm-ipam +spec: + env: + - name: ANSIBLE_FORCE_COLOR + value: "True" + baremetalSetTemplate: + bmhLabelSelector: + app: openstack + ctlplaneInterface: enp1s0 + cloudUserName: cloud-admin + nodes: + edpm-compute-0: + hostName: edpm-compute-0 + nodeTemplate: + ansible: + ansiblePort: 22 + ansibleUser: cloud-admin + ansibleVars: + timesync_ntp_servers: + - hostname: pool.ntp.org + edpm_network_config_template: | + --- + {% set mtu_list = [ctlplane_mtu] %} + {% for network in role_networks %} + {{ mtu_list.append(lookup('vars', networks_lower[network] ~ '_mtu')) }} + {%- endfor %} + {% set min_viable_mtu = mtu_list | max %} + network_config: + - type: ovs_bridge + name: {{ neutron_physical_bridge_name }} + mtu: {{ min_viable_mtu }} + use_dhcp: false + dns_servers: {{ ctlplane_dns_nameservers }} + domain: {{ dns_search_domains }} + addresses: + - ip_netmask: {{ ctlplane_ip }}/{{ ctlplane_subnet_cidr }} + routes: {{ ctlplane_host_routes }} + members: + - type: interface + name: nic1 + mtu: {{ min_viable_mtu }} + # force the MAC address of the bridge to this interface + primary: true + {% for network in role_networks %} + - type: vlan + mtu: {{ lookup('vars', networks_lower[network] ~ '_mtu') }} + vlan_id: {{ lookup('vars', networks_lower[network] ~ '_vlan_id') }} + addresses: + - ip_netmask: + {{ lookup('vars', networks_lower[network] ~ '_ip') }}/{{ lookup('vars', networks_lower[network] ~ '_cidr') }} + routes: {{ lookup('vars', networks_lower[network] ~ '_host_routes') }} + {% endfor %} + edpm_network_config_hide_sensitive_logs: false + edpm_nodes_validation_validate_controllers_icmp: false + edpm_nodes_validation_validate_gateway_icmp: false + edpm_selinux_mode: enforcing + edpm_sshd_allowed_ranges: + - 192.168.111.0/24 + edpm_sshd_configure_firewall: true + enable_debug: false + gather_facts: false + neutron_physical_bridge_name: br-ex + neutron_public_interface_name: eth0 + service_net_map: + nova_api_network: internalapi + nova_libvirt_network: internalapi + ansibleSSHPrivateKeySecret: dataplane-ansible-ssh-private-key-secret + networks: + - name: ctlplane + subnetName: subnet1 + defaultRoute: true + fixedIP: 192.168.122.100 + - name: internalapi + subnetName: subnet1 + - name: storage + subnetName: subnet1 + - name: tenant + subnetName: subnet1 + managementNetwork: ctlplane + services: + - bootstrap + - download-cache + - configure-network + - validate-network + - install-os + - configure-os + - ssh-known-hosts + - run-os + - reboot-os + - install-certs + - ovn + - neutron-metadata + - libvirt + - nova + - telemetry +status: + allHostnames: + edpm-compute-0: + ctlplane: edpm-compute-0.ctlplane.example.com + internalapi: edpm-compute-0.internalapi.example.com + storage: edpm-compute-0.storage.example.com + tenant: edpm-compute-0.tenant.example.com + allIPs: + edpm-compute-0: + ctlplane: 192.168.122.100 + internalapi: 172.17.0.100 + storage: 172.18.0.100 + tenant: 172.19.0.100 + ctlplaneSearchDomain: ctlplane.example.com + conditions: + - message: NodeSetBaremetalProvisionReady error occurred + reason: Error + severity: Error + status: "False" + type: Ready + - message: Init + reason: Init + status: Unknown + type: DeploymentReady + - message: Input data complete + reason: Ready + status: "True" + type: InputReady + - message: NodeSetBaremetalProvisionReady error occurred + reason: Error + severity: Error + status: "False" + type: NodeSetBaremetalProvisionReady + - message: NodeSetDNSDataReady ready + reason: Ready + status: "True" + type: NodeSetDNSDataReady + - message: NodeSetIPReservationReady ready + reason: Ready + status: "True" + type: NodeSetIPReservationReady + - message: ServiceAccount created + reason: Ready + status: "True" + type: ServiceAccountReady + - message: Setup started + reason: Requested + severity: Info + status: "False" + type: SetupReady diff --git a/tests/kuttl/tests/docs-test-00/01-ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.yaml b/tests/kuttl/tests/docs-test-00/01-ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.yaml new file mode 100644 index 000000000..f9ee03d53 --- /dev/null +++ b/tests/kuttl/tests/docs-test-00/01-ref_example-OpenStackDataPlaneNodeSet-CR-for-bare-metal-nodes.yaml @@ -0,0 +1,105 @@ +apiVersion: dataplane.openstack.org/v1beta1 +kind: OpenStackDataPlaneNodeSet +metadata: + name: openstack-edpm-ipam +spec: + env: #<1> + - name: ANSIBLE_FORCE_COLOR + value: "True" + services: #<2> + - bootstrap + - download-cache + - configure-network + - validate-network + - install-os + - configure-os + - ssh-known-hosts + - run-os + - reboot-os + - install-certs + - ovn + - neutron-metadata + - libvirt + - nova + - telemetry + baremetalSetTemplate: #<3> + bmhLabelSelector: + app: openstack + ctlplaneInterface: enp1s0 + cloudUserName: cloud-admin + nodes: + edpm-compute-0: #<4> + hostName: edpm-compute-0 + networkAttachments: #<5> + - ctlplane + nodeTemplate: #<6> + ansibleSSHPrivateKeySecret: dataplane-ansible-ssh-private-key-secret #<7> + networks: #<8> + - name: ctlplane + subnetName: subnet1 + defaultRoute: true + fixedIP: 192.168.122.100 + - name: internalapi + subnetName: subnet1 + - name: storage + subnetName: subnet1 + - name: tenant + subnetName: subnet1 + managementNetwork: ctlplane + ansible: + ansibleUser: cloud-admin #<9> + ansiblePort: 22 + ansibleVars: #<10> + service_net_map: + nova_api_network: internalapi + nova_libvirt_network: internalapi + timesync_ntp_servers: + - hostname: pool.ntp.org + edpm_network_config_template: | #<11> + --- + {% set mtu_list = [ctlplane_mtu] %} + {% for network in role_networks %} + {{ mtu_list.append(lookup('vars', networks_lower[network] ~ '_mtu')) }} + {%- endfor %} + {% set min_viable_mtu = mtu_list | max %} + network_config: + - type: ovs_bridge + name: {{ neutron_physical_bridge_name }} + mtu: {{ min_viable_mtu }} + use_dhcp: false + dns_servers: {{ ctlplane_dns_nameservers }} + domain: {{ dns_search_domains }} + addresses: + - ip_netmask: {{ ctlplane_ip }}/{{ ctlplane_subnet_cidr }} + routes: {{ ctlplane_host_routes }} + members: + - type: interface + name: nic1 + mtu: {{ min_viable_mtu }} + # force the MAC address of the bridge to this interface + primary: true + {% for network in role_networks %} + - type: vlan + mtu: {{ lookup('vars', networks_lower[network] ~ '_mtu') }} + vlan_id: {{ lookup('vars', networks_lower[network] ~ '_vlan_id') }} + addresses: + - ip_netmask: + {{ lookup('vars', networks_lower[network] ~ '_ip') }}/{{ lookup('vars', networks_lower[network] ~ '_cidr') }} + routes: {{ lookup('vars', networks_lower[network] ~ '_host_routes') }} + {% endfor %} + edpm_network_config_hide_sensitive_logs: false + # These vars are for the network config templates themselves and are + # considered EDPM network defaults. + neutron_physical_bridge_name: br-ex + neutron_public_interface_name: eth0 + # edpm_nodes_validation + edpm_nodes_validation_validate_controllers_icmp: false + edpm_nodes_validation_validate_gateway_icmp: false + gather_facts: false + enable_debug: false + # edpm firewall, change the allowed CIDR if needed + edpm_sshd_configure_firewall: true + edpm_sshd_allowed_ranges: + - 192.168.111.0/24 + # SELinux module + edpm_selinux_mode: enforcing diff --git a/tests/kuttl/tests/docs-test-01/00-prereq.yaml b/tests/kuttl/tests/docs-test-01/00-prereq.yaml new file mode 100644 index 000000000..4729de56b --- /dev/null +++ b/tests/kuttl/tests/docs-test-01/00-prereq.yaml @@ -0,0 +1,13 @@ +--- +apiVersion: network.openstack.org/v1beta1 +kind: DNSMasq +metadata: + name: dnsmasq +spec: + replicas: 1 + options: + - key: server + values: + - 192.168.122.1 + debug: + service: false diff --git a/tests/kuttl/tests/docs-test-01/01-assert.yaml b/tests/kuttl/tests/docs-test-01/01-assert.yaml new file mode 100644 index 000000000..01e779b05 --- /dev/null +++ b/tests/kuttl/tests/docs-test-01/01-assert.yaml @@ -0,0 +1,153 @@ +apiVersion: dataplane.openstack.org/v1beta1 +kind: OpenStackDataPlaneNodeSet +metadata: + name: openstack-edpm-ipam +spec: + env: + - name: ANSIBLE_FORCE_COLOR + value: "True" + networkAttachments: + - ctlplane + nodeTemplate: + ansible: + ansiblePort: 22 + ansibleUser: cloud-admin + ansibleVars: + timesync_ntp_servers: + - hostname: pool.ntp.org + edpm_network_config_hide_sensitive_logs: false + edpm_network_config_template: | + --- + {% set mtu_list = [ctlplane_mtu] %} + {% for network in role_networks %} + {{ mtu_list.append(lookup('vars', networks_lower[network] ~ '_mtu')) }} + {%- endfor %} + {% set min_viable_mtu = mtu_list | max %} + network_config: + - type: ovs_bridge + name: {{ neutron_physical_bridge_name }} + mtu: {{ min_viable_mtu }} + use_dhcp: false + dns_servers: {{ ctlplane_dns_nameservers }} + domain: {{ dns_search_domains }} + addresses: + - ip_netmask: {{ ctlplane_ip }}/{{ ctlplane_subnet_cidr }} + routes: {{ ctlplane_host_routes }} + members: + - type: interface + name: nic1 + mtu: {{ min_viable_mtu }} + # force the MAC address of the bridge to this interface + primary: true + {% for network in role_networks %} + - type: vlan + mtu: {{ lookup('vars', networks_lower[network] ~ '_mtu') }} + vlan_id: {{ lookup('vars', networks_lower[network] ~ '_vlan_id') }} + addresses: + - ip_netmask: + {{ lookup('vars', networks_lower[network] ~ '_ip') }}/{{ lookup('vars', networks_lower[network] ~ '_cidr') }} + routes: {{ lookup('vars', networks_lower[network] ~ '_host_routes') }} + {% endfor %} + edpm_nodes_validation_validate_controllers_icmp: false + edpm_nodes_validation_validate_gateway_icmp: false + edpm_selinux_mode: enforcing + edpm_sshd_allowed_ranges: + - 192.168.122.0/24 + edpm_sshd_configure_firewall: true + enable_debug: false + gather_facts: false + neutron_physical_bridge_name: br-ex + neutron_public_interface_name: eth0 + service_net_map: + nova_api_network: internalapi + nova_libvirt_network: internalapi + ansibleSSHPrivateKeySecret: dataplane-ansible-ssh-private-key-secret + networks: + - defaultRoute: true + name: ctlplane + subnetName: subnet1 + - name: internalapi + subnetName: subnet1 + - name: storage + subnetName: subnet1 + - name: tenant + subnetName: subnet1 + managementNetwork: ctlplane + nodes: + edpm-compute-0: + hostName: edpm-compute-0 + edpm-compute-1: + hostName: edpm-compute-1 + preProvisioned: true + services: + - bootstrap + - download-cache + - configure-network + - validate-network + - install-os + - configure-os + - ssh-known-hosts + - run-os + - reboot-os + - install-certs + - ovn + - neutron-metadata + - libvirt + - nova + - telemetry + tlsEnabled: false +status: + allHostnames: + edpm-compute-0: + ctlplane: edpm-compute-0.ctlplane.example.com + internalapi: edpm-compute-0.internalapi.example.com + storage: edpm-compute-0.storage.example.com + tenant: edpm-compute-0.tenant.example.com + edpm-compute-1: + ctlplane: edpm-compute-1.ctlplane.example.com + internalapi: edpm-compute-1.internalapi.example.com + storage: edpm-compute-1.storage.example.com + tenant: edpm-compute-1.tenant.example.com + allIPs: + edpm-compute-0: + ctlplane: 192.168.122.100 + internalapi: 172.17.0.100 + storage: 172.18.0.100 + tenant: 172.19.0.100 + edpm-compute-1: + ctlplane: 192.168.122.101 + internalapi: 172.17.0.101 + storage: 172.18.0.101 + tenant: 172.19.0.101 + conditions: + - message: Deployment not started + reason: Requested + severity: Info + status: "False" + type: Ready + - message: Deployment not started + reason: Requested + severity: Info + status: "False" + type: DeploymentReady + - message: Input data complete + reason: Ready + status: "True" + type: InputReady + - message: NodeSetDNSDataReady ready + reason: Ready + status: "True" + type: NodeSetDNSDataReady + - message: NodeSetIPReservationReady ready + reason: Ready + status: "True" + type: NodeSetIPReservationReady + - message: ServiceAccount created + reason: Ready + status: "True" + type: ServiceAccountReady + - message: Setup complete + reason: Ready + status: "True" + type: SetupReady + ctlplaneSearchDomain: ctlplane.example.com diff --git a/tests/kuttl/tests/docs-test-01/01-ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.yaml b/tests/kuttl/tests/docs-test-01/01-ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.yaml new file mode 100644 index 000000000..c19bf0e43 --- /dev/null +++ b/tests/kuttl/tests/docs-test-01/01-ref_example-OpenStackDataPlaneNodeSet-CR-for-preprovisioned-nodes.yaml @@ -0,0 +1,101 @@ +apiVersion: dataplane.openstack.org/v1beta1 +kind: OpenStackDataPlaneNodeSet +metadata: + name: openstack-edpm-ipam +spec: + env: #<1> + - name: ANSIBLE_FORCE_COLOR + value: "True" + preProvisioned: true #<2> + services: #<3> + - bootstrap + - download-cache + - configure-network + - validate-network + - install-os + - configure-os + - ssh-known-hosts + - run-os + - reboot-os + - install-certs + - ovn + - neutron-metadata + - libvirt + - nova + - telemetry + nodes: + edpm-compute-0: #<4> + hostName: edpm-compute-0 + edpm-compute-1: + hostName: edpm-compute-1 + networkAttachments: #<5> + - ctlplane + nodeTemplate: #<6> + ansibleSSHPrivateKeySecret: dataplane-ansible-ssh-private-key-secret #<7> + networks: + - defaultRoute: true + name: ctlplane + subnetName: subnet1 + - name: internalapi + subnetName: subnet1 + - name: storage + subnetName: subnet1 + - name: tenant + subnetName: subnet1 + managementNetwork: ctlplane + ansible: + ansibleUser: cloud-admin #<8> + ansiblePort: 22 + ansibleVars: #<9> + service_net_map: + nova_api_network: internalapi + nova_libvirt_network: internalapi + timesync_ntp_servers: + - hostname: pool.ntp.org + edpm_network_config_template: | #<10> + --- + {% set mtu_list = [ctlplane_mtu] %} + {% for network in role_networks %} + {{ mtu_list.append(lookup('vars', networks_lower[network] ~ '_mtu')) }} + {%- endfor %} + {% set min_viable_mtu = mtu_list | max %} + network_config: + - type: ovs_bridge + name: {{ neutron_physical_bridge_name }} + mtu: {{ min_viable_mtu }} + use_dhcp: false + dns_servers: {{ ctlplane_dns_nameservers }} + domain: {{ dns_search_domains }} + addresses: + - ip_netmask: {{ ctlplane_ip }}/{{ ctlplane_subnet_cidr }} + routes: {{ ctlplane_host_routes }} + members: + - type: interface + name: nic1 + mtu: {{ min_viable_mtu }} + # force the MAC address of the bridge to this interface + primary: true + {% for network in role_networks %} + - type: vlan + mtu: {{ lookup('vars', networks_lower[network] ~ '_mtu') }} + vlan_id: {{ lookup('vars', networks_lower[network] ~ '_vlan_id') }} + addresses: + - ip_netmask: + {{ lookup('vars', networks_lower[network] ~ '_ip') }}/{{ lookup('vars', networks_lower[network] ~ '_cidr') }} + routes: {{ lookup('vars', networks_lower[network] ~ '_host_routes') }} + {% endfor %} + edpm_network_config_hide_sensitive_logs: false + # These vars are for the network config templates themselves and are + # considered EDPM network defaults. + neutron_physical_bridge_name: br-ex + neutron_public_interface_name: eth0 + # edpm_nodes_validation + edpm_nodes_validation_validate_controllers_icmp: false + edpm_nodes_validation_validate_gateway_icmp: false + gather_facts: false + enable_debug: false + # edpm firewall, change the allowed CIDR if needed + edpm_sshd_configure_firewall: true + edpm_sshd_allowed_ranges: ['192.168.122.0/24'] + # SELinux module + edpm_selinux_mode: enforcing