mirror of https://github.com/hashicorp/packer
Merge pull request #3940 from bhcleek/fix-fastpath
allow ssh communicator's Upload fastpath to executepull/4127/head
commit
f6c611da5b
@ -0,0 +1,33 @@
|
||||
package rpc
|
||||
|
||||
import (
|
||||
"os"
|
||||
"time"
|
||||
)
|
||||
|
||||
func NewFileInfo(fi os.FileInfo) *fileInfo {
|
||||
if fi == nil {
|
||||
return nil
|
||||
}
|
||||
|
||||
return &fileInfo{N: fi.Name(), S: fi.Size(), M: fi.Mode(), T: fi.ModTime()}
|
||||
}
|
||||
|
||||
type fileInfo struct {
|
||||
N string
|
||||
S int64
|
||||
M os.FileMode
|
||||
T time.Time
|
||||
}
|
||||
|
||||
func (fi fileInfo) Name() string { return fi.N }
|
||||
func (fi fileInfo) Size() int64 { return fi.S }
|
||||
func (fi fileInfo) Mode() os.FileMode { return fi.M }
|
||||
func (fi fileInfo) ModTime() time.Time {
|
||||
if fi.T.IsZero() {
|
||||
return time.Now()
|
||||
}
|
||||
return fi.T
|
||||
}
|
||||
func (fi fileInfo) IsDir() bool { return fi.M.IsDir() }
|
||||
func (fi fileInfo) Sys() interface{} { return nil }
|
||||
@ -0,0 +1,49 @@
|
||||
package rpc
|
||||
|
||||
import (
|
||||
"os"
|
||||
"testing"
|
||||
"time"
|
||||
)
|
||||
|
||||
type dummyFileInfo struct{}
|
||||
|
||||
func (fi dummyFileInfo) Name() string { return "dummy" }
|
||||
func (fi dummyFileInfo) Size() int64 { return 64 }
|
||||
func (fi dummyFileInfo) Mode() os.FileMode { return 0644 }
|
||||
func (fi dummyFileInfo) ModTime() time.Time {
|
||||
return time.Time{}.Add(1 * time.Minute)
|
||||
}
|
||||
func (fi dummyFileInfo) IsDir() bool { return false }
|
||||
func (fi dummyFileInfo) Sys() interface{} { return nil }
|
||||
func TestNewFileInfoNilPointer(t *testing.T) {
|
||||
fi := NewFileInfo(os.FileInfo(nil))
|
||||
if fi != nil {
|
||||
t.Fatalf("should be nil")
|
||||
}
|
||||
}
|
||||
|
||||
func TestNewFileInfoValues(t *testing.T) {
|
||||
in := dummyFileInfo{}
|
||||
fi := NewFileInfo(in)
|
||||
|
||||
if fi.Size() != in.Size() {
|
||||
t.Errorf("fi.Size() = %d; want %d", fi.Size(), in.Size())
|
||||
}
|
||||
|
||||
if fi.Name() != in.Name() {
|
||||
t.Errorf("fi.Name() = %s; want %s", fi.Name(), in.Name())
|
||||
}
|
||||
|
||||
if fi.Mode() != in.Mode() {
|
||||
t.Errorf("fi.Mode() = %#o; want %#o", fi.Mode(), in.Mode())
|
||||
}
|
||||
|
||||
if fi.ModTime() != in.ModTime() {
|
||||
t.Errorf("fi.ModTime() = %s; want %s", fi.ModTime(), in.ModTime())
|
||||
}
|
||||
|
||||
if fi.IsDir() != in.IsDir() {
|
||||
t.Errorf("fi.IsDir() = %t; want %t", fi.IsDir(), in.IsDir())
|
||||
}
|
||||
}
|
||||
Loading…
Reference in new issue