2020-09-04 17:53:09 -04:00
|
|
|
package proxmoxiso
|
2020-01-04 16:50:35 -05:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/packer/packer"
|
2020-11-17 19:31:03 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep"
|
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep/commonsteps"
|
2020-01-04 16:50:35 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
type uploaderMock struct {
|
|
|
|
fail bool
|
|
|
|
wasCalled bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *uploaderMock) Upload(node string, storage string, contentType string, filename string, file io.Reader) error {
|
|
|
|
m.wasCalled = true
|
|
|
|
if m.fail {
|
|
|
|
return fmt.Errorf("Testing induced failure")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ uploader = &uploaderMock{}
|
|
|
|
|
|
|
|
func TestUploadISO(t *testing.T) {
|
|
|
|
cs := []struct {
|
|
|
|
name string
|
|
|
|
builderConfig *Config
|
|
|
|
downloadPath string
|
|
|
|
failUpload bool
|
|
|
|
|
|
|
|
expectError bool
|
|
|
|
expectUploadCalled bool
|
|
|
|
expectedISOPath string
|
|
|
|
expectedAction multistep.StepAction
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "should not call upload unless configured to do so",
|
|
|
|
builderConfig: &Config{shouldUploadISO: false, ISOFile: "local:iso/some-file"},
|
|
|
|
|
|
|
|
expectUploadCalled: false,
|
|
|
|
expectedISOPath: "local:iso/some-file",
|
|
|
|
expectedAction: multistep.ActionContinue,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "success should continue",
|
|
|
|
builderConfig: &Config{
|
|
|
|
shouldUploadISO: true,
|
|
|
|
ISOStoragePool: "local",
|
2020-11-11 18:04:28 -05:00
|
|
|
ISOConfig: commonsteps.ISOConfig{ISOUrls: []string{"http://server.example/some-file.iso"}},
|
2020-01-04 16:50:35 -05:00
|
|
|
},
|
|
|
|
downloadPath: "testdata/test.iso",
|
|
|
|
|
|
|
|
expectedISOPath: "local:iso/some-file.iso",
|
|
|
|
expectUploadCalled: true,
|
|
|
|
expectedAction: multistep.ActionContinue,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "failing upload should halt",
|
|
|
|
builderConfig: &Config{
|
|
|
|
shouldUploadISO: true,
|
|
|
|
ISOStoragePool: "local",
|
2020-11-11 18:04:28 -05:00
|
|
|
ISOConfig: commonsteps.ISOConfig{ISOUrls: []string{"http://server.example/some-file.iso"}},
|
2020-01-04 16:50:35 -05:00
|
|
|
},
|
|
|
|
downloadPath: "testdata/test.iso",
|
|
|
|
failUpload: true,
|
|
|
|
|
|
|
|
expectError: true,
|
|
|
|
expectUploadCalled: true,
|
|
|
|
expectedAction: multistep.ActionHalt,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "downloader: state misconfiguration should halt",
|
|
|
|
builderConfig: &Config{
|
|
|
|
shouldUploadISO: true,
|
|
|
|
ISOStoragePool: "local",
|
2020-11-11 18:04:28 -05:00
|
|
|
ISOConfig: commonsteps.ISOConfig{ISOUrls: []string{"http://server.example/some-file.iso"}},
|
2020-01-04 16:50:35 -05:00
|
|
|
},
|
|
|
|
|
|
|
|
expectError: true,
|
|
|
|
expectUploadCalled: false,
|
|
|
|
expectedAction: multistep.ActionHalt,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "downloader: file unreadable should halt",
|
|
|
|
builderConfig: &Config{
|
|
|
|
shouldUploadISO: true,
|
|
|
|
ISOStoragePool: "local",
|
2020-11-11 18:04:28 -05:00
|
|
|
ISOConfig: commonsteps.ISOConfig{ISOUrls: []string{"http://server.example/some-file.iso"}},
|
2020-01-04 16:50:35 -05:00
|
|
|
},
|
|
|
|
downloadPath: "testdata/non-existent.iso",
|
|
|
|
|
|
|
|
expectError: true,
|
|
|
|
expectUploadCalled: false,
|
|
|
|
expectedAction: multistep.ActionHalt,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, c := range cs {
|
|
|
|
t.Run(c.name, func(t *testing.T) {
|
|
|
|
m := &uploaderMock{fail: c.failUpload}
|
|
|
|
|
|
|
|
state := new(multistep.BasicStateBag)
|
|
|
|
state.Put("ui", packer.TestUi(t))
|
2020-09-04 17:53:09 -04:00
|
|
|
state.Put("iso-config", c.builderConfig)
|
2020-01-04 16:50:35 -05:00
|
|
|
state.Put(downloadPathKey, c.downloadPath)
|
|
|
|
state.Put("proxmoxClient", m)
|
|
|
|
|
|
|
|
step := stepUploadISO{}
|
|
|
|
action := step.Run(context.TODO(), state)
|
|
|
|
step.Cleanup(state)
|
|
|
|
|
|
|
|
if action != c.expectedAction {
|
|
|
|
t.Errorf("Expected action to be %v, got %v", c.expectedAction, action)
|
|
|
|
}
|
|
|
|
if m.wasCalled != c.expectUploadCalled {
|
|
|
|
t.Errorf("Expected mock to be called: %v, got: %v", c.expectUploadCalled, m.wasCalled)
|
|
|
|
}
|
|
|
|
err, gotError := state.GetOk("error")
|
|
|
|
if gotError != c.expectError {
|
|
|
|
t.Errorf("Expected error state to be: %v, got: %v", c.expectError, gotError)
|
|
|
|
}
|
|
|
|
if err == nil {
|
|
|
|
if isoPath := state.Get("iso_file"); isoPath != c.expectedISOPath {
|
|
|
|
if _, ok := isoPath.(string); !ok {
|
|
|
|
isoPath = ""
|
|
|
|
}
|
|
|
|
t.Errorf("Expected state iso_path to be %q, got %q", c.expectedISOPath, isoPath)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|