mirror of
https://github.com/opentffoundation/opentf.git
synced 2026-01-16 11:01:09 -05:00
This changeset performs the following: - Updates `masterzen/winrm` vendor to include change from (https://github.com/masterzen/winrm/pull/73) - Updates `dylanmei/winrmtest` vendor to include change from (https://github.com/dylanmei/winrmtest/pull/4) - Updates `packer-community/winrmcp` vendor to include the removal of the `masterzen/winrm/winrm` sub-class as a result of the `winrm` CLI tool being removed from the `masterzen/winrm` repository. - Changes `communicator/winrm/communicator.go` to conform to the new ABI in the `masterzen/winrm` library. This should completely remove any LGPL licensed dependencies inside of the Terraform project. ``` $ make test ==> Checking that code complies with gofmt requirements... go generate $(go list ./... | grep -v /terraform/vendor/) 2017/08/20 13:40:16 Generated command/internal_plugin_list.go go test -i $(go list ./... | grep -v '/terraform/vendor/' | grep -v '/builtin/bins/') || exit 1 echo $(go list ./... | grep -v '/terraform/vendor/' | grep -v '/builtin/bins/') | \ xargs -t -n4 go test -timeout=60s -parallel=4 go test -timeout=60s -parallel=4 github.com/hashicorp/terraform github.com/hashicorp/terraform/backend github.com/hashicorp/terraform/backend/atlas github.com/hashicorp/terraform/backend/init ok github.com/hashicorp/terraform 0.011s ok github.com/hashicorp/terraform/backend 0.020s ok github.com/hashicorp/terraform/backend/atlas 0.634s ok github.com/hashicorp/terraform/backend/init 0.007s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/backend/legacy github.com/hashicorp/terraform/backend/local github.com/hashicorp/terraform/backend/remote-state github.com/hashicorp/terraf orm/backend/remote-state/azure ok github.com/hashicorp/terraform/backend/legacy 0.009s ok github.com/hashicorp/terraform/backend/local 0.211s ok github.com/hashicorp/terraform/backend/remote-state 0.006s ok github.com/hashicorp/terraform/backend/remote-state/azure 0.010s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/backend/remote-state/consul github.com/hashicorp/terraform/backend/remote-state/inmem github.com/hashicorp/terraform/backend/remote-state/s 3 github.com/hashicorp/terraform/backend/remote-state/swift ok github.com/hashicorp/terraform/backend/remote-state/consul 0.007s ok github.com/hashicorp/terraform/backend/remote-state/inmem 0.013s ok github.com/hashicorp/terraform/backend/remote-state/s3 0.007s ok github.com/hashicorp/terraform/backend/remote-state/swift 0.013s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/builtin/providers/test github.com/hashicorp/terraform/builtin/provisioners/chef github.com/hashicorp/terraform/builtin/provisioners/file gi thub.com/hashicorp/terraform/builtin/provisioners/local-exec ok github.com/hashicorp/terraform/builtin/providers/test 1.544s ok github.com/hashicorp/terraform/builtin/provisioners/chef 0.017s ok github.com/hashicorp/terraform/builtin/provisioners/file 0.006s ok github.com/hashicorp/terraform/builtin/provisioners/local-exec 0.078s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/builtin/provisioners/remote-exec github.com/hashicorp/terraform/builtin/provisioners/salt-masterless github.com/hashicorp/terraform/command github.com/hashicorp/terraform/command/clistate ok github.com/hashicorp/terraform/builtin/provisioners/remote-exec 1.037s ok github.com/hashicorp/terraform/builtin/provisioners/salt-masterless 0.008s ok github.com/hashicorp/terraform/command 14.589s ? github.com/hashicorp/terraform/command/clistate [no test files] go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/command/e2etest github.com/hashicorp/terraform/command/format github.com/hashicorp/terraform/communicator github.com/hashicorp/terraform/co mmunicator/remote ok github.com/hashicorp/terraform/command/e2etest 3.729s ok github.com/hashicorp/terraform/command/format 0.004s ok github.com/hashicorp/terraform/communicator 0.005s ok github.com/hashicorp/terraform/communicator/remote 0.003s [no tests to run] go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/communicator/shared github.com/hashicorp/terraform/communicator/ssh github.com/hashicorp/terraform/communicator/winrm github.com/hashicorp/ terraform/config ok github.com/hashicorp/terraform/communicator/shared 0.007s ok github.com/hashicorp/terraform/communicator/ssh 0.016s ok github.com/hashicorp/terraform/communicator/winrm 0.018s ok github.com/hashicorp/terraform/config 0.213s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/config/module github.com/hashicorp/terraform/dag github.com/hashicorp/terraform/digraph github.com/hashicorp/terraform/flatmap ok github.com/hashicorp/terraform/config/module 0.044s ok github.com/hashicorp/terraform/dag 0.010s ok github.com/hashicorp/terraform/digraph 0.002s ok github.com/hashicorp/terraform/flatmap 0.002s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/acctest github.com/hashicorp/terraform/helper/config github.com/hashicorp/terraform/helper/copy github.com/hashicorp/terraform/helpe r/diff ? github.com/hashicorp/terraform/helper/acctest [no test files] ok github.com/hashicorp/terraform/helper/config 0.005s ? github.com/hashicorp/terraform/helper/copy [no test files] ok github.com/hashicorp/terraform/helper/diff 0.005s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/encryption github.com/hashicorp/terraform/helper/experiment github.com/hashicorp/terraform/helper/hashcode github.com/hashicorp/terr aform/helper/hilmapstructure ? github.com/hashicorp/terraform/helper/encryption [no test files] ok github.com/hashicorp/terraform/helper/experiment 0.001s ok github.com/hashicorp/terraform/helper/hashcode 0.001s ? github.com/hashicorp/terraform/helper/hilmapstructure [no test files] go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/logging github.com/hashicorp/terraform/helper/mutexkv github.com/hashicorp/terraform/helper/pathorcontents github.com/hashicorp/terr aform/helper/resource ? github.com/hashicorp/terraform/helper/logging [no test files] ok github.com/hashicorp/terraform/helper/mutexkv 0.055s ok github.com/hashicorp/terraform/helper/pathorcontents 0.002s ok github.com/hashicorp/terraform/helper/resource 2.659s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/schema github.com/hashicorp/terraform/helper/shadow github.com/hashicorp/terraform/helper/signalwrapper github.com/hashicorp/terrafo rm/helper/slowmessage ok github.com/hashicorp/terraform/helper/schema 0.063s ok github.com/hashicorp/terraform/helper/shadow 0.156s ok github.com/hashicorp/terraform/helper/signalwrapper 0.022s ok github.com/hashicorp/terraform/helper/slowmessage 0.102s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/structure github.com/hashicorp/terraform/helper/validation github.com/hashicorp/terraform/helper/variables github.com/hashicorp/terr aform/helper/wrappedreadline ok github.com/hashicorp/terraform/helper/structure 0.004s ok github.com/hashicorp/terraform/helper/validation 0.004s ok github.com/hashicorp/terraform/helper/variables 0.006s ? github.com/hashicorp/terraform/helper/wrappedreadline [no test files] go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/helper/wrappedstreams github.com/hashicorp/terraform/moduledeps github.com/hashicorp/terraform/plugin github.com/hashicorp/terraform/plugin /discovery ? github.com/hashicorp/terraform/helper/wrappedstreams [no test files] ok github.com/hashicorp/terraform/moduledeps 0.004s ok github.com/hashicorp/terraform/plugin 0.046s ok github.com/hashicorp/terraform/plugin/discovery 0.029s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/repl github.com/hashicorp/terraform/scripts github.com/hashicorp/terraform/state github.com/hashicorp/terraform/state/remote ok github.com/hashicorp/terraform/repl 0.006s ok github.com/hashicorp/terraform/scripts 0.008s ok github.com/hashicorp/terraform/state 2.617s ok github.com/hashicorp/terraform/state/remote 0.025s go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/terraform github.com/hashicorp/terraform/tools/terraform-bundle go test -timeout=60s -parallel=4 github.com/hashicorp/terraform/terraform github.com/hashicorp/terraform/tools/terraform-bundle ok github.com/hashicorp/terraform/terraform 4.222s ? github.com/hashicorp/terraform/tools/terraform-bundle [no test files] ```
240 lines
4.7 KiB
Go
240 lines
4.7 KiB
Go
package winrm
|
|
|
|
import (
|
|
"bytes"
|
|
"errors"
|
|
"io"
|
|
"strings"
|
|
)
|
|
|
|
type commandWriter struct {
|
|
*Command
|
|
eof bool
|
|
}
|
|
|
|
type commandReader struct {
|
|
*Command
|
|
write *io.PipeWriter
|
|
read *io.PipeReader
|
|
stream string
|
|
}
|
|
|
|
// Command represents a given command running on a Shell. This structure allows to get access
|
|
// to the various stdout, stderr and stdin pipes.
|
|
type Command struct {
|
|
client *Client
|
|
shell *Shell
|
|
id string
|
|
exitCode int
|
|
finished bool
|
|
err error
|
|
|
|
Stdin *commandWriter
|
|
Stdout *commandReader
|
|
Stderr *commandReader
|
|
|
|
done chan struct{}
|
|
cancel chan struct{}
|
|
}
|
|
|
|
func newCommand(shell *Shell, ids string) *Command {
|
|
command := &Command{
|
|
shell: shell,
|
|
client: shell.client,
|
|
id: ids,
|
|
exitCode: 0,
|
|
err: nil,
|
|
done: make(chan struct{}),
|
|
cancel: make(chan struct{}),
|
|
}
|
|
|
|
command.Stdout = newCommandReader("stdout", command)
|
|
command.Stdin = &commandWriter{
|
|
Command: command,
|
|
eof: false,
|
|
}
|
|
command.Stderr = newCommandReader("stderr", command)
|
|
|
|
go fetchOutput(command)
|
|
|
|
return command
|
|
}
|
|
|
|
func newCommandReader(stream string, command *Command) *commandReader {
|
|
read, write := io.Pipe()
|
|
return &commandReader{
|
|
Command: command,
|
|
stream: stream,
|
|
write: write,
|
|
read: read,
|
|
}
|
|
}
|
|
|
|
func fetchOutput(command *Command) {
|
|
for {
|
|
select {
|
|
case <-command.cancel:
|
|
close(command.done)
|
|
return
|
|
default:
|
|
finished, err := command.slurpAllOutput()
|
|
if finished {
|
|
command.err = err
|
|
close(command.done)
|
|
return
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func (c *Command) check() error {
|
|
if c.id == "" {
|
|
return errors.New("Command has already been closed")
|
|
}
|
|
if c.shell == nil {
|
|
return errors.New("Command has no associated shell")
|
|
}
|
|
if c.client == nil {
|
|
return errors.New("Command has no associated client")
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Close will terminate the running command
|
|
func (c *Command) Close() error {
|
|
if err := c.check(); err != nil {
|
|
return err
|
|
}
|
|
|
|
select { // close cancel channel if it's still open
|
|
case <-c.cancel:
|
|
default:
|
|
close(c.cancel)
|
|
}
|
|
|
|
request := NewSignalRequest(c.client.url, c.shell.id, c.id, &c.client.Parameters)
|
|
defer request.Free()
|
|
|
|
_, err := c.client.sendRequest(request)
|
|
return err
|
|
}
|
|
|
|
func (c *Command) slurpAllOutput() (bool, error) {
|
|
if err := c.check(); err != nil {
|
|
c.Stderr.write.CloseWithError(err)
|
|
c.Stdout.write.CloseWithError(err)
|
|
return true, err
|
|
}
|
|
|
|
request := NewGetOutputRequest(c.client.url, c.shell.id, c.id, "stdout stderr", &c.client.Parameters)
|
|
defer request.Free()
|
|
|
|
response, err := c.client.sendRequest(request)
|
|
if err != nil {
|
|
if strings.Contains(err.Error(), "OperationTimeout") {
|
|
// Operation timeout because there was no command output
|
|
return false, err
|
|
}
|
|
if strings.Contains(err.Error(), "EOF") {
|
|
c.exitCode = 16001
|
|
}
|
|
|
|
c.Stderr.write.CloseWithError(err)
|
|
c.Stdout.write.CloseWithError(err)
|
|
return true, err
|
|
}
|
|
|
|
var exitCode int
|
|
var stdout, stderr bytes.Buffer
|
|
finished, exitCode, err := ParseSlurpOutputErrResponse(response, &stdout, &stderr)
|
|
if err != nil {
|
|
c.Stderr.write.CloseWithError(err)
|
|
c.Stdout.write.CloseWithError(err)
|
|
return true, err
|
|
}
|
|
if stdout.Len() > 0 {
|
|
c.Stdout.write.Write(stdout.Bytes())
|
|
}
|
|
if stderr.Len() > 0 {
|
|
c.Stderr.write.Write(stderr.Bytes())
|
|
}
|
|
if finished {
|
|
c.exitCode = exitCode
|
|
c.Stderr.write.Close()
|
|
c.Stdout.write.Close()
|
|
}
|
|
|
|
return finished, nil
|
|
}
|
|
|
|
func (c *Command) sendInput(data []byte) error {
|
|
if err := c.check(); err != nil {
|
|
return err
|
|
}
|
|
|
|
request := NewSendInputRequest(c.client.url, c.shell.id, c.id, data, &c.client.Parameters)
|
|
defer request.Free()
|
|
|
|
_, err := c.client.sendRequest(request)
|
|
return err
|
|
}
|
|
|
|
// ExitCode returns command exit code when it is finished. Before that the result is always 0.
|
|
func (c *Command) ExitCode() int {
|
|
return c.exitCode
|
|
}
|
|
|
|
// Wait function will block the current goroutine until the remote command terminates.
|
|
func (c *Command) Wait() {
|
|
// block until finished
|
|
<-c.done
|
|
}
|
|
|
|
// Write data to this Pipe
|
|
// commandWriter implements io.Writer interface
|
|
func (w *commandWriter) Write(data []byte) (int, error) {
|
|
|
|
var (
|
|
written int
|
|
err error
|
|
)
|
|
|
|
for len(data) > 0 {
|
|
if w.eof {
|
|
return written, io.EOF
|
|
}
|
|
// never send more data than our EnvelopeSize.
|
|
n := min(w.client.Parameters.EnvelopeSize-1000, len(data))
|
|
if err := w.sendInput(data[:n]); err != nil {
|
|
break
|
|
}
|
|
data = data[n:]
|
|
written += n
|
|
}
|
|
|
|
return written, err
|
|
}
|
|
|
|
func min(a int, b int) int {
|
|
if a < b {
|
|
return a
|
|
}
|
|
return b
|
|
}
|
|
|
|
// Close method wrapper
|
|
// commandWriter implements io.Closer interface
|
|
func (w *commandWriter) Close() error {
|
|
w.eof = true
|
|
return w.Close()
|
|
}
|
|
|
|
// Read data from this Pipe
|
|
func (r *commandReader) Read(buf []byte) (int, error) {
|
|
n, err := r.read.Read(buf)
|
|
if err != nil && err != io.EOF {
|
|
return 0, err
|
|
}
|
|
return n, err
|
|
}
|