container/initoverlay: check path equivalence by value
All checks were successful
Test / Create distribution (push) Successful in 33s
Test / Sandbox (push) Successful in 2m4s
Test / Hakurei (push) Successful in 3m7s
Test / Hpkg (push) Successful in 4m7s
Test / Sandbox (race detector) (push) Successful in 4m27s
Test / Hakurei (race detector) (push) Successful in 4m56s
Test / Flake checks (push) Successful in 1m19s
All checks were successful
Test / Create distribution (push) Successful in 33s
Test / Sandbox (push) Successful in 2m4s
Test / Hakurei (push) Successful in 3m7s
Test / Hpkg (push) Successful in 4m7s
Test / Sandbox (race detector) (push) Successful in 4m27s
Test / Hakurei (race detector) (push) Successful in 4m56s
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
97ab24feef
commit
696e593898
@ -163,11 +163,10 @@ func (o *MountOverlayOp) apply(state *setupState) error {
|
|||||||
|
|
||||||
func (o *MountOverlayOp) Is(op Op) bool {
|
func (o *MountOverlayOp) Is(op Op) bool {
|
||||||
vo, ok := op.(*MountOverlayOp)
|
vo, ok := op.(*MountOverlayOp)
|
||||||
return ok &&
|
return ok && ((o == nil && vo == nil) || (o != nil && vo != nil &&
|
||||||
o.Target == vo.Target &&
|
o.Target != nil && vo.Target != nil && o.Target.Is(vo.Target) &&
|
||||||
slices.Equal(o.Lower, vo.Lower) &&
|
slices.EqualFunc(o.Lower, vo.Lower, func(a *Absolute, v *Absolute) bool { return a.Is(v) }) &&
|
||||||
o.Upper == vo.Upper &&
|
o.Upper.Is(vo.Upper) && o.Work.Is(vo.Work)))
|
||||||
o.Work == vo.Work
|
|
||||||
}
|
}
|
||||||
func (*MountOverlayOp) prefix() string { return "mounting" }
|
func (*MountOverlayOp) prefix() string { return "mounting" }
|
||||||
func (o *MountOverlayOp) String() string {
|
func (o *MountOverlayOp) String() string {
|
||||||
|
111
container/initoverlay_test.go
Normal file
111
container/initoverlay_test.go
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
package container
|
||||||
|
|
||||||
|
import "testing"
|
||||||
|
|
||||||
|
func TestMountOverlayOp(t *testing.T) {
|
||||||
|
checkOpsBuilder(t, []opsBuilderTestCase{
|
||||||
|
{"full", new(Ops).Overlay(
|
||||||
|
MustAbs("/nix/store"),
|
||||||
|
MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
MustAbs("/mnt-root/nix/.rw-store/work"),
|
||||||
|
MustAbs("/mnt-root/nix/.ro-store"),
|
||||||
|
), Ops{
|
||||||
|
&MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work"),
|
||||||
|
},
|
||||||
|
}},
|
||||||
|
|
||||||
|
{"ephemeral", new(Ops).OverlayEphemeral(MustAbs("/nix/store"), MustAbs("/mnt-root/nix/.ro-store")), Ops{
|
||||||
|
&MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/"),
|
||||||
|
},
|
||||||
|
}},
|
||||||
|
|
||||||
|
{"readonly", new(Ops).OverlayReadonly(MustAbs("/nix/store"), MustAbs("/mnt-root/nix/.ro-store")), Ops{
|
||||||
|
&MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
},
|
||||||
|
}},
|
||||||
|
})
|
||||||
|
|
||||||
|
checkOpIs(t, []opIsTestCase{
|
||||||
|
{"zero", new(MountOverlayOp), new(MountOverlayOp), false},
|
||||||
|
|
||||||
|
{"differs target", &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store/differs"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work"),
|
||||||
|
}, &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work")}, false},
|
||||||
|
|
||||||
|
{"differs lower", &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store/differs")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work"),
|
||||||
|
}, &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work")}, false},
|
||||||
|
|
||||||
|
{"differs upper", &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper/differs"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work"),
|
||||||
|
}, &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work")}, false},
|
||||||
|
|
||||||
|
{"differs work", &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work/differs"),
|
||||||
|
}, &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work")}, false},
|
||||||
|
|
||||||
|
{"equals ro", &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
}, &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")}}, true},
|
||||||
|
|
||||||
|
{"equals", &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work"),
|
||||||
|
}, &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work")}, true},
|
||||||
|
})
|
||||||
|
|
||||||
|
checkOpMeta(t, []opMetaTestCase{
|
||||||
|
{"nix", &MountOverlayOp{
|
||||||
|
Target: MustAbs("/nix/store"),
|
||||||
|
Lower: []*Absolute{MustAbs("/mnt-root/nix/.ro-store")},
|
||||||
|
Upper: MustAbs("/mnt-root/nix/.rw-store/upper"),
|
||||||
|
Work: MustAbs("/mnt-root/nix/.rw-store/work"),
|
||||||
|
}, "mounting", `overlay on "/nix/store" with 1 layers`},
|
||||||
|
})
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user