Skip to content

Commit

Permalink
Controller: Set CNI args on the delegate request
Browse files Browse the repository at this point in the history
The CNI args has to be set in the delegate request so the cni-args in
the network attachment annotation are considered.

Signed-off-by: Lionel Jouin <[email protected]>
  • Loading branch information
LionelJouin committed Sep 13, 2023
1 parent 8e06025 commit 0603293
Show file tree
Hide file tree
Showing 3 changed files with 77 additions and 5 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/check.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ jobs:
- name: Linters
uses: golangci/golangci-lint-action@v3
with:
version: v1.48.0
version: v1.54.2
args: --timeout 3m --verbose cmd/... pkg/...

- name: Test
Expand Down
16 changes: 13 additions & 3 deletions pkg/controller/pod.go
Original file line number Diff line number Diff line change
Expand Up @@ -243,7 +243,7 @@ func (pnc *PodNetworksController) processNextWorkItem() bool {
PodNetNS: netnsPath,
})
if err != nil {
klog.Errorf("error removing attachments: %v")
klog.Errorf("error removing attachments: %v", err)
return true
}
}
Expand Down Expand Up @@ -440,11 +440,20 @@ func podContainerID(pod *corev1.Pod) string {
}

func addIfaceEventFormat(pod *corev1.Pod, network *nadv1.NetworkSelectionElement) string {
attributes := ""
if len(network.IPRequest) > 0 || network.MacRequest != "" || network.CNIArgs != nil {
attributes = fmt.Sprintf(" (ips: %v, mac: %s, cni-args: %v)",
network.IPRequest,
network.MacRequest,
network.CNIArgs,
)
}
return fmt.Sprintf(
"pod [%s]: added interface %s to network: %s",
"pod [%s]: added interface %s to network: %s%s",
annotations.NamespacedName(pod.GetNamespace(), pod.GetName()),
network.InterfaceRequest,
network.Name,
attributes,
)
}

Expand All @@ -465,10 +474,11 @@ func rejectInterfaceAddEventFormat(pod *corev1.Pod) string {
}

func interfaceAttributes(networkData nadv1.NetworkSelectionElement) *multusapi.DelegateInterfaceAttributes {
if len(networkData.IPRequest) > 0 || networkData.MacRequest != "" {
if len(networkData.IPRequest) > 0 || networkData.MacRequest != "" || networkData.CNIArgs != nil {
return &multusapi.DelegateInterfaceAttributes{
IPRequest: networkData.IPRequest,
MacRequest: networkData.MacRequest,
CNIArgs: networkData.CNIArgs,
}
}
return nil
Expand Down
64 changes: 63 additions & 1 deletion pkg/controller/pod_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -66,11 +66,13 @@ var _ = Describe("Dynamic Attachment controller", func() {
Context("with an existing running pod", func() {
const (
cniVersion = "0.3.0"
ipAddr = "172.16.0.1"
macAddr = "02:03:04:05:06:07"
namespace = "default"
networkName = "tiny-net"
podName = "tiny-winy-pod"
)
cniArgs := &map[string]string{"foo": "bar"}
var (
eventRecorder *record.FakeRecorder
k8sClient k8sclient.Interface
Expand Down Expand Up @@ -244,6 +246,61 @@ var _ = Describe("Dynamic Attachment controller", func() {
Eventually(<-eventRecorder.Events).Should(Equal(expectedEventPayload))
})
})

When("an attachment is added with attributes (IPs, MAC, cni-args)", func() {
JustBeforeEach(func() {
pod = updatePodSpec(pod)
netSelectionElements := append(generateNetworkSelectionElements(namespace, networkName),
nad.NetworkSelectionElement{
Name: networkToAdd,
Namespace: namespace,
InterfaceRequest: "net1",
IPRequest: []string{ipAddr},
MacRequest: macAddr,
CNIArgs: &map[string]interface{}{
"foo": "bar",
},
},
)
serelizedNetSelectionElements, _ := json.Marshal(netSelectionElements)
pod.Annotations[nad.NetworkAttachmentAnnot] = string(serelizedNetSelectionElements)
_, err := k8sClient.CoreV1().Pods(namespace).UpdateStatus(
context.TODO(),
pod,
metav1.UpdateOptions{})
Expect(err).NotTo(HaveOccurred())
})

It("an `AddedInterface` event is seen in the event recorded", func() {
expectedEventPayload := fmt.Sprintf(
"Normal AddedInterface pod [%s]: added interface %s to network: %s (ips: [%s], mac: %s, cni-args: %v)",
annotations.NamespacedName(namespace, podName),
"net1",
networkToAdd,
ipAddr,
macAddr,
cniArgs,
)
Eventually(<-eventRecorder.Events).Should(Equal(expectedEventPayload))
})

It("the pod network-status is updated with the new network attachment", func() {
Eventually(func() ([]nad.NetworkStatus, error) {
updatedPod, err := k8sClient.CoreV1().Pods(namespace).Get(context.TODO(), podName, metav1.GetOptions{})
if err != nil {
return nil, err
}
status, err := annotations.PodDynamicNetworkStatus(updatedPod)
if err != nil {
return nil, err
}
return status, nil
}).Should(ConsistOf(
ifaceStatus(namespace, networkName, "net0", ""),
ifaceStatus(namespace, networkToAdd, "net1", macAddr)))
})
})

})
})
})
Expand Down Expand Up @@ -425,7 +482,7 @@ func podNetworkConfig(networkNames ...string) map[string]string {
}
}

func generateNetworkSelectionAnnotation(namespace string, networkNames ...string) string {
func generateNetworkSelectionElements(namespace string, networkNames ...string) []nad.NetworkSelectionElement {
var netSelectionElements []nad.NetworkSelectionElement
for i, networkName := range networkNames {
netSelectionElements = append(
Expand All @@ -439,6 +496,11 @@ func generateNetworkSelectionAnnotation(namespace string, networkNames ...string
if netSelectionElements == nil {
netSelectionElements = make([]nad.NetworkSelectionElement, 0)
}
return netSelectionElements
}

func generateNetworkSelectionAnnotation(namespace string, networkNames ...string) string {
netSelectionElements := generateNetworkSelectionElements(namespace, networkNames...)
serelizedNetSelectionElements, err := json.Marshal(netSelectionElements)
if err != nil {
return ""
Expand Down

0 comments on commit 0603293

Please sign in to comment.