mirror of
https://github.com/containers/podman.git
synced 2025-05-21 09:05:56 +08:00

Moving from Go module v4 to v5 prepares us for public releases. Move done using gomove [1] as with the v3 and v4 moves. [1] https://github.com/KSubedi/gomove Signed-off-by: Matt Heon <mheon@redhat.com>
219 lines
6.7 KiB
Go
219 lines
6.7 KiB
Go
//go:build linux
|
|
|
|
package specgenutil
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/containers/common/pkg/machine"
|
|
"github.com/containers/podman/v5/pkg/domain/entities"
|
|
"github.com/containers/podman/v5/pkg/specgen"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestWinPath(t *testing.T) {
|
|
const (
|
|
fail = false
|
|
pass = true
|
|
)
|
|
tests := []struct {
|
|
vol string
|
|
source string
|
|
dest string
|
|
isN bool
|
|
outcome bool
|
|
mach string
|
|
}{
|
|
{`C:\Foo:/blah`, "/mnt/c/Foo", "/blah", false, pass, "wsl"},
|
|
{`C:\Foo:/blah`, "/mnt/c/Foo", "/blah", false, fail, ""},
|
|
{`\\?\C:\Foo:/blah`, "/mnt/c/Foo", "/blah", false, pass, "wsl"},
|
|
{`/c/bar:/blah`, "/mnt/c/bar", "/blah", false, pass, "wsl"},
|
|
{`/c/bar:/blah`, "/c/bar", "/blah", false, pass, ""},
|
|
{`/test/this:/blah`, "/test/this", "/blah", false, pass, "wsl"},
|
|
{`c:/bar/something:/other`, "/mnt/c/bar/something", "/other", false, pass, "wsl"},
|
|
{`c:/foo:ro`, "c", "/foo", true, pass, ""},
|
|
{`\\computer\loc:/dest`, "", "", false, fail, "wsl"},
|
|
{`\\.\drive\loc:/target`, "/mnt/wsl/drive/loc", "/target", false, pass, "wsl"},
|
|
}
|
|
|
|
f := func(vol string, mach string) (*specgen.SpecGenerator, error) {
|
|
machine := machine.GetMachineMarker()
|
|
oldEnable, oldType := machine.Enabled, machine.Type
|
|
machine.Enabled, machine.Type = len(mach) > 0, mach
|
|
sg := specgen.NewSpecGenerator("nothing", false)
|
|
err := FillOutSpecGen(sg, &entities.ContainerCreateOptions{
|
|
ImageVolume: "ignore",
|
|
Volume: []string{vol}}, []string{},
|
|
)
|
|
machine.Enabled, machine.Type = oldEnable, oldType
|
|
return sg, err
|
|
}
|
|
|
|
for _, test := range tests {
|
|
msg := "Checking: " + test.vol
|
|
sg, err := f(test.vol, test.mach)
|
|
if test.outcome == fail {
|
|
assert.NotNil(t, err, msg)
|
|
continue
|
|
}
|
|
if !assert.Nil(t, err, msg) {
|
|
continue
|
|
}
|
|
if test.isN {
|
|
if !assert.Equal(t, 1, len(sg.Volumes), msg) {
|
|
continue
|
|
}
|
|
assert.Equal(t, test.source, sg.Volumes[0].Name, msg)
|
|
assert.Equal(t, test.dest, sg.Volumes[0].Dest, msg)
|
|
} else {
|
|
if !assert.Equal(t, 1, len(sg.Mounts), msg) {
|
|
continue
|
|
}
|
|
assert.Equal(t, test.source, sg.Mounts[0].Source, msg)
|
|
assert.Equal(t, test.dest, sg.Mounts[0].Destination, msg)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestParseLinuxResourcesDeviceAccess(t *testing.T) {
|
|
d, err := parseLinuxResourcesDeviceAccess("a *:* rwm")
|
|
assert.Nil(t, err, "err is nil")
|
|
assert.True(t, d.Allow, "allow is true")
|
|
assert.Equal(t, d.Type, "a", "type is 'a'")
|
|
assert.Nil(t, d.Minor, "minor is nil")
|
|
assert.Nil(t, d.Major, "major is nil")
|
|
|
|
d, err = parseLinuxResourcesDeviceAccess("b 3:* rwm")
|
|
assert.Nil(t, err, "err is nil")
|
|
assert.True(t, d.Allow, "allow is true")
|
|
assert.Equal(t, d.Type, "b", "type is 'b'")
|
|
assert.Nil(t, d.Minor, "minor is nil")
|
|
assert.NotNil(t, d.Major, "major is not nil")
|
|
assert.Equal(t, *d.Major, int64(3), "major is 3")
|
|
|
|
d, err = parseLinuxResourcesDeviceAccess("a *:3 rwm")
|
|
assert.Nil(t, err, "err is nil")
|
|
assert.True(t, d.Allow, "allow is true")
|
|
assert.Equal(t, d.Type, "a", "type is 'a'")
|
|
assert.Nil(t, d.Major, "major is nil")
|
|
assert.NotNil(t, d.Minor, "minor is not nil")
|
|
assert.Equal(t, *d.Minor, int64(3), "minor is 3")
|
|
|
|
d, err = parseLinuxResourcesDeviceAccess("c 1:2 rwm")
|
|
assert.Nil(t, err, "err is nil")
|
|
assert.True(t, d.Allow, "allow is true")
|
|
assert.Equal(t, d.Type, "c", "type is 'c'")
|
|
assert.NotNil(t, d.Major, "minor is not nil")
|
|
assert.Equal(t, *d.Major, int64(1), "minor is 1")
|
|
assert.NotNil(t, d.Minor, "minor is not nil")
|
|
assert.Equal(t, *d.Minor, int64(2), "minor is 2")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("q *:* rwm")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a a:* rwm")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a *:a rwm")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a *:* abc")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("* *:* *")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("* *:a2 *")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("*")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("*:*")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a *:*")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a *:*")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a 12a:* r")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a a12:* r")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a 0x1:* r")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a -2:* r")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
|
|
_, err = parseLinuxResourcesDeviceAccess("a *:-3 r")
|
|
assert.NotNil(t, err, "err is not nil")
|
|
}
|
|
|
|
func TestGenRlimits(t *testing.T) {
|
|
testLimits := map[string]string{
|
|
"core": "1:2",
|
|
"cpu": "1:2",
|
|
"data": "1:2",
|
|
"fsize": "1:2",
|
|
"locks": "1:2",
|
|
"memlock": "1:2",
|
|
"msgqueue": "1:2",
|
|
"nice": "1:2",
|
|
"nofile": "1:2",
|
|
"nproc": "1:2",
|
|
"rss": "1:2",
|
|
"rtprio": "1:2",
|
|
"rttime": "1:2",
|
|
"sigpending": "1:2",
|
|
"stack": "1:2",
|
|
}
|
|
|
|
lowerCaseLimits := make([]string, 0, len(testLimits))
|
|
upperCaseLimitsWithPrefix := make([]string, 0, len(testLimits))
|
|
for name, limit := range testLimits {
|
|
lowerCaseLimits = append(lowerCaseLimits, fmt.Sprintf("%s=%s", name, limit))
|
|
upperCaseLimitsWithPrefix = append(upperCaseLimitsWithPrefix, strings.ToUpper(fmt.Sprintf("%s%s=%s", rlimitPrefix, name, limit)))
|
|
}
|
|
|
|
parsedLimits, err := GenRlimits(lowerCaseLimits)
|
|
assert.NoError(t, err, "err is nil")
|
|
|
|
for _, limit := range parsedLimits {
|
|
val, ok := testLimits[limit.Type]
|
|
assert.True(t, ok, "%s matched", limit.Type)
|
|
assert.Equal(t, val, fmt.Sprintf("%d:%d", limit.Soft, limit.Hard), "soft and hard limits are equal")
|
|
}
|
|
|
|
parsedLimits, err = GenRlimits(upperCaseLimitsWithPrefix)
|
|
assert.NoError(t, err, "err is nil")
|
|
|
|
for _, limit := range parsedLimits {
|
|
val, ok := testLimits[limit.Type]
|
|
assert.True(t, ok, "%s matched", limit.Type)
|
|
assert.Equal(t, val, fmt.Sprintf("%d:%d", limit.Soft, limit.Hard), "soft and hard limits are equal")
|
|
}
|
|
|
|
// go-utils module has no tests for the parser.
|
|
_, err = GenRlimits([]string{"foo=1:1"})
|
|
assert.Error(t, err, "err is not nil")
|
|
|
|
_, err = GenRlimits([]string{"RLIMIT_FOO=1:1"})
|
|
assert.Error(t, err, "err is not nil")
|
|
|
|
_, err = GenRlimits([]string{"nofile"})
|
|
assert.Error(t, err, "err is not nil")
|
|
|
|
_, err = GenRlimits([]string{"nofile=bar"})
|
|
assert.Error(t, err, "err is not nil")
|
|
|
|
_, err = GenRlimits([]string{"nofile=bar:buzz"})
|
|
assert.Error(t, err, "err is not nil")
|
|
}
|