Merge pull request #1067 from mitchellh/f-msgpack-rpc
core: Replace Gob RPC with MsgPack RPC
This commit is contained in:
commit
8edbcf95c4
|
@ -191,8 +191,17 @@ func decodeConfigHook(raws []interface{}) (mapstructure.DecodeHookFunc, error) {
|
|||
// First thing we do is decode PackerConfig so that we can have access
|
||||
// to the user variables so that we can process some templates.
|
||||
var pc PackerConfig
|
||||
|
||||
decoderConfig := &mapstructure.DecoderConfig{
|
||||
Result: &pc,
|
||||
WeaklyTypedInput: true,
|
||||
}
|
||||
decoder, err := mapstructure.NewDecoder(decoderConfig)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
for _, raw := range raws {
|
||||
if err := mapstructure.Decode(raw, &pc); err != nil {
|
||||
if err := decoder.Decode(raw); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
|
|
@ -33,7 +33,7 @@ const MagicCookieValue = "d602bf8f470bc67ca7faa0386276bbdd4330efaf76d1a219cb4d69
|
|||
// The APIVersion is outputted along with the RPC address. The plugin
|
||||
// client validates this API version and will show an error if it doesn't
|
||||
// know how to speak it.
|
||||
const APIVersion = "2"
|
||||
const APIVersion = "3"
|
||||
|
||||
// Server waits for a connection to this plugin and returns a Packer
|
||||
// RPC server that you can use to register components and serve them.
|
||||
|
|
|
@ -26,7 +26,7 @@ type BuilderPrepareArgs struct {
|
|||
|
||||
type BuilderPrepareResponse struct {
|
||||
Warnings []string
|
||||
Error error
|
||||
Error *BasicError
|
||||
}
|
||||
|
||||
func (b *builder) Prepare(config ...interface{}) ([]string, error) {
|
||||
|
@ -35,8 +35,12 @@ func (b *builder) Prepare(config ...interface{}) ([]string, error) {
|
|||
if cerr != nil {
|
||||
return nil, cerr
|
||||
}
|
||||
var err error = nil
|
||||
if resp.Error != nil {
|
||||
err = resp.Error
|
||||
}
|
||||
|
||||
return resp.Warnings, resp.Error
|
||||
return resp.Warnings, err
|
||||
}
|
||||
|
||||
func (b *builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packer.Artifact, error) {
|
||||
|
@ -72,13 +76,9 @@ func (b *builder) Cancel() {
|
|||
|
||||
func (b *BuilderServer) Prepare(args *BuilderPrepareArgs, reply *BuilderPrepareResponse) error {
|
||||
warnings, err := b.builder.Prepare(args.Configs...)
|
||||
if err != nil {
|
||||
err = NewBasicError(err)
|
||||
}
|
||||
|
||||
*reply = BuilderPrepareResponse{
|
||||
Warnings: warnings,
|
||||
Error: err,
|
||||
Error: NewBasicError(err),
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
|
|
@ -30,8 +30,9 @@ func TestBuilderPrepare(t *testing.T) {
|
|||
t.Fatal("should be called")
|
||||
}
|
||||
|
||||
if !reflect.DeepEqual(b.PrepareConfig, []interface{}{42}) {
|
||||
t.Fatalf("bad: %#v", b.PrepareConfig)
|
||||
expected := []interface{}{int64(42)}
|
||||
if !reflect.DeepEqual(b.PrepareConfig, expected) {
|
||||
t.Fatalf("bad: %#v != %#v", b.PrepareConfig, expected)
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -2,6 +2,7 @@ package rpc
|
|||
|
||||
import (
|
||||
"github.com/mitchellh/packer/packer"
|
||||
"github.com/ugorji/go/codec"
|
||||
"io"
|
||||
"log"
|
||||
"net/rpc"
|
||||
|
@ -32,9 +33,12 @@ func newClientWithMux(mux *MuxConn, streamId uint32) (*Client, error) {
|
|||
return nil, err
|
||||
}
|
||||
|
||||
var h codec.MsgpackHandle
|
||||
clientCodec := codec.GoRpc.ClientCodec(clientConn, &h)
|
||||
|
||||
return &Client{
|
||||
mux: mux,
|
||||
client: rpc.NewClient(clientConn),
|
||||
client: rpc.NewClientWithCodec(clientCodec),
|
||||
closeMux: false,
|
||||
}, nil
|
||||
}
|
||||
|
|
|
@ -9,6 +9,10 @@ type BasicError struct {
|
|||
}
|
||||
|
||||
func NewBasicError(err error) *BasicError {
|
||||
if err == nil {
|
||||
return nil
|
||||
}
|
||||
|
||||
return &BasicError{err.Error()}
|
||||
}
|
||||
|
||||
|
|
|
@ -54,7 +54,8 @@ func TestPostProcessorRPC(t *testing.T) {
|
|||
t.Fatal("config should be called")
|
||||
}
|
||||
|
||||
if !reflect.DeepEqual(p.configVal, []interface{}{42}) {
|
||||
expected := []interface{}{int64(42)}
|
||||
if !reflect.DeepEqual(p.configVal, expected) {
|
||||
t.Fatalf("unknown config value: %#v", p.configVal)
|
||||
}
|
||||
|
||||
|
|
|
@ -23,7 +23,8 @@ func TestProvisionerRPC(t *testing.T) {
|
|||
if !p.PrepCalled {
|
||||
t.Fatal("should be called")
|
||||
}
|
||||
if !reflect.DeepEqual(p.PrepConfigs, []interface{}{42}) {
|
||||
expected := []interface{}{int64(42)}
|
||||
if !reflect.DeepEqual(p.PrepConfigs, expected) {
|
||||
t.Fatalf("bad: %#v", p.PrepConfigs)
|
||||
}
|
||||
|
||||
|
|
|
@ -3,6 +3,7 @@ package rpc
|
|||
import (
|
||||
"fmt"
|
||||
"github.com/mitchellh/packer/packer"
|
||||
"github.com/ugorji/go/codec"
|
||||
"io"
|
||||
"log"
|
||||
"net/rpc"
|
||||
|
@ -145,7 +146,9 @@ func (s *Server) Serve() {
|
|||
return
|
||||
}
|
||||
|
||||
s.server.ServeConn(stream)
|
||||
var h codec.MsgpackHandle
|
||||
rpcCodec := codec.GoRpc.ServerCodec(stream, &h)
|
||||
s.server.ServeCodec(rpcCodec)
|
||||
}
|
||||
|
||||
// registerComponent registers a single Packer RPC component onto
|
||||
|
|
Loading…
Reference in New Issue