All checks were successful
Test / Create distribution (push) Successful in 33s
Test / Sandbox (push) Successful in 2m14s
Test / Hakurei (push) Successful in 3m37s
Test / Hpkg (push) Successful in 4m27s
Test / Sandbox (race detector) (push) Successful in 4m23s
Test / Hakurei (race detector) (push) Successful in 5m22s
Test / Flake checks (push) Successful in 1m22s
This allows mount points to be represented by different underlying structs. Signed-off-by: Ophestra <cat@gensokyo.uk>
51 lines
1.2 KiB
Go
51 lines
1.2 KiB
Go
package hst_test
|
|
|
|
import (
|
|
"syscall"
|
|
"testing"
|
|
|
|
"hakurei.app/container"
|
|
"hakurei.app/hst"
|
|
)
|
|
|
|
func TestFSEphemeral(t *testing.T) {
|
|
checkFs(t, "ephemeral", []fsTestCase{
|
|
{"nil", (*hst.FSEphemeral)(nil), nil, nil, nil, "<invalid>"},
|
|
|
|
{"full", &hst.FSEphemeral{
|
|
Dst: m("/run/user/65534"),
|
|
Write: true,
|
|
Size: 1 << 10,
|
|
Perm: 0700,
|
|
}, container.Ops{&container.MountTmpfsOp{
|
|
FSName: "ephemeral",
|
|
Path: m("/run/user/65534"),
|
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
|
Size: 1 << 10,
|
|
Perm: 0700,
|
|
}}, m("/run/user/65534"), nil,
|
|
"w+ephemeral(-rwx------):/run/user/65534"},
|
|
|
|
{"cover ro", &hst.FSEphemeral{Dst: m("/run/nscd")},
|
|
container.Ops{&container.MountTmpfsOp{
|
|
FSName: "readonly",
|
|
Path: m("/run/nscd"),
|
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV | syscall.MS_RDONLY,
|
|
Perm: 0755,
|
|
}}, m("/run/nscd"), nil,
|
|
"+ephemeral(-rwxr-xr-x):/run/nscd"},
|
|
|
|
{"negative size", &hst.FSEphemeral{
|
|
Dst: hst.AbsTmp,
|
|
Write: true,
|
|
Size: -1,
|
|
}, container.Ops{&container.MountTmpfsOp{
|
|
FSName: "ephemeral",
|
|
Path: hst.AbsTmp,
|
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
|
Perm: 0755,
|
|
}}, hst.AbsTmp, nil,
|
|
"w+ephemeral(-rwxr-xr-x):/.hakurei"},
|
|
})
|
|
}
|