Skip to content

Commit

Permalink
fix(agent): missing path for pod without labels (#2518)
Browse files Browse the repository at this point in the history
## Description

identify when a pod has no labels (and thus has no `/metadata/labels`
for jsonpatch replace operations. use the `add` jsonpath operation to
add the labels path with the map[string]string value of `{"zarf-agent":
"patched"}`

## Related Issue

Fixes #2517

## Testing
Deploy a pod without labels to test:
```
apiVersion: v1
kind: Pod
metadata:
  creationTimestamp: null
  name: test
  namespace: test
spec:
  containers:
  - image: nginx
    name: test
    resources: {}
  dnsPolicy: ClusterFirst
  restartPolicy: Always
status: {}
```

## Checklist before merging

- [x] Test, docs, adr added or updated as needed
- [x] [Contributor Guide
Steps](https://github.com/defenseunicorns/zarf/blob/main/.github/CONTRIBUTING.md#developer-workflow)
followed

Signed-off-by: Austin Abro <AustinAbro321@gmail.com>
  • Loading branch information
brandtkeller authored and AustinAbro321 committed Jul 23, 2024
1 parent afe5fa4 commit c0c389b
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 1 deletion.
10 changes: 9 additions & 1 deletion src/internal/agent/hooks/pods.go
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,15 @@ func mutatePod(r *v1.AdmissionRequest) (*operations.Result, error) {
}

// Add a label noting the zarf mutation
patchOperations = append(patchOperations, operations.ReplacePatchOperation("/metadata/labels/zarf-agent", "patched"))
if pod.Labels == nil {
// If the labels path does not exist - create with map[string]string value
patchOperations = append(patchOperations, operations.AddPatchOperation("/metadata/labels",
map[string]string{
"zarf-agent": "patched",
}))
} else {
patchOperations = append(patchOperations, operations.ReplacePatchOperation("/metadata/labels/zarf-agent", "patched"))
}

return &operations.Result{
Allowed: true,
Expand Down
35 changes: 35 additions & 0 deletions src/test/e2e/37_pod_without_labels_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
// SPDX-License-Identifier: Apache-2.0
// SPDX-FileCopyrightText: 2021-Present The Zarf Authors

// Package test provides e2e tests for Zarf.
package test

import (
"path/filepath"
"testing"

"github.com/stretchr/testify/require"
)

func TestPodWithoutLabels(t *testing.T) {
t.Log("E2E: Pod Without Labels")
e2e.SetupWithCluster(t)

// Path to pod manifest containing 0 lavbels
buildPath := filepath.Join("src", "test", "packages", "37-pod-without-labels", "pod.yaml")

// Create the testing namespace
_, _, err := e2e.Kubectl("create", "ns", "pod-label")
require.NoError(t, err)

// Create the pod without labels
// This is not an image zarf will have in the registry - but the agent was failing to admit on an internal server error before completing admission
_, _, err = e2e.Kubectl("create", "-f", buildPath, "-n", "pod-label")
require.NoError(t, err)

// Cleanup
_, _, err = e2e.Kubectl("delete", "-f", buildPath, "-n", "pod-label")
require.NoError(t, err)
_, _, err = e2e.Kubectl("delete", "ns", "pod-label")
require.NoError(t, err)
}
13 changes: 13 additions & 0 deletions src/test/packages/37-pod-without-labels/pod.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
apiVersion: v1
kind: Pod
metadata:
creationTimestamp: null
name: test
spec:
containers:
- image: nginx
name: test
resources: {}
dnsPolicy: ClusterFirst
restartPolicy: Always
status: {}

0 comments on commit c0c389b

Please sign in to comment.