builder/vmware: new artifact type that is common

This commit is contained in:
Mitchell Hashimoto 2013-12-25 11:27:53 -07:00
parent 6f449abf2e
commit bee879409a
5 changed files with 112 additions and 6 deletions

View File

@ -0,0 +1,61 @@
package common
import (
"fmt"
"os"
"path/filepath"
"github.com/mitchellh/packer/packer"
)
// BuilderId for the local artifacts
const BuilderId = "mitchellh.vmware"
// Artifact is the result of running the VMware builder, namely a set
// of files associated with the resulting machine.
type localArtifact struct {
dir string
f []string
}
// NewLocalArtifact returns a VMware artifact containing the files
// in the given directory.
func NewLocalArtifact(dir string) (packer.Artifact, error) {
files := make([]string, 0, 5)
visit := func(path string, info os.FileInfo, err error) error {
if !info.IsDir() {
files = append(files, path)
}
return err
}
if err := filepath.Walk(dir, visit); err != nil {
return nil, err
}
return &localArtifact{
dir: dir,
f: files,
}, nil
}
func (a *localArtifact) BuilderId() string {
return BuilderId
}
func (a *localArtifact) Files() []string {
return a.f
}
func (*localArtifact) Id() string {
return "VM"
}
func (a *localArtifact) String() string {
return fmt.Sprintf("VM files in directory: %s", a.dir)
}
func (a *localArtifact) Destroy() error {
return os.RemoveAll(a.dir)
}

View File

@ -0,0 +1,43 @@
package common
import (
"io/ioutil"
"os"
"path/filepath"
"testing"
"github.com/mitchellh/packer/packer"
)
func TestLocalArtifact_impl(t *testing.T) {
var _ packer.Artifact = new(localArtifact)
}
func TestNewLocalArtifact(t *testing.T) {
td, err := ioutil.TempDir("", "packer")
if err != nil {
t.Fatalf("err: %s", err)
}
defer os.RemoveAll(td)
err = ioutil.WriteFile(filepath.Join(td, "a"), []byte("foo"), 0644)
if err != nil {
t.Fatalf("err: %s", err)
}
if err := os.Mkdir(filepath.Join(td, "b"), 0755); err != nil {
t.Fatalf("err: %s", err)
}
a, err := NewLocalArtifact(td)
if err != nil {
t.Fatalf("err: %s", err)
}
if a.BuilderId() != BuilderId {
t.Fatalf("bad: %#v", a.BuilderId())
}
if len(a.Files()) != 1 {
t.Fatalf("should length 1: %d", len(a.Files()))
}
}

View File

@ -2,14 +2,13 @@ package iso
import ( import (
"fmt" "fmt"
"os"
) )
// Artifact is the result of running the VMware builder, namely a set // Artifact is the result of running the VMware builder, namely a set
// of files associated with the resulting machine. // of files associated with the resulting machine.
type Artifact struct { type Artifact struct {
builderId string builderId string
dir string dir OutputDir
f []string f []string
} }
@ -30,5 +29,5 @@ func (a *Artifact) String() string {
} }
func (a *Artifact) Destroy() error { func (a *Artifact) Destroy() error {
return os.RemoveAll(a.dir) return a.dir.RemoveAll()
} }

View File

@ -16,7 +16,6 @@ import (
"time" "time"
) )
const BuilderId = "mitchellh.vmware"
const BuilderIdESX = "mitchellh.vmware-esx" const BuilderIdESX = "mitchellh.vmware-esx"
type Builder struct { type Builder struct {
@ -454,14 +453,14 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
} }
// Set the proper builder ID // Set the proper builder ID
builderId := BuilderId builderId := vmwcommon.BuilderId
if b.config.RemoteType != "" { if b.config.RemoteType != "" {
builderId = BuilderIdESX builderId = BuilderIdESX
} }
return &Artifact{ return &Artifact{
builderId: builderId, builderId: builderId,
dir: b.config.OutputDir, dir: dir,
f: files, f: files,
}, nil }, nil
} }

View File

@ -60,3 +60,7 @@ func (d *localOutputDir) RemoveAll() error {
func (d *localOutputDir) SetOutputDir(path string) { func (d *localOutputDir) SetOutputDir(path string) {
d.dir = path d.dir = path
} }
func (d *localOutputDir) String() string {
return d.dir
}