Skip to content

Commit

Permalink
Attempt to mount using mountBYAPI without makeConfig
Browse files Browse the repository at this point in the history
Signed-off-by: fappy1234567 <2019gexinlei@bupt.edu.cn>
  • Loading branch information
fappy1234567 committed Aug 21, 2024
1 parent 52ed07b commit c27f8f6
Show file tree
Hide file tree
Showing 3 changed files with 85 additions and 17 deletions.
2 changes: 1 addition & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

42 changes: 42 additions & 0 deletions smoke/tests/api_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -193,6 +193,48 @@ func (a *APIV1TestSuite) TestPrefetch(t *testing.T) {
require.NoError(t, err)
}

func (a *APIV1TestSuite) TestMount(t *testing.T) {

ctx := tool.DefaultContext(t)

ctx.PrepareWorkDir(t)
defer ctx.Destroy(t)

rootFs := texture.MakeLowerLayer(t, filepath.Join(ctx.Env.WorkDir, "root-fs"))

rafs := a.buildLayer(t, ctx, rootFs)

config := tool.NydusdConfig{
NydusdPath: ctx.Binary.Nydusd,
MountPath: ctx.Env.MountDir,
APISockPath: filepath.Join(ctx.Env.WorkDir, "nydusd-api.sock"),
ConfigPath: filepath.Join(ctx.Env.WorkDir, "nydusd-config.fusedev.json"),
}
nydusd, err := tool.NewNydusd(config)
require.NoError(t, err)

err = nydusd.Mount()
require.NoError(t, err)

config.BootstrapPath = rafs
config.MountPath = "/mount1"
config.BackendType = "localfs"
config.BackendConfig = fmt.Sprintf(`{"dir": "%s"}`, ctx.Env.BlobDir)
config.BlobCacheDir = ctx.Env.CacheDir
config.CacheType = ctx.Runtime.CacheType
config.CacheCompressed = ctx.Runtime.CacheCompressed
config.RafsMode = ctx.Runtime.RafsMode
config.EnablePrefetch = ctx.Runtime.EnablePrefetch
config.DigestValidate = false
config.AmplifyIO = ctx.Runtime.AmplifyIO
err = nydusd.MountByAPI(config)
require.NoError(t, err)

defer nydusd.Umount()
defer nydusd.UmountByAPI(config.MountPath)
nydusd.VerifyByPath(t, rootFs.FileTree, config.MountPath)
}

func (a *APIV1TestSuite) buildLayer(t *testing.T, ctx *tool.Context, rootFs *tool.Layer) string {
digest := rootFs.Pack(t,
converter.PackOption{
Expand Down
58 changes: 42 additions & 16 deletions smoke/tests/tool/nydusd.go
Original file line number Diff line number Diff line change
Expand Up @@ -315,19 +315,24 @@ func (nydusd *Nydusd) Mount() error {
}

func (nydusd *Nydusd) MountByAPI(config NydusdConfig) error {
err := makeConfig(NydusdConfigTpl, config)
if err != nil {
return err
}
f, err := os.Open(config.ConfigPath)
if err != nil {
return err
var tpl *template.Template

tplType := NydusdConfigTpl

switch tplType {
case NydusdConfigTpl:
tpl = template.Must(template.New("").Parse(configTpl))
case NydusdOvlConfigTpl:
tpl = template.Must(template.New("").Parse(configOvlTpl))
default:
return errors.New("unknown template type")
}
defer f.Close()
rafsConfig, err := io.ReadAll(f)
if err != nil {
return err

var ret bytes.Buffer
if err := tpl.Execute(&ret, config); err != nil {
return errors.New("prepare config template for Nydusd")
}
rafsConfig := ret.String()

nydusdConfig := struct {
Bootstrap string `json:"source"`
Expand All @@ -336,7 +341,7 @@ func (nydusd *Nydusd) MountByAPI(config NydusdConfig) error {
PrefetchFiles []string `json:"prefetch_files"`
}{
Bootstrap: config.BootstrapPath,
RafsConfig: string(rafsConfig),
RafsConfig: rafsConfig,
FsType: "rafs",
PrefetchFiles: config.PrefetchFiles,
}
Expand All @@ -352,6 +357,7 @@ func (nydusd *Nydusd) MountByAPI(config NydusdConfig) error {
)

return err

}

func (nydusd *Nydusd) Umount() error {
Expand All @@ -365,6 +371,23 @@ func (nydusd *Nydusd) Umount() error {
return nil
}

func (nydusd *Nydusd) UmountByAPI(point string) error {
path := point
// path: /mount1
url := fmt.Sprintf("http://unix/api/v1/mount?mountpoint=%s", path)
req, err := http.NewRequest("DELETE", url, nil)
if err != nil {
return err
}
resp, err := nydusd.client.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()

return nil
}

func (nydusd *Nydusd) WaitStatus(states ...string) error {
ctx, cancel := context.WithTimeout(context.Background(), time.Second*10)
defer cancel()
Expand Down Expand Up @@ -622,17 +645,20 @@ func (nydusd *Nydusd) GetInflightMetrics() (*InflightMetrics, error) {
}

func (nydusd *Nydusd) Verify(t *testing.T, expectedFileTree map[string]*File) {
nydusd.VerifyByPath(t, expectedFileTree, nydusd.MountPath)
}

func (nydusd *Nydusd) VerifyByPath(t *testing.T, expectedFileTree map[string]*File, point string) {
actualFiles := map[string]*File{}
err := filepath.WalkDir(nydusd.MountPath, func(path string, _ fs.DirEntry, err error) error {
require.Nil(t, err)

targetPath, err := filepath.Rel(nydusd.MountPath, path)
require.NoError(t, err)

if targetPath == "." || targetPath == ".." {
pointMdr := strings.TrimPrefix(point, "/")
targetPath = strings.TrimPrefix(targetPath, pointMdr+"/")
if targetPath == "." || targetPath == ".." || targetPath == pointMdr {
return nil
}

file := NewFile(t, path, targetPath)
actualFiles[targetPath] = file
if expectedFileTree[targetPath] != nil {
Expand Down

0 comments on commit c27f8f6

Please sign in to comment.