Skip to content

Commit

Permalink
deprecate Usagecharge->BillingOn (#296)
Browse files Browse the repository at this point in the history
  • Loading branch information
oliver006 committed Jun 14, 2024
1 parent 25ac86d commit 59f2103
Show file tree
Hide file tree
Showing 3 changed files with 0 additions and 40 deletions.
2 changes: 0 additions & 2 deletions goshopify_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -987,8 +987,6 @@ func TestListWithPagination(t *testing.T) {
t.Fatalf("Expected pagination options but found at least one of them nil")
}

t.Logf("b: %#v \n", *pagination.NextPageOptions)

if pagination.NextPageOptions.PageInfo != "abc" {
t.Fatalf("Expected next page: %s got: %s", "abc", pagination.NextPageOptions.PageInfo)
}
Expand Down
22 changes: 0 additions & 22 deletions usagecharge.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package goshopify

import (
"context"
"encoding/json"
"fmt"
"time"

Expand Down Expand Up @@ -30,34 +29,13 @@ type UsageChargeServiceOp struct {
type UsageCharge struct {
BalanceRemaining *decimal.Decimal `json:"balance_remaining,omitempty"`
BalanceUsed *decimal.Decimal `json:"balance_used,omitempty"`
BillingOn *time.Time `json:"billing_on,omitempty"`
CreatedAt *time.Time `json:"created_at,omitempty"`
Description string `json:"description,omitempty"`
Id uint64 `json:"id,omitempty"`
Price *decimal.Decimal `json:"price,omitempty"`
RiskLevel *decimal.Decimal `json:"risk_level,omitempty"`
}

func (r *UsageCharge) UnmarshalJSON(data []byte) error {
// This is a workaround for the API returning BillingOn date in the format of "YYYY-MM-DD"
// https://help.shopify.com/en/api/reference/billing/usagecharge#endpoints
// For a longer explanation of the hack check:
// http://choly.ca/post/go-json-marshalling/
type alias UsageCharge
aux := &struct {
BillingOn *string `json:"billing_on"`
*alias
}{alias: (*alias)(r)}

if err := json.Unmarshal(data, &aux); err != nil {
return err
}
if err := parse(&r.BillingOn, aux.BillingOn); err != nil {
return err
}
return nil
}

// UsageChargeResource represents the result from the
// /admin/recurring_application_charges/X/usage_charges/X.json endpoints
type UsageChargeResource struct {
Expand Down
16 changes: 0 additions & 16 deletions usagecharge_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@ import (
func usageChargeTests(t *testing.T, usageCharge UsageCharge) {
price := decimal.NewFromFloat(1.0)
createdAt, _ := time.Parse(time.RFC3339, "2018-07-05T13:05:43-04:00")
billingOn, _ := time.Parse("2006-01-02", "2018-08-04")
balanceUsed := decimal.NewFromFloat(11.0)
balancedRemaining := decimal.NewFromFloat(89.0)
riskLevel := decimal.NewFromFloat(0.08)
Expand All @@ -23,7 +22,6 @@ func usageChargeTests(t *testing.T, usageCharge UsageCharge) {
Description: "Super Mega Plan 1000 emails",
Price: &price,
CreatedAt: &createdAt,
BillingOn: &billingOn,
BalanceRemaining: &balancedRemaining,
BalanceUsed: &balanceUsed,
RiskLevel: &riskLevel,
Expand All @@ -41,9 +39,6 @@ func usageChargeTests(t *testing.T, usageCharge UsageCharge) {
if !usageCharge.CreatedAt.Equal(*expected.CreatedAt) {
t.Errorf("UsageCharge.CreatedAt returned %v, expected %v", usageCharge.CreatedAt, expected.CreatedAt)
}
if !usageCharge.BillingOn.Equal(*expected.BillingOn) {
t.Errorf("UsageCharge.BillingOn returned %v, expected %v", usageCharge.BillingOn, expected.BillingOn)
}
if !usageCharge.BalanceRemaining.Equal(*expected.BalanceRemaining) {
t.Errorf("UsageCharge.BalanceRemaining returned %v, expected %v", usageCharge.BalanceRemaining, expected.BalanceRemaining)
}
Expand Down Expand Up @@ -140,15 +135,4 @@ func TestUsageChargeServiceOp_GetBadFields(t *testing.T) {
if _, err := client.UsageCharge.Get(context.Background(), 455696195, 1034618210, nil); err == nil {
t.Errorf("UsageCharge.Get should have returned an error")
}

httpmock.RegisterResponder(
"GET",
fmt.Sprintf("https://fooshop.myshopify.com/%s/recurring_application_charges/455696195/usage_charges/1034618210.json", client.pathPrefix),
httpmock.NewStringResponder(
200, `{"usage_charge":{"billing_on":"2018-14-01"}}`,
),
)
if _, err := client.UsageCharge.Get(context.Background(), 455696195, 1034618210, nil); err == nil {
t.Errorf("UsageCharge.Get should have returned an error")
}
}

0 comments on commit 59f2103

Please sign in to comment.