Skip to content

Commit

Permalink
kernel: Fix IsKernelLockdownMode
Browse files Browse the repository at this point in the history
Passing `/bin/sh -c xxx` to `RunCommand` requires xxx to be a single string
representing a full command. Multiple arguments shifts the executed command
from:
```
/bin/sh -c "cat file.txt"
```
to:
```
/bin/sh -c cat file.txt
```

This regression has been introduced by:
- k8snetworkplumbingwg/sriov-network-operator#553

Signed-off-by: Andrea Panattoni <[email protected]>
  • Loading branch information
zeeke authored and SchSeba committed May 7, 2024
1 parent 28d09f1 commit de8bf41
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 2 deletions.
2 changes: 1 addition & 1 deletion pkg/host/internal/kernel/kernel.go
Original file line number Diff line number Diff line change
Expand Up @@ -579,7 +579,7 @@ func (k *kernel) IsKernelLockdownMode() bool {
path := utils.GetHostExtension()
path = filepath.Join(path, "/sys/kernel/security/lockdown")

stdout, stderr, err := k.utilsHelper.RunCommand("/bin/sh", "-c", "cat", path)
stdout, stderr, err := k.utilsHelper.RunCommand("cat", path)
log.Log.V(2).Info("IsKernelLockdownMode()", "output", stdout, "error", err)
if err != nil {
log.Log.Error(err, "IsKernelLockdownMode(): failed to check for lockdown file", "stderr", stderr)
Expand Down
25 changes: 24 additions & 1 deletion pkg/host/internal/kernel/kernel_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import (

"github.com/k8snetworkplumbingwg/sriov-network-operator/pkg/consts"
"github.com/k8snetworkplumbingwg/sriov-network-operator/pkg/host/types"
"github.com/k8snetworkplumbingwg/sriov-network-operator/pkg/utils"
"github.com/k8snetworkplumbingwg/sriov-network-operator/test/util/fakefilesystem"
"github.com/k8snetworkplumbingwg/sriov-network-operator/test/util/helpers"
)
Expand All @@ -16,7 +17,7 @@ var _ = Describe("Kernel", func() {
k types.KernelInterface
)
BeforeEach(func() {
k = New(nil)
k = New(utils.New())
})
Context("Unbind, UnbindDriverByBusAndDevice", func() {
It("unknown device", func() {
Expand Down Expand Up @@ -217,5 +218,27 @@ var _ = Describe("Kernel", func() {
Expect(driver).To(BeEmpty())
})
})

Context("IsKernelLockdownMode", func() {
It("should return true when kernel boots in lockdown integrity", func() {
helpers.GinkgoConfigureFakeFS(&fakefilesystem.FS{
Dirs: []string{"/host/sys/kernel/security"},
Files: map[string][]byte{
"/host/sys/kernel/security/lockdown": []byte("none [integrity] confidentiality")},
})

Expect(k.IsKernelLockdownMode()).To(BeTrue())
})

It("should return false when kernel lockdown is none", func() {
helpers.GinkgoConfigureFakeFS(&fakefilesystem.FS{
Dirs: []string{"/host/sys/kernel/security"},
Files: map[string][]byte{
"/host/sys/kernel/security/lockdown": []byte("[none] integrity confidentiality")},
})

Expect(k.IsKernelLockdownMode()).To(BeFalse())
})
})
})
})

0 comments on commit de8bf41

Please sign in to comment.