Commit b26ff7a6 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

communicator/ssh: More logging

parent 9ebf0435
...@@ -75,6 +75,7 @@ func (c *comm) Start(cmd string) (remote *packer.RemoteCommand, err error) { ...@@ -75,6 +75,7 @@ func (c *comm) Start(cmd string) (remote *packer.RemoteCommand, err error) {
} }
func (c *comm) Upload(path string, input io.Reader) error { func (c *comm) Upload(path string, input io.Reader) error {
log.Println("Opening new SSH session")
session, err := c.client.NewSession() session, err := c.client.NewSession()
if err != nil { if err != nil {
return err return err
...@@ -123,6 +124,7 @@ func (c *comm) Upload(path string, input io.Reader) error { ...@@ -123,6 +124,7 @@ func (c *comm) Upload(path string, input io.Reader) error {
} }
// Start the protocol // Start the protocol
log.Println("Beginning file upload...")
fmt.Fprintln(w, "C0644", input_memory.Len(), target_file) fmt.Fprintln(w, "C0644", input_memory.Len(), target_file)
io.Copy(w, input_memory) io.Copy(w, input_memory)
fmt.Fprint(w, "\x00") fmt.Fprint(w, "\x00")
...@@ -133,11 +135,13 @@ func (c *comm) Upload(path string, input io.Reader) error { ...@@ -133,11 +135,13 @@ func (c *comm) Upload(path string, input io.Reader) error {
// Close the stdin, which sends an EOF, and then set w to nil so that // Close the stdin, which sends an EOF, and then set w to nil so that
// our defer func doesn't close it again since that is unsafe with // our defer func doesn't close it again since that is unsafe with
// the Go SSH package. // the Go SSH package.
log.Println("Upload complete, closing stdin pipe")
w.Close() w.Close()
w = nil w = nil
// Wait for the SCP connection to close, meaning it has consumed all // Wait for the SCP connection to close, meaning it has consumed all
// our data and has completed. Or has errored. // our data and has completed. Or has errored.
log.Println("Waiting for SSH session to complete")
err = session.Wait() err = session.Wait()
if err != nil { if err != nil {
if exitErr, ok := err.(*ssh.ExitError); ok { if exitErr, ok := err.(*ssh.ExitError); ok {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment