container/inittmpfs: check path equivalence by value
All checks were successful
Test / Create distribution (push) Successful in 34s
Test / Sandbox (push) Successful in 2m10s
Test / Hakurei (push) Successful in 3m5s
Test / Hpkg (push) Successful in 4m2s
Test / Sandbox (race detector) (push) Successful in 4m21s
Test / Hakurei (race detector) (push) Successful in 4m57s
Test / Flake checks (push) Successful in 1m19s
All checks were successful
Test / Create distribution (push) Successful in 34s
Test / Sandbox (push) Successful in 2m10s
Test / Hakurei (push) Successful in 3m5s
Test / Hpkg (push) Successful in 4m2s
Test / Sandbox (race detector) (push) Successful in 4m21s
Test / Hakurei (race detector) (push) Successful in 4m57s
Test / Flake checks (push) Successful in 1m19s
Fixes regression introduced while integrating Absolute. Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
parent
a07f9ed84c
commit
a1482ecdd0
@ -42,6 +42,11 @@ func (t *MountTmpfsOp) apply(*setupState) error {
|
|||||||
return mountTmpfs(t.FSName, toSysroot(t.Path.String()), t.Flags, t.Size, t.Perm)
|
return mountTmpfs(t.FSName, toSysroot(t.Path.String()), t.Flags, t.Size, t.Perm)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *MountTmpfsOp) Is(op Op) bool { vt, ok := op.(*MountTmpfsOp); return ok && *t == *vt }
|
func (t *MountTmpfsOp) Is(op Op) bool {
|
||||||
|
vt, ok := op.(*MountTmpfsOp)
|
||||||
|
return ok && ((t == nil && vt == nil) ||
|
||||||
|
(t.Path != nil && vt.Path != nil && t.Path.Is(vt.Path)) &&
|
||||||
|
t.FSName == vt.FSName && t.Flags == vt.Flags && t.Size == vt.Size && t.Perm == vt.Perm)
|
||||||
|
}
|
||||||
func (*MountTmpfsOp) prefix() string { return "mounting" }
|
func (*MountTmpfsOp) prefix() string { return "mounting" }
|
||||||
func (t *MountTmpfsOp) String() string { return fmt.Sprintf("tmpfs on %q size %d", t.Path, t.Size) }
|
func (t *MountTmpfsOp) String() string { return fmt.Sprintf("tmpfs on %q size %d", t.Path, t.Size) }
|
||||||
|
134
container/inittmpfs_test.go
Normal file
134
container/inittmpfs_test.go
Normal file
@ -0,0 +1,134 @@
|
|||||||
|
package container
|
||||||
|
|
||||||
|
import (
|
||||||
|
"syscall"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestMountTmpfsOp(t *testing.T) {
|
||||||
|
checkOpsBuilder(t, []opsBuilderTestCase{
|
||||||
|
{"runtime", new(Ops).Tmpfs(
|
||||||
|
MustAbs("/run/user"),
|
||||||
|
1<<10,
|
||||||
|
0755,
|
||||||
|
), Ops{
|
||||||
|
&MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
},
|
||||||
|
}},
|
||||||
|
|
||||||
|
{"nscd", new(Ops).Readonly(
|
||||||
|
MustAbs("/var/run/nscd"),
|
||||||
|
0755,
|
||||||
|
), Ops{
|
||||||
|
&MountTmpfsOp{
|
||||||
|
FSName: "readonly",
|
||||||
|
Path: MustAbs("/var/run/nscd"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV | syscall.MS_RDONLY,
|
||||||
|
Perm: 0755,
|
||||||
|
},
|
||||||
|
}},
|
||||||
|
})
|
||||||
|
|
||||||
|
checkOpIs(t, []opIsTestCase{
|
||||||
|
{"zero", new(MountTmpfsOp), new(MountTmpfsOp), false},
|
||||||
|
|
||||||
|
{"fsname differs", &MountTmpfsOp{
|
||||||
|
FSName: "readonly",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, false},
|
||||||
|
|
||||||
|
{"path differs", &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user/differs"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, false},
|
||||||
|
|
||||||
|
{"flags differs", &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV | syscall.MS_RDONLY,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, false},
|
||||||
|
|
||||||
|
{"size differs", &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1,
|
||||||
|
Perm: 0755,
|
||||||
|
}, &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, false},
|
||||||
|
|
||||||
|
{"perm differs", &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0700,
|
||||||
|
}, &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, false},
|
||||||
|
|
||||||
|
{"equals", &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, true},
|
||||||
|
})
|
||||||
|
|
||||||
|
checkOpMeta(t, []opMetaTestCase{
|
||||||
|
{"runtime", &MountTmpfsOp{
|
||||||
|
FSName: "ephemeral",
|
||||||
|
Path: MustAbs("/run/user"),
|
||||||
|
Flags: syscall.MS_NOSUID | syscall.MS_NODEV,
|
||||||
|
Size: 1 << 10,
|
||||||
|
Perm: 0755,
|
||||||
|
}, "mounting", `tmpfs on "/run/user" size 1024`},
|
||||||
|
})
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user