Skip to content

Commit

Permalink
Port bomb.zip test updates from v1 (#425)
Browse files Browse the repository at this point in the history
* Merge pull request #424 from hashicorp/fix-av-reports

Remove `bomb.zip` test file to stop anti-virus noise

* Update call to WriteFile

---------

Co-authored-by: Kent 'picat' Gruber <[email protected]>
  • Loading branch information
nywilken and picatz authored Mar 13, 2023
1 parent d5cdddb commit 79d9081
Show file tree
Hide file tree
Showing 2 changed files with 62 additions and 14 deletions.
76 changes: 62 additions & 14 deletions decompress_zip_test.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
package getter

import (
"archive/zip"
"bytes"
"io/ioutil"
"log"
"os"
"path/filepath"
"runtime"
Expand Down Expand Up @@ -132,23 +136,67 @@ func TestDecompressZipPermissions(t *testing.T) {
}

func TestDecompressZipBomb(t *testing.T) {
// If the zip decompression bomb protection fails, this can fill up disk space on the entire
// computer.
if os.Getenv("GO_GETTER_TEST_ZIP_BOMB") != "true" {
t.Skip("skipping potentially dangerous test without GO_GETTER_TEST_ZIP_BOMB=true")
buf := new(bytes.Buffer)

// Create a zip file inline, written to the buffer.
{
w := zip.NewWriter(buf)

var files = []struct {
Name, Body string
}{
{"readme.txt", "This archive contains some text files."},
{"gopher.txt", "Gopher names:\nGeorge\nGeoffrey\nGonzo"},
{"todo.txt", "Get animal handling licence.\nWrite more examples."},
}
for _, file := range files {
f, err := w.Create(file.Name)
if err != nil {
t.Fatal(err)
}
_, err = f.Write([]byte(file.Body))
if err != nil {
t.Fatal(err)
}
}

err := w.Close()
if err != nil {
log.Fatal(err)
}
}

// https://www.bamsoftware.com/hacks/zipbomb/zblg.zip
srcPath := filepath.Join("./testdata", "decompress-zip", "bomb.zip")
td, err := ioutil.TempDir("", "go-getter-zip")
if err != nil {
t.Fatalf("err: %s", err)
}

d := new(ZipDecompressor)
d.FileSizeLimit = 512
zipFilePath := filepath.Join(td, "input.zip")

err := d.Decompress(t.TempDir(), srcPath, true, 0644)
if err == nil {
t.FailNow()
}
if !strings.Contains(err.Error(), "zip archive larger than limit: 512") {
t.Fatalf("unexpected error: %q", err.Error())
err = ioutil.WriteFile(zipFilePath, buf.Bytes(), 0666)
if err != nil {
t.Fatalf("err: %s", err)
}

t.Run("error with limit", func(t *testing.T) {
d := new(ZipDecompressor)
d.FileSizeLimit = 7 // bytes

err = d.Decompress(t.TempDir(), zipFilePath, true, 0644)
if err == nil {
t.FailNow()
}
if !strings.Contains(err.Error(), "zip archive larger than limit: 7") {
t.Fatalf("unexpected error: %q", err.Error())
}
})

t.Run("no error without limit", func(t *testing.T) {
d := new(ZipDecompressor)

err = d.Decompress(t.TempDir(), zipFilePath, true, 0644)
if err != nil {
t.Fatalf("unexpected error: %v", err)
}
})
}
Binary file removed testdata/decompress-zip/bomb.zip
Binary file not shown.

0 comments on commit 79d9081

Please sign in to comment.