Should return an error when the metadata file is not in the box tar archive

Split out box creation into new helper function
This commit is contained in:
DanHam 2019-08-21 10:47:08 +01:00
parent 063e4bd3e5
commit 0bf0e7c078
No known key found for this signature in database
GPG Key ID: 58E79AEDD6AA987E
1 changed files with 67 additions and 15 deletions

View File

@ -16,6 +16,10 @@ import (
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
) )
type tarFiles []struct {
Name, Body string
}
func testGoodConfig() map[string]interface{} { func testGoodConfig() map[string]interface{} {
return map[string]interface{}{ return map[string]interface{}{
"access_token": "foo", "access_token": "foo",
@ -249,25 +253,13 @@ func TestProviderFromVagrantBox_gzip_only_box(t *testing.T) {
} }
func TestProviderFromVagrantBox_no_files_in_archive(t *testing.T) { func TestProviderFromVagrantBox_no_files_in_archive(t *testing.T) {
boxfile, err := newBoxFile() // Bad: Box contains no files
boxfile, err := createBox(tarFiles{})
if err != nil { if err != nil {
t.Fatalf("%s", err) t.Fatalf("Error creating test box: %s", err)
} }
defer os.Remove(boxfile.Name()) defer os.Remove(boxfile.Name())
// Bad: box contains no files in the archive
aw := gzip.NewWriter(boxfile)
tw := tar.NewWriter(aw)
// Flush and close each writer creating an empty gzipped tar archive
err = tw.Close()
if err != nil {
t.Fatalf("Error flushing tar file contents: %s", err)
}
err = aw.Close()
if err != nil {
t.Fatalf("Error flushing gzip file contents: %s", err)
}
_, err = providerFromVagrantBox(boxfile.Name()) _, err = providerFromVagrantBox(boxfile.Name())
if err == nil { if err == nil {
t.Fatalf("Should have error as box file has no contents") t.Fatalf("Should have error as box file has no contents")
@ -275,6 +267,25 @@ func TestProviderFromVagrantBox_no_files_in_archive(t *testing.T) {
t.Logf("%s", err) t.Logf("%s", err)
} }
func TestProviderFromVagrantBox_no_metadata(t *testing.T) {
// Bad: Box contains no metadata/metadata.json file
files := tarFiles{
{"foo.txt", "This is a foo file"},
{"bar.txt", "This is a bar file"},
}
boxfile, err := createBox(files)
if err != nil {
t.Fatalf("Error creating test box: %s", err)
}
defer os.Remove(boxfile.Name())
_, err = providerFromVagrantBox(boxfile.Name())
if err == nil {
t.Fatalf("Should have error as box file does not include metadata.json file")
}
t.Logf("%s", err)
}
func newBoxFile() (boxfile *os.File, err error) { func newBoxFile() (boxfile *os.File, err error) {
boxfile, err = ioutil.TempFile(os.TempDir(), "test*.box") boxfile, err = ioutil.TempFile(os.TempDir(), "test*.box")
if err != nil { if err != nil {
@ -282,3 +293,44 @@ func newBoxFile() (boxfile *os.File, err error) {
} }
return boxfile, nil return boxfile, nil
} }
func createBox(files tarFiles) (boxfile *os.File, err error) {
boxfile, err = newBoxFile()
if err != nil {
return boxfile, err
}
// Box files are gzipped tar archives
aw := gzip.NewWriter(boxfile)
tw := tar.NewWriter(aw)
// Add each file to the box
for _, file := range files {
// Create and write the tar file header
hdr := &tar.Header{
Name: file.Name,
Mode: 0644,
Size: int64(len(file.Body)),
}
err = tw.WriteHeader(hdr)
if err != nil {
return boxfile, fmt.Errorf("Error writing box tar file header: %s", err)
}
// Write the file contents
_, err = tw.Write([]byte(file.Body))
if err != nil {
return boxfile, fmt.Errorf("Error writing box tar file contents: %s", err)
}
}
// Flush and close each writer
err = tw.Close()
if err != nil {
return boxfile, fmt.Errorf("Error flushing tar file contents: %s", err)
}
err = aw.Close()
if err != nil {
return boxfile, fmt.Errorf("Error flushing gzip file contents: %s", err)
}
return boxfile, nil
}