diff --git a/hcloud/primary_ip.go b/hcloud/primary_ip.go index 15999ddb..3d51ea21 100644 --- a/hcloud/primary_ip.go +++ b/hcloud/primary_ip.go @@ -119,7 +119,7 @@ type PrimaryIPUpdateOpts struct { // PrimaryIPAssignOpts defines the request to // assign a Primary IP to an assignee (usually a server). type PrimaryIPAssignOpts struct { - ID int + ID int `json:"-"` AssigneeID int `json:"assignee_id"` AssigneeType string `json:"assignee_type"` } @@ -133,7 +133,7 @@ type PrimaryIPAssignResult struct { // PrimaryIPChangeDNSPtrOpts defines the request to // change a DNS PTR entry from a Primary IP. type PrimaryIPChangeDNSPtrOpts struct { - ID int + ID int `json:"-"` DNSPtr string `json:"dns_ptr"` IP string `json:"ip"` } @@ -147,7 +147,7 @@ type PrimaryIPChangeDNSPtrResult struct { // PrimaryIPChangeProtectionOpts defines the request to // change protection configuration of a Primary IP. type PrimaryIPChangeProtectionOpts struct { - ID int + ID int `json:"-"` Delete bool `json:"delete"` } diff --git a/hcloud/primary_ip_test.go b/hcloud/primary_ip_test.go index d368b71a..224d0c94 100644 --- a/hcloud/primary_ip_test.go +++ b/hcloud/primary_ip_test.go @@ -368,18 +368,15 @@ func TestPrimaryIPClient(t *testing.T) { t.Error("expected POST") } w.Header().Set("Content-Type", "application/json") - expectedReqBody := PrimaryIPAssignOpts{ - AssigneeType: "server", - AssigneeID: 1, - ID: 1, - } + if err := json.NewDecoder(r.Body).Decode(&reqBody); err != nil { t.Fatal(err) } - if !cmp.Equal(expectedReqBody, reqBody) { - t.Log(cmp.Diff(expectedReqBody, reqBody)) - t.Error("unexpected request body") - } + + assert.Equal(t, int(1), reqBody.AssigneeID) + assert.Equal(t, "server", reqBody.AssigneeType) + assert.Equal(t, int(0), reqBody.ID) + json.NewEncoder(w).Encode(PrimaryIPAssignResult{ Action: schema.Action{ID: 1}, }) @@ -428,16 +425,15 @@ func TestPrimaryIPClient(t *testing.T) { t.Error("expected POST") } w.Header().Set("Content-Type", "application/json") - expectedReqBody := PrimaryIPChangeDNSPtrOpts{ - ID: 1, - } + if err := json.NewDecoder(r.Body).Decode(&reqBody); err != nil { t.Fatal(err) } - if !cmp.Equal(expectedReqBody, reqBody) { - t.Log(cmp.Diff(expectedReqBody, reqBody)) - t.Error("unexpected request body") - } + + assert.Equal(t, "value", reqBody.DNSPtr) + assert.Equal(t, "127.0.0.1", reqBody.IP) + assert.Equal(t, int(0), reqBody.ID) + json.NewEncoder(w).Encode(PrimaryIPChangeDNSPtrResult{ Action: schema.Action{ID: 1}, }) @@ -445,7 +441,9 @@ func TestPrimaryIPClient(t *testing.T) { ctx := context.Background() opts := PrimaryIPChangeDNSPtrOpts{ - ID: 1, + ID: 1, + DNSPtr: "value", + IP: "127.0.0.1", } action, resp, err := env.Client.PrimaryIP.ChangeDNSPtr(ctx, opts) @@ -463,17 +461,13 @@ func TestPrimaryIPClient(t *testing.T) { t.Error("expected POST") } w.Header().Set("Content-Type", "application/json") - expectedReqBody := PrimaryIPChangeProtectionOpts{ - ID: 1, - Delete: true, - } if err := json.NewDecoder(r.Body).Decode(&reqBody); err != nil { t.Fatal(err) } - if !cmp.Equal(expectedReqBody, reqBody) { - t.Log(cmp.Diff(expectedReqBody, reqBody)) - t.Error("unexpected request body") - } + + assert.True(t, reqBody.Delete) + assert.Equal(t, int(0), reqBody.ID) + json.NewEncoder(w).Encode(PrimaryIPChangeProtectionResult{ Action: schema.Action{ID: 1}, })