2014-05-29 00:07:47 +02:00
|
|
|
package rpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net"
|
|
|
|
"net/rpc"
|
|
|
|
"testing"
|
2014-09-28 19:49:27 +02:00
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/terraform"
|
2014-05-29 00:07:47 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func testConn(t *testing.T) (net.Conn, net.Conn) {
|
|
|
|
l, err := net.Listen("tcp", "127.0.0.1:0")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
var serverConn net.Conn
|
|
|
|
doneCh := make(chan struct{})
|
|
|
|
go func() {
|
|
|
|
defer close(doneCh)
|
|
|
|
defer l.Close()
|
|
|
|
var err error
|
|
|
|
serverConn, err = l.Accept()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
clientConn, err := net.Dial("tcp", l.Addr().String())
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
<-doneCh
|
|
|
|
|
|
|
|
return clientConn, serverConn
|
|
|
|
}
|
|
|
|
|
|
|
|
func testClientServer(t *testing.T) (*rpc.Client, *rpc.Server) {
|
|
|
|
clientConn, serverConn := testConn(t)
|
|
|
|
|
|
|
|
server := rpc.NewServer()
|
|
|
|
go server.ServeConn(serverConn)
|
|
|
|
|
|
|
|
client := rpc.NewClient(clientConn)
|
|
|
|
|
|
|
|
return client, server
|
|
|
|
}
|
2014-09-28 19:49:27 +02:00
|
|
|
|
|
|
|
func testProviderFixed(p terraform.ResourceProvider) ProviderFunc {
|
|
|
|
return func() terraform.ResourceProvider {
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
}
|
2014-09-28 19:55:12 +02:00
|
|
|
|
|
|
|
func testProvisionerFixed(p terraform.ResourceProvisioner) ProvisionerFunc {
|
|
|
|
return func() terraform.ResourceProvisioner {
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
}
|