use .Buffer() for layer contents

This commit is contained in:
2021-05-24 00:11:58 +03:00
parent c3be4bdb35
commit 81db130c94
3 changed files with 43 additions and 42 deletions

View File

@@ -12,11 +12,7 @@ import (
type (
Tarrer interface {
Tar(*tar.Writer)
}
Byter interface {
Bytes() []byte
Tar(*tar.Writer) error
}
Tarball []Tarrer
@@ -33,7 +29,7 @@ type (
File struct {
Name string
Uid int
Contents Byter
Contents *bytes.Buffer
}
Manifest []string
@@ -48,55 +44,60 @@ type (
}
)
func (tb Tarball) Bytes() []byte {
buf := bytes.Buffer{}
func (tb Tarball) Buffer() *bytes.Buffer {
var buf bytes.Buffer
tw := tar.NewWriter(&buf)
for _, member := range tb {
member.Tar(tw)
}
tw.Close()
return buf.Bytes()
return &buf
}
func (d Dir) Tar(tw *tar.Writer) {
func (d Dir) Tar(tw *tar.Writer) error {
hdr := &tar.Header{
Typeflag: tar.TypeDir,
Name: d.Name,
Mode: 0644,
Uid: d.Uid,
}
tw.WriteHeader(hdr)
return tw.WriteHeader(hdr)
}
func (f File) Tar(tw *tar.Writer) {
var contentbytes []byte
func (f File) Tar(tw *tar.Writer) error {
var contents []byte
if f.Contents != nil {
contentbytes = f.Contents.Bytes()
contents = f.Contents.Bytes()
}
hdr := &tar.Header{
Typeflag: tar.TypeReg,
Name: f.Name,
Mode: 0644,
Uid: f.Uid,
Size: int64(len(contentbytes)),
Size: int64(len(contents)),
}
tw.WriteHeader(hdr)
tw.Write(contentbytes)
if err := tw.WriteHeader(hdr); err != nil {
return err
}
if _, err := tw.Write(contents); err != nil {
return err
}
return nil
}
func (m Manifest) Tar(tw *tar.Writer) {
func (m Manifest) Tar(tw *tar.Writer) error {
b, err := json.Marshal(dockerManifestJSON{{Layers: m}})
if err != nil {
panic("testerr")
return err
}
File{
return File{
Name: "manifest.json",
Contents: bytes.NewBuffer(b),
}.Tar(tw)
}
func (h Hardlink) Tar(tw *tar.Writer) {
tw.WriteHeader(&tar.Header{
func (h Hardlink) Tar(tw *tar.Writer) error {
return tw.WriteHeader(&tar.Header{
Typeflag: tar.TypeLink,
Name: h.Name,
Mode: 0644,

View File

@@ -10,15 +10,15 @@ import (
func TestTarball(t *testing.T) {
bk := Tarball{File{Name: "entrypoint.sh", Contents: bytes.NewBufferString("hello")}}
img := Tarball{
File{Name: "backup.tar", Contents: bk},
File{Name: "backup.tar", Contents: bk.Buffer()},
File{Name: "entrypoint.sh", Contents: bytes.NewBufferString("bye")},
Dir{Name: "bin"},
Hardlink{Name: "entrypoint2"},
}
got := Extract(t, bytes.NewBuffer(img.Bytes()))
got := Extract(t, img.Buffer())
want := []Extractable{
File{Name: "backup.tar", Contents: bytes.NewBuffer(bk.Bytes())},
File{Name: "backup.tar", Contents: bk.Buffer()},
File{Name: "entrypoint.sh", Contents: bytes.NewBufferString("bye")},
Dir{Name: "bin"},
Hardlink{Name: "entrypoint2"},