Add test that verifies disksize bug (1/2)

This commit is contained in:
Paul Meyer 2019-10-04 17:14:10 +00:00
parent eb5dc9326d
commit 98175c06d5
3 changed files with 123 additions and 46 deletions

View File

@ -19,7 +19,7 @@ const (
// Tests assume current machine is capable of running chroot builder (i.e. an Azure VM) // Tests assume current machine is capable of running chroot builder (i.e. an Azure VM)
func Test_DiskAttacherAttachesDiskToVM(t *testing.T) { func Test_DiskAttacherAttachesDiskToVM(t *testing.T) {
azcli, err := client.GetTestClientSet(t) azcli, err := client.GetTestClientSet(t) // integration test
require.Nil(t, err) require.Nil(t, err)
da := NewDiskAttacher(azcli) da := NewDiskAttacher(azcli)
testDiskName := t.Name() testDiskName := t.Name()

View File

@ -49,7 +49,6 @@ func (s StepCreateNewDisk) Run(ctx context.Context, state multistep.StateBag) mu
OsType: "Linux", OsType: "Linux",
HyperVGeneration: compute.HyperVGeneration(s.HyperVGeneration), HyperVGeneration: compute.HyperVGeneration(s.HyperVGeneration),
CreationData: &compute.CreationData{}, CreationData: &compute.CreationData{},
DiskSizeGB: to.Int32Ptr(s.DiskSizeGB),
}, },
//Tags: map[string]*string{ //Tags: map[string]*string{
} }

View File

@ -4,6 +4,7 @@ import (
"context" "context"
"io/ioutil" "io/ioutil"
"net/http" "net/http"
"reflect"
"regexp" "regexp"
"testing" "testing"
@ -14,56 +15,133 @@ import (
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
) )
func Test_StepCreateNewDisk_FromDisk(t *testing.T) { func TestStepCreateNewDisk_Run(t *testing.T) {
sut := StepCreateNewDisk{ type fields struct {
SubscriptionID: "SubscriptionID", SubscriptionID string
ResourceGroup: "ResourceGroupName", ResourceGroup string
DiskName: "TemporaryOSDiskName", DiskName string
DiskSizeGB: 42, DiskSizeGB int32
DiskStorageAccountType: string(compute.PremiumLRS), DiskStorageAccountType string
HyperVGeneration: string(compute.V1), HyperVGeneration string
Location: "westus", Location string
SourceDiskResourceID: "SourceDisk", PlatformImage *client.PlatformImage
} SourceDiskResourceID string
expected := regexp.MustCompile(`[\s\n]`).ReplaceAllString(` expectedPutDiskBody string
{ }
"location": "westus", tests := []struct {
"properties": { name string
"osType": "Linux", fields fields
"hyperVGeneration": "V1", want multistep.StepAction
"creationData": { }{
"createOption": "Copy", {
"sourceResourceId": "SourceDisk" name: "HappyPathDiskSource",
fields: fields{
SubscriptionID: "SubscriptionID",
ResourceGroup: "ResourceGroupName",
DiskName: "TemporaryOSDiskName",
DiskSizeGB: 42,
DiskStorageAccountType: string(compute.PremiumLRS),
HyperVGeneration: string(compute.V1),
Location: "westus",
SourceDiskResourceID: "SourceDisk",
expectedPutDiskBody: `
{
"location": "westus",
"properties": {
"osType": "Linux",
"hyperVGeneration": "V1",
"creationData": {
"createOption": "Copy",
"sourceResourceId": "SourceDisk"
},
"diskSizeGB": 42
},
"sku": {
"name": "Premium_LRS"
}
}`,
},
want: multistep.ActionContinue,
},
{
name: "HappyPathDiskSource",
fields: fields{
SubscriptionID: "SubscriptionID",
ResourceGroup: "ResourceGroupName",
DiskName: "TemporaryOSDiskName",
DiskStorageAccountType: string(compute.StandardLRS),
HyperVGeneration: string(compute.V1),
Location: "westus",
PlatformImage: &client.PlatformImage{
Publisher: "Microsoft",
Offer: "Windows",
Sku: "2016-DataCenter",
Version: "2016.1.4",
},
expectedPutDiskBody: `
{
"location": "westus",
"properties": {
"osType": "Linux",
"hyperVGeneration": "V1",
"creationData": {
"createOption":"FromImage",
"imageReference": {
"id":"/subscriptions/SubscriptionID/providers/Microsoft.Compute/locations/westus/publishers/Microsoft/artifacttypes/vmimage/offers/Windows/skus/2016-DataCenter/versions/2016.1.4"
}
}
},
"sku": {
"name": "Standard_LRS"
}
}`,
},
want: multistep.ActionContinue,
}, },
"diskSizeGB": 42
},
"sku": {
"name": "Premium_LRS"
} }
}`, "") for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
s := StepCreateNewDisk{
SubscriptionID: tt.fields.SubscriptionID,
ResourceGroup: tt.fields.ResourceGroup,
DiskName: tt.fields.DiskName,
DiskSizeGB: tt.fields.DiskSizeGB,
DiskStorageAccountType: tt.fields.DiskStorageAccountType,
HyperVGeneration: tt.fields.HyperVGeneration,
Location: tt.fields.Location,
PlatformImage: tt.fields.PlatformImage,
SourceDiskResourceID: tt.fields.SourceDiskResourceID,
}
m := compute.NewDisksClient("subscriptionId") expectedPutDiskBody := regexp.MustCompile(`[\s\n]`).ReplaceAllString(tt.fields.expectedPutDiskBody, "")
m.Sender = autorest.SenderFunc(func(r *http.Request) (*http.Response, error) {
b, _ := ioutil.ReadAll(r.Body)
if string(b) != expected {
t.Fatalf("expected body to be %q, but got %q", expected, string(b))
}
return &http.Response{
Request: r,
StatusCode: 200,
}, nil
})
state := new(multistep.BasicStateBag) m := compute.NewDisksClient("subscriptionId")
state.Put("azureclient", &client.AzureClientSetMock{ m.Sender = autorest.SenderFunc(func(r *http.Request) (*http.Response, error) {
DisksClientMock: m, if r.Method != "PUT" {
}) t.Fatal("Expected only a PUT disk call")
state.Put("ui", packer.TestUi(t)) }
b, _ := ioutil.ReadAll(r.Body)
if string(b) != expectedPutDiskBody {
t.Fatalf("expected body to be %q, but got %q", expectedPutDiskBody, string(b))
}
return &http.Response{
Request: r,
StatusCode: 200,
}, nil
})
r := sut.Run(context.TODO(), state) state := new(multistep.BasicStateBag)
state.Put("azureclient", &client.AzureClientSetMock{
DisksClientMock: m,
})
state.Put("ui", packer.TestUi(t))
if r != multistep.ActionContinue { if got := s.Run(context.TODO(), state); !reflect.DeepEqual(got, tt.want) {
t.Fatal("Run failed") t.Errorf("StepCreateNewDisk.Run() = %v, want %v", got, tt.want)
}
})
} }
} }