forked from tetratelabs/wazero
-
Notifications
You must be signed in to change notification settings - Fork 0
/
fsconfig_test.go
111 lines (97 loc) · 2.58 KB
/
fsconfig_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
package wazero
import (
"testing"
"github.com/tetratelabs/wazero/internal/sysfs"
testfs "github.com/tetratelabs/wazero/internal/testing/fs"
"github.com/tetratelabs/wazero/internal/testing/require"
)
// TestFSConfig only tests the cases that change the inputs to sysfs.NewRootFS.
func TestFSConfig(t *testing.T) {
base := NewFSConfig()
testFS := testfs.FS{}
testFS2 := testfs.FS{"/": &testfs.File{}}
tests := []struct {
name string
input FSConfig
expected sysfs.FS
}{
{
name: "empty",
input: base,
expected: sysfs.UnimplementedFS{},
},
{
name: "WithFSMount",
input: base.WithFSMount(testFS, "/"),
expected: sysfs.Adapt(testFS),
},
{
name: "WithFSMount overwrites",
input: base.WithFSMount(testFS, "/").WithFSMount(testFS2, "/"),
expected: sysfs.Adapt(testFS2),
},
{
name: "WithFsMount nil",
input: base.WithFSMount(nil, "/"),
expected: sysfs.UnimplementedFS{},
},
{
name: "WithDirMount overwrites",
input: base.WithFSMount(testFS, "/").WithDirMount(".", "/"),
expected: sysfs.NewDirFS("."),
},
{
name: "Composition",
input: base.WithReadOnlyDirMount(".", "/").WithDirMount("/tmp", "/tmp"),
expected: func() sysfs.FS {
f, err := sysfs.NewRootFS(
[]sysfs.FS{sysfs.NewReadFS(sysfs.NewDirFS(".")), sysfs.NewDirFS("/tmp")},
[]string{"/", "/tmp"},
)
require.NoError(t, err)
return f
}(),
},
}
for _, tt := range tests {
tc := tt
t.Run(tc.name, func(t *testing.T) {
sysCtx, err := tc.input.(*fsConfig).toFS()
require.NoError(t, err)
require.Equal(t, tc.expected, sysCtx)
})
}
}
func TestFSConfig_Errors(t *testing.T) {
tests := []struct {
name string
input FSConfig
expectedErr string
}{
{
name: "multi-level path not yet supported",
input: NewFSConfig().WithDirMount(".", "/usr/bin"),
expectedErr: "only single-level guest paths allowed: [.:/usr/bin]",
},
}
for _, tt := range tests {
tc := tt
t.Run(tc.name, func(t *testing.T) {
_, err := tc.input.(*fsConfig).toFS()
require.EqualError(t, err, tc.expectedErr)
})
}
}
func TestFSConfig_clone(t *testing.T) {
fc := NewFSConfig().(*fsConfig)
fc.guestPathToFS["/"] = 0
cloned := fc.clone()
// Make post-clone changes
fc.guestPaths = []string{"/"}
fc.guestPathToFS["/"] = 1
// Ensure the guestPathToFS map is not shared
require.Equal(t, map[string]int{"/": 1}, fc.guestPathToFS)
require.Equal(t, map[string]int{"/": 0}, cloned.guestPathToFS)
// Ensure the guestPaths slice is not shared
require.Zero(t, len(cloned.guestPaths))
}