mirror of
				https://github.com/containers/podman.git
				synced 2025-10-31 18:08:51 +08:00 
			
		
		
		
	 72f1617fac
			
		
	
	72f1617fac
	
	
	
		
			
			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")
 | |
| }
 |