Skip to content

Commit

Permalink
chore: function renaming and change tests
Browse files Browse the repository at this point in the history
  • Loading branch information
zhijie-yang committed Nov 28, 2024
1 parent 310216f commit 9be1e54
Show file tree
Hide file tree
Showing 6 changed files with 85 additions and 33 deletions.
4 changes: 2 additions & 2 deletions internal/deb/extract.go
Original file line number Diff line number Diff line change
Expand Up @@ -320,7 +320,7 @@ func extractData(pkgReader io.ReadSeeker, options *ExtractOptions) error {
pendingPaths: pendingPaths,
}

err = handlePendingHardLinks(extractHardLinkOptions)
err = extractHardLinks(extractHardLinkOptions)
if err != nil {
return err
}
Expand Down Expand Up @@ -349,7 +349,7 @@ type extractHardLinkOptions struct {
pendingPaths map[string]bool
}

func handlePendingHardLinks(opts *extractHardLinkOptions) error {
func extractHardLinks(opts *extractHardLinkOptions) error {
for {
tarHeader, err := opts.tarReader.Next()
if err == io.EOF {
Expand Down
49 changes: 25 additions & 24 deletions internal/deb/extract_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -355,23 +355,47 @@ var extractTests = []extractTest{{
},
error: `cannot extract from package "test-package": path /dir/ requested twice with diverging mode: 0777 != 0000`,
}, {
summary: "Hard link is inflated with the target file",
summary: "Hard link is linked to the target file",
pkgdata: testutil.MustMakeDeb([]testutil.TarEntry{
testutil.Dir(0755, "./"),
testutil.Reg(0644, "./file", "text for file"),
testutil.Hln(0644, "./hardlink", "./file"),
}),
options: deb.ExtractOptions{
Extract: map[string][]deb.ExtractInfo{
"/file": []deb.ExtractInfo{{
Path: "/file",
}},
"/hardlink": []deb.ExtractInfo{{
Path: "/hardlink",
}},
},
},
result: map[string]string{
"/file": "file 0644 28121945",
"/hardlink": "file 0644 28121945",
},
notCreated: []string{},
}, {
summary: "Hard link is inflated with the target file",
pkgdata: testutil.MustMakeDeb([]testutil.TarEntry{
testutil.Dir(0755, "./"),
testutil.Reg(0644, "./file", "text for file"),
testutil.Hln(0644, "./hardlink1", "./file"),
testutil.Hln(0644, "./hardlink2", "./file"),
}),
options: deb.ExtractOptions{
Extract: map[string][]deb.ExtractInfo{
"/hardlink*": []deb.ExtractInfo{{
Path: "/hardlink*",
}},
},
},
result: map[string]string{
"/hardlink1": "file 0644 28121945",
"/hardlink2": "file 0644 28121945",
},
notCreated: []string{},
}, {
summary: "Dangling hard link",
pkgdata: testutil.MustMakeDeb([]testutil.TarEntry{
Expand Down Expand Up @@ -405,29 +429,6 @@ var extractTests = []extractTest{{
"/symlink": "symlink ./file",
},
notCreated: []string{},
}, {
summary: "Extract all types of files",
pkgdata: testutil.MustMakeDeb([]testutil.TarEntry{
testutil.Dir(0755, "./"),
testutil.Dir(0755, "./dir/"),
testutil.Reg(0644, "./dir/file", "text for file"),
testutil.Lnk(0644, "./symlink", "./dir/file"),
testutil.Hln(0644, "./hardlink", "./dir/file"),
}),
options: deb.ExtractOptions{
Extract: map[string][]deb.ExtractInfo{
"/**": []deb.ExtractInfo{{
Path: "/**",
}},
},
},
result: map[string]string{
"/dir/": "dir 0755",
"/dir/file": "file 0644 28121945",
"/hardlink": "file 0644 28121945",
"/symlink": "symlink ./dir/file",
},
notCreated: []string{},
}, {
summary: "Explicit extraction overrides existing file",
pkgdata: testutil.PackageData["test-package"],
Expand Down
3 changes: 2 additions & 1 deletion internal/fsutil/create_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -282,7 +282,8 @@ func (s *S) TestCreate(c *C) {
// [fsutil.Create] does not return information about parent directories
// created implicitly. We only check for the requested path.
if entry.Link != "" && entry.Mode&fs.ModeSymlink == 0 {
// Entry is a hard link.
// Entry is a hard link. We should test it differently to ensure
// that it produces a hard link indeed.
pathInfo, err := os.Lstat(entry.Path)
c.Assert(err, IsNil)
linkInfo, err := os.Lstat(entry.Link)
Expand Down
1 change: 0 additions & 1 deletion internal/manifest/report.go
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,6 @@ func (r *Report) getHardLinkId(fsEntry *fsutil.Entry) uint64 {
fsEntry.Link = ""
} else {
// The hard link links to a symlink
fmt.Println("FSENTRY:", fsEntry.Path, fsEntry.Link, "ENTRY:", entry.Path, entry.Link)
fsEntry.Link = entry.Link
}
}
Expand Down
57 changes: 56 additions & 1 deletion internal/slicer/slicer_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1653,7 +1653,8 @@ var slicerTests = []slicerTest{{
"/hardlink2.txt": "file 0644 dcddda2e <2> {test-package_myslice}",
},
}, {
summary: "Symlink is a valid hard link base file", slices: []setup.SliceKey{
summary: "Symlink is a valid hard link base file",
slices: []setup.SliceKey{
{"test-package", "myslice"}},
pkgs: []*testutil.TestPackage{{
Name: "test-package",
Expand Down Expand Up @@ -1683,6 +1684,60 @@ var slicerTests = []slicerTest{{
"/symlink": "symlink ./dir/file <1> {test-package_myslice}",
"/hardlink": "symlink ./dir/file <1> {test-package_myslice}",
},
}, {
summary: "Hard link IDs are unique to multiple packages",
slices: []setup.SliceKey{
{"test-package1", "myslice"},
{"test-package2", "myslice"},
},
pkgs: []*testutil.TestPackage{{
Name: "test-package1",
Data: testutil.MustMakeDeb([]testutil.TarEntry{
testutil.Dir(0755, "./"),
testutil.Dir(0755, "./dir/"),
testutil.Reg(0644, "./dir/file1", "text for file"),
testutil.Hln(0644, "./hardlink1", "./dir/file1"),
}),
}, {
Name: "test-package2",
Data: testutil.MustMakeDeb([]testutil.TarEntry{
testutil.Dir(0755, "./"),
testutil.Dir(0755, "./dir/"),
testutil.Reg(0644, "./dir/file2", "text for file"),
testutil.Hln(0644, "./hardlink2", "./dir/file2"),
}),
}},
release: map[string]string{
"slices/mydir/test-package1.yaml": `
package: test-package1
slices:
myslice:
contents:
/dir/file1:
/hardlink1:
`,
"slices/mydir/test-package2.yaml": `
package: test-package2
slices:
myslice:
contents:
/dir/file2:
/hardlink2:
`,
},
filesystem: map[string]string{
"/dir/": "dir 0755",
"/dir/file1": "file 0644 28121945",
"/hardlink1": "file 0644 28121945",
"/dir/file2": "file 0644 28121945",
"/hardlink2": "file 0644 28121945",
},
manifestPaths: map[string]string{
"/dir/file1": "file 0644 28121945 <1> {test-package1_myslice}",
"/hardlink1": "file 0644 28121945 <1> {test-package1_myslice}",
"/dir/file2": "file 0644 28121945 <2> {test-package2_myslice}",
"/hardlink2": "file 0644 28121945 <2> {test-package2_myslice}",
},
}}

var defaultChiselYaml = `
Expand Down
4 changes: 0 additions & 4 deletions internal/testutil/treedump.go
Original file line number Diff line number Diff line change
Expand Up @@ -75,10 +75,6 @@ func TreeDumpEntry(entry *fsutil.Entry) string {
case fs.ModeSymlink:
return fmt.Sprintf("symlink %s", entry.Link)
case 0:
// Hard link.
if entry.Link != "" {
return fmt.Sprintf("hardlink %s", entry.Link)
}
// Regular file.
if entry.Size == 0 {
return fmt.Sprintf("file %#o empty", entry.Mode.Perm())
Expand Down

0 comments on commit 9be1e54

Please sign in to comment.