From 3df0f9496dfb13d8946307b77d7dbeba6acd76b6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Harald=20Jens=C3=A5s?= Date: Thu, 15 Feb 2024 23:04:40 +0100 Subject: [PATCH] Pass instanceSpec.CtlPlaneIP in CIDR notation Get the ipPrefix from the Cidr in the ipSet reservation, combine address and prefix when setting CtlPlaneIP in the instanceSpec. Depends-On: https://github.com/openstack-k8s-operators/openstack-baremetal-operator/pull/129 --- pkg/deployment/baremetal.go | 16 ++++++++++------ .../openstackdataplanenodeset_webhook_test.go | 4 ++-- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/pkg/deployment/baremetal.go b/pkg/deployment/baremetal.go index c000468c4..c30b97adc 100644 --- a/pkg/deployment/baremetal.go +++ b/pkg/deployment/baremetal.go @@ -57,19 +57,23 @@ func DeployBaremetalSet( ipSet, ok := ipSets[hostName] instanceSpec := baremetalSet.Spec.BaremetalHosts[hostName] if !ok { + // TODO: Change this to raise an error instead. + // NOTE(hjensas): Hardcode /24 here, this used to rely on + // baremetalSet.Spec.CtlplaneNetmask's default value ("255.255.255.0"). utils.LogForObject(helper, "IPAM Not configured for use, skipping", instance) - instanceSpec.CtlPlaneIP = node.Ansible.AnsibleHost + instanceSpec.CtlPlaneIP = fmt.Sprintf("%s/24", node.Ansible.AnsibleHost) } else { for _, res := range ipSet.Status.Reservation { if strings.ToLower(string(res.Network)) == CtlPlaneNetwork { - instanceSpec.CtlPlaneIP = res.Address + _, ipNet, err := net.ParseCIDR(res.Cidr) + if err != nil { + return err + } + ipPrefix, _ := ipNet.Mask.Size() + instanceSpec.CtlPlaneIP = fmt.Sprintf("%s/%d", res.Address, ipPrefix) baremetalSet.Spec.CtlplaneGateway = *res.Gateway baremetalSet.Spec.BootstrapDNS = dnsAddresses baremetalSet.Spec.DNSSearchDomains = []string{res.DNSDomain} - _, ipNet, err := net.ParseCIDR(res.Cidr) - if err == nil { - baremetalSet.Spec.CtlplaneNetmask = net.IP(ipNet.Mask).String() - } } } } diff --git a/tests/functional/openstackdataplanenodeset_webhook_test.go b/tests/functional/openstackdataplanenodeset_webhook_test.go index a669a4f64..fba72ada4 100644 --- a/tests/functional/openstackdataplanenodeset_webhook_test.go +++ b/tests/functional/openstackdataplanenodeset_webhook_test.go @@ -70,7 +70,7 @@ var _ = Describe("DataplaneNodeSet Webhook", func() { }, BaremetalHosts: map[string]baremetalv1.InstanceSpec{ "compute-0": { - CtlPlaneIP: "192.168.1.12", + CtlPlaneIP: "192.168.1.12/24", }, }, } @@ -87,7 +87,7 @@ var _ = Describe("DataplaneNodeSet Webhook", func() { }, BaremetalHosts: map[string]baremetalv1.InstanceSpec{ "compute-0": { - CtlPlaneIP: "192.168.1.12", + CtlPlaneIP: "192.168.1.12/24", }, }, }