From 2fd6743614a94e3ba7b188da109efcbb7b436747 Mon Sep 17 00:00:00 2001 From: Ben Patterson Date: Mon, 22 Jul 2019 11:45:07 +0100 Subject: [PATCH] Use a temporary directory for export Fixes /~https://github.com/deislabs/duffle/issues/721 --- pkg/packager/export.go | 3 ++- pkg/packager/export_test.go | 13 +++++++------ 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/pkg/packager/export.go b/pkg/packager/export.go index 7c5a7a9d..7ac666bb 100644 --- a/pkg/packager/export.go +++ b/pkg/packager/export.go @@ -3,6 +3,7 @@ package packager import ( "fmt" "io" + "io/ioutil" "os" "path/filepath" "time" @@ -75,7 +76,7 @@ func (ex *Exporter) Export() error { return fmt.Errorf("Error loading bundle: %s", err) } name := bun.Name + "-" + bun.Version - archiveDir, err := filepath.Abs(name + "-export") + archiveDir, err := ioutil.TempDir("", name) if err != nil { return err } diff --git a/pkg/packager/export_test.go b/pkg/packager/export_test.go index 602f0c51..0766cb97 100644 --- a/pkg/packager/export_test.go +++ b/pkg/packager/export_test.go @@ -7,6 +7,7 @@ import ( "path/filepath" "reflect" "sort" + "strings" "testing" "github.com/deislabs/duffle/pkg/loader" @@ -52,10 +53,10 @@ func TestExport(t *testing.T) { t.Errorf("Expected no error, got error: %v", err) } - expectedConfigArchiveDirBase := "examplebun-0.1.0-export" + expectedPrefix := "examplebun-0.1.0" configArchiveDirBase := filepath.Base(configArchiveDir) - if configArchiveDirBase != expectedConfigArchiveDirBase { - t.Errorf("ImageStore.configure was passed an archive directory ending in %s; expected %s", configArchiveDirBase, expectedConfigArchiveDirBase) + if !strings.HasPrefix(configArchiveDirBase, expectedPrefix) { + t.Errorf("ImageStore.configure was passed an archive directory %s; expected prefix %s", configArchiveDirBase, expectedPrefix) } expectedImagesAdded := []string{"mock/examplebun:0.1.0", "mock/image-a:58326809e0p19b79054015bdd4e93e84b71ae1ta", "mock/image-b:88426103e0p19b38554015bd34e93e84b71de2fc"} @@ -107,10 +108,10 @@ func TestExportCreatesFileProperly(t *testing.T) { t.Error("Expected path does not exist error, got no error") } - expectedConfigArchiveDirBase := "examplebun-0.1.0-export" + expectedPrefix := "examplebun-0.1.0" configArchiveDirBase := filepath.Base(configArchiveDir) - if configArchiveDirBase != expectedConfigArchiveDirBase { - t.Errorf("ImageStore.configure was passed an archive directory ending in %s; expected %s", configArchiveDirBase, expectedConfigArchiveDirBase) + if !strings.HasPrefix(configArchiveDirBase, expectedPrefix) { + t.Errorf("ImageStore.configure was passed an archive directory %s; expected prefix %s", configArchiveDirBase, expectedPrefix) } expectedImagesAdded := []string{"mock/examplebun:0.1.0", "mock/image-a:58326809e0p19b79054015bdd4e93e84b71ae1ta", "mock/image-b:88426103e0p19b38554015bd34e93e84b71de2fc"}