packer/plugin: Support PostProcessor
This commit is contained in:
parent
9b9af6dc9d
commit
51fe46e6d9
|
@ -143,13 +143,12 @@ func (c *Client) Hook() (packer.Hook, error) {
|
||||||
// Returns a post-processor implementation that is communicating over
|
// Returns a post-processor implementation that is communicating over
|
||||||
// this client. If the client hasn't been started, this will start it.
|
// this client. If the client hasn't been started, this will start it.
|
||||||
func (c *Client) PostProcessor() (packer.PostProcessor, error) {
|
func (c *Client) PostProcessor() (packer.PostProcessor, error) {
|
||||||
_, err := c.rpcClient()
|
client, err := c.rpcClient()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO
|
return &cmdPostProcessor{packrpc.PostProcessor(client), c}, nil
|
||||||
return nil, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns a provisioner implementation that is communicating over this
|
// Returns a provisioner implementation that is communicating over this
|
||||||
|
|
|
@ -137,6 +137,19 @@ func ServeHook(hook packer.Hook) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Serves a post-processor from a plugin.
|
||||||
|
func ServePostProcessor(p packer.PostProcessor) {
|
||||||
|
log.Println("Preparing to serve a post-processor plugin...")
|
||||||
|
|
||||||
|
server := rpc.NewServer()
|
||||||
|
packrpc.RegisterPostProcessor(server, p)
|
||||||
|
|
||||||
|
swallowInterrupts()
|
||||||
|
if err := serve(server); err != nil {
|
||||||
|
log.Panic(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Serves a provisioner from a plugin.
|
// Serves a provisioner from a plugin.
|
||||||
func ServeProvisioner(p packer.Provisioner) {
|
func ServeProvisioner(p packer.Provisioner) {
|
||||||
log.Println("Preparing to serve a provisioner plugin...")
|
log.Println("Preparing to serve a provisioner plugin...")
|
||||||
|
|
|
@ -59,6 +59,8 @@ func TestHelperProcess(*testing.T) {
|
||||||
case "mock":
|
case "mock":
|
||||||
fmt.Println(":1234")
|
fmt.Println(":1234")
|
||||||
<-make(chan int)
|
<-make(chan int)
|
||||||
|
case "post-processor":
|
||||||
|
ServePostProcessor(new(helperPostProcessor))
|
||||||
case "provisioner":
|
case "provisioner":
|
||||||
ServeProvisioner(new(helperProvisioner))
|
ServeProvisioner(new(helperProvisioner))
|
||||||
case "start-timeout":
|
case "start-timeout":
|
||||||
|
|
|
@ -0,0 +1,37 @@
|
||||||
|
package plugin
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/mitchellh/packer/packer"
|
||||||
|
"log"
|
||||||
|
)
|
||||||
|
|
||||||
|
type cmdPostProcessor struct {
|
||||||
|
p packer.PostProcessor
|
||||||
|
client *Client
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *cmdPostProcessor) Configure(config interface{}) error {
|
||||||
|
defer func() {
|
||||||
|
r := recover()
|
||||||
|
c.checkExit(r, nil)
|
||||||
|
}()
|
||||||
|
|
||||||
|
return c.p.Configure(config)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *cmdPostProcessor) PostProcess(a packer.Artifact) (packer.Artifact, error) {
|
||||||
|
defer func() {
|
||||||
|
r := recover()
|
||||||
|
c.checkExit(r, nil)
|
||||||
|
}()
|
||||||
|
|
||||||
|
return c.p.PostProcess(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *cmdPostProcessor) checkExit(p interface{}, cb func()) {
|
||||||
|
if c.client.Exited() {
|
||||||
|
cb()
|
||||||
|
} else if p != nil {
|
||||||
|
log.Panic(p)
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,37 @@
|
||||||
|
package plugin
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/mitchellh/packer/packer"
|
||||||
|
"os/exec"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
type helperPostProcessor byte
|
||||||
|
|
||||||
|
func (helperPostProcessor) Configure(interface{}) error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (helperPostProcessor) PostProcess(packer.Artifact) (packer.Artifact, error) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPostProcessor_NoExist(t *testing.T) {
|
||||||
|
c := NewClient(&ClientConfig{Cmd: exec.Command("i-should-not-exist")})
|
||||||
|
defer c.Kill()
|
||||||
|
|
||||||
|
_, err := c.PostProcessor()
|
||||||
|
if err == nil {
|
||||||
|
t.Fatal("should have error")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPostProcessor_Good(t *testing.T) {
|
||||||
|
c := NewClient(&ClientConfig{Cmd: helperProcess("post-processor")})
|
||||||
|
defer c.Kill()
|
||||||
|
|
||||||
|
_, err := c.PostProcessor()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("should not have error: %s", err)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue