mirror of
https://github.com/plutov/paypal.git
synced 2025-01-23 10:21:03 +01:00
438 lines
11 KiB
Go
438 lines
11 KiB
Go
// +build integration
|
|
|
|
package paypalsdk
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
// All test values are defined here
|
|
var testClientID = "AZgwu4yt5Ba0gyTu1dGBH3txHCJbMuFNvrmQxBaQbfDncDiCs6W_rwJD8Ir-0pZrN-_eq7n9zVd8Y-5f"
|
|
var testSecret = "EBzA1wRl5t73OMugOieDj_tI3vihfJmGl47ukQT-cpctooIzDu0K7IPESNC0cKodlLSOXzwI8qXSM0rd"
|
|
var testAuthID = "2DC87612EK520411B"
|
|
var testOrderID = "O-0PW72302W3743444R"
|
|
var testSaleID = "4CF18861HF410323U"
|
|
var testPaymentID = "PAY-5YK922393D847794YKER7MUI"
|
|
var testPayerID = "CR87QHB7JTRSC"
|
|
var testUserID = "https://www.paypal.com/webapps/auth/identity/user/WEssgRpQij92sE99_F9MImvQ8FPYgUEjrvCja2qH2H8"
|
|
var testCardID = "CARD-54E6956910402550WKGRL6EA"
|
|
|
|
func TestGetAccessToken(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
token, err := c.GetAccessToken()
|
|
if err != nil {
|
|
t.Errorf("Not expected error for GetAccessToken(), got %s", err.Error())
|
|
}
|
|
if token.Token == "" {
|
|
t.Errorf("Expected non-empty token for GetAccessToken()")
|
|
}
|
|
}
|
|
|
|
func TestGetAuthorization(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.GetAuthorization(testAuthID)
|
|
if err == nil {
|
|
t.Errorf("GetAuthorization expects error")
|
|
}
|
|
}
|
|
|
|
func TestCaptureAuthorization(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.CaptureAuthorization(testAuthID, &Amount{Total: "200", Currency: "USD"}, true)
|
|
|
|
if err == nil {
|
|
t.Errorf("Auth is expired, 400 error must be returned")
|
|
}
|
|
}
|
|
|
|
func TestVoidAuthorization(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.VoidAuthorization(testAuthID)
|
|
|
|
if err == nil {
|
|
t.Errorf("Auth is expired, 400 error must be returned")
|
|
}
|
|
}
|
|
|
|
func TestReauthorizeAuthorization(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.ReauthorizeAuthorization(testAuthID, &Amount{Total: "200", Currency: "USD"})
|
|
|
|
if err == nil {
|
|
t.Errorf("Reauthorization not allowed for this product, 500 error must be returned")
|
|
}
|
|
}
|
|
|
|
func TestGrantNewAccessTokenFromAuthCode(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
|
|
_, err := c.GrantNewAccessTokenFromAuthCode("123", "http://example.com/myapp/return.php")
|
|
if err == nil {
|
|
t.Errorf("GrantNewAccessTokenFromAuthCode must return error for invalid code")
|
|
}
|
|
}
|
|
|
|
func TestGrantNewAccessTokenFromRefreshToken(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
|
|
_, err := c.GrantNewAccessTokenFromRefreshToken("123")
|
|
if err == nil {
|
|
t.Errorf("GrantNewAccessTokenFromRefreshToken must return error for invalid refresh token")
|
|
}
|
|
}
|
|
|
|
func TestGetUserInfo(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
u, err := c.GetUserInfo("openid")
|
|
if u.ID != testUserID || err != nil {
|
|
t.Errorf("GetUserInfo must return valid test ID=%s, error: %v", testUserID, err)
|
|
}
|
|
}
|
|
|
|
func TestGetOrder(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.GetOrder(testOrderID)
|
|
if err == nil {
|
|
t.Errorf("GetOrder expects error")
|
|
}
|
|
}
|
|
|
|
func TestAuthorizeOrder(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.AuthorizeOrder(testOrderID, &Amount{Total: "7.00", Currency: "USD"})
|
|
if err == nil {
|
|
t.Errorf("Order is expired, 400 error must be returned")
|
|
}
|
|
}
|
|
|
|
func TestCaptureOrder(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.CaptureOrder(testOrderID, &Amount{Total: "100", Currency: "USD"}, true, nil)
|
|
if err == nil {
|
|
t.Errorf("Order is expired, 400 error must be returned")
|
|
}
|
|
}
|
|
|
|
func TestVoidOrder(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.VoidOrder(testOrderID)
|
|
if err == nil {
|
|
t.Errorf("Order is expired, 400 error must be returned")
|
|
}
|
|
}
|
|
|
|
func TestCreateDirectPaypalPayment(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
amount := Amount{
|
|
Total: "15.11",
|
|
Currency: "USD",
|
|
}
|
|
|
|
p, err := c.CreateDirectPaypalPayment(amount, "http://example.com", "http://example.com", "test payment")
|
|
|
|
if err != nil || p.ID == "" {
|
|
t.Errorf("Test paypal payment is not created, err: %v", err)
|
|
}
|
|
}
|
|
|
|
func TestCreatePayment(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
p := Payment{
|
|
Intent: "sale",
|
|
Payer: &Payer{
|
|
PaymentMethod: "credit_card",
|
|
FundingInstruments: []FundingInstrument{{
|
|
CreditCard: &CreditCard{
|
|
Number: "4111111111111111",
|
|
Type: "visa",
|
|
ExpireMonth: "11",
|
|
ExpireYear: "2020",
|
|
CVV2: "777",
|
|
FirstName: "John",
|
|
LastName: "Doe",
|
|
},
|
|
}},
|
|
},
|
|
Transactions: []Transaction{{
|
|
Amount: &Amount{
|
|
Currency: "USD",
|
|
Total: "10.00", // total cost including shipping
|
|
Details: Details{
|
|
Shipping: "3.00", // total shipping cost
|
|
Subtotal: "7.00", // total cost without shipping
|
|
},
|
|
},
|
|
Description: "My Payment",
|
|
ItemList: &ItemList{
|
|
Items: []Item{
|
|
Item{
|
|
Quantity: "2",
|
|
Price: "3.50",
|
|
Currency: "USD",
|
|
Name: "Product 1",
|
|
},
|
|
},
|
|
},
|
|
}},
|
|
RedirectURLs: &RedirectURLs{
|
|
ReturnURL: "http://..",
|
|
CancelURL: "http://..",
|
|
},
|
|
}
|
|
_, err := c.CreatePayment(p)
|
|
if err == nil {
|
|
t.Errorf("Expected error")
|
|
}
|
|
}
|
|
|
|
func TestGetPayment(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.GetPayment(testPaymentID)
|
|
|
|
if err == nil {
|
|
t.Errorf("404 for this payment ID")
|
|
}
|
|
}
|
|
|
|
func TestGetPayments(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.GetPayments()
|
|
|
|
if err != nil {
|
|
t.Errorf("Nil error expected, got: %s", err.Error())
|
|
}
|
|
}
|
|
|
|
func TestPatchPayment(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
p := Payment{
|
|
Intent: "sale",
|
|
Payer: &Payer{
|
|
PaymentMethod: "paypal",
|
|
},
|
|
Transactions: []Transaction{{
|
|
Amount: &Amount{
|
|
Currency: "USD",
|
|
Total: "10.00", // total cost including shipping
|
|
Details: Details{
|
|
Shipping: "3.00", // total shipping cost
|
|
Subtotal: "7.00", // total cost without shipping
|
|
},
|
|
},
|
|
Description: "My Payment",
|
|
ItemList: &ItemList{
|
|
Items: []Item{
|
|
Item{
|
|
Quantity: "2",
|
|
Price: "3.50",
|
|
Currency: "USD",
|
|
Name: "Product 1",
|
|
},
|
|
},
|
|
},
|
|
Custom: "First value",
|
|
}},
|
|
RedirectURLs: &RedirectURLs{
|
|
ReturnURL: "http://..",
|
|
CancelURL: "http://..",
|
|
},
|
|
}
|
|
NewPayment, err := c.CreatePayment(p)
|
|
if err != nil {
|
|
t.Errorf("Unexpected error %v", err)
|
|
}
|
|
PaymentID := NewPayment.ID
|
|
pp := []PaymentPatch{
|
|
{
|
|
Operation: "replace",
|
|
Path: "/transactions/0/custom",
|
|
Value: "Replaced Value",
|
|
},
|
|
}
|
|
RevisedPayment, errpp := c.PatchPayment(PaymentID, pp)
|
|
if errpp != nil {
|
|
t.Errorf("Unexpected error when patching %v", errpp)
|
|
}
|
|
if RevisedPayment.Transactions != nil &&
|
|
len(RevisedPayment.Transactions) > 0 &&
|
|
RevisedPayment.Transactions[0].Custom != "" {
|
|
if RevisedPayment.Transactions[0].Custom != "Replaced Value" {
|
|
t.Errorf("Patched payment value failed to be patched %v", RevisedPayment.Transactions[0].Custom)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestExecuteApprovedPayment(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.ExecuteApprovedPayment(testPaymentID, testPayerID)
|
|
|
|
if err == nil {
|
|
t.Errorf("404 for this payment ID")
|
|
}
|
|
}
|
|
|
|
func TestCreateSinglePayout(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
payout := Payout{
|
|
SenderBatchHeader: &SenderBatchHeader{
|
|
EmailSubject: "Subject will be displayed on PayPal",
|
|
},
|
|
Items: []PayoutItem{
|
|
{
|
|
RecipientType: "EMAIL",
|
|
Receiver: "single-email-payout@mail.com",
|
|
Amount: &AmountPayout{
|
|
Value: "15.11",
|
|
Currency: "USD",
|
|
},
|
|
Note: "Optional note",
|
|
SenderItemID: "Optional Item ID",
|
|
},
|
|
},
|
|
}
|
|
|
|
_, err := c.CreateSinglePayout(payout)
|
|
|
|
if err != nil {
|
|
t.Errorf("Test single payout is not created, error: %v", err)
|
|
}
|
|
}
|
|
|
|
func TestGetSale(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.GetSale(testSaleID)
|
|
if err == nil {
|
|
t.Errorf("404 must be returned for ID=%s", testSaleID)
|
|
}
|
|
}
|
|
|
|
func TestRefundSale(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.RefundSale(testSaleID, nil)
|
|
if err == nil {
|
|
t.Errorf("404 must be returned for ID=%s", testSaleID)
|
|
}
|
|
|
|
_, err = c.RefundSale(testSaleID, &Amount{Total: "7.00", Currency: "USD"})
|
|
if err == nil {
|
|
t.Errorf("404 must be returned for ID=%s", testSaleID)
|
|
}
|
|
}
|
|
|
|
func TestGetRefund(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
_, err := c.GetRefund("1")
|
|
if err == nil {
|
|
t.Errorf("404 must be returned for ID=%s", testSaleID)
|
|
}
|
|
}
|
|
|
|
func TestStoreCreditCard(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
r1, e1 := c.StoreCreditCard(CreditCard{})
|
|
if e1 == nil || r1 != nil {
|
|
t.Errorf("Error is expected for invalid CC")
|
|
}
|
|
|
|
r2, e2 := c.StoreCreditCard(CreditCard{
|
|
Number: "4417119669820331",
|
|
Type: "visa",
|
|
ExpireMonth: "11",
|
|
ExpireYear: "2020",
|
|
CVV2: "874",
|
|
FirstName: "Foo",
|
|
LastName: "Bar",
|
|
})
|
|
if e2 != nil || r2 == nil {
|
|
t.Errorf("200 code expected for valid CC card. Error: %v", e2)
|
|
}
|
|
}
|
|
|
|
func TestDeleteCreditCard(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
e1 := c.DeleteCreditCard("")
|
|
if e1 == nil {
|
|
t.Errorf("Error is expected for invalid CC ID")
|
|
}
|
|
}
|
|
|
|
func TestGetCreditCard(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
r1, e1 := c.GetCreditCard("BBGGG")
|
|
if e1 == nil || r1 != nil {
|
|
t.Errorf("Error is expected for invalid CC, got CC %v", r1)
|
|
}
|
|
}
|
|
|
|
func TestGetCreditCards(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
r1, e1 := c.GetCreditCards(nil)
|
|
if e1 != nil || r1 == nil {
|
|
t.Errorf("200 code expected. Error: %v", e1)
|
|
}
|
|
|
|
r2, e2 := c.GetCreditCards(&CreditCardsFilter{
|
|
Page: 2,
|
|
PageSize: 7,
|
|
})
|
|
if e2 != nil || r2 == nil {
|
|
t.Errorf("200 code expected. Error: %v", e2)
|
|
}
|
|
}
|
|
|
|
func TestPatchCreditCard(t *testing.T) {
|
|
c, _ := NewClient(testClientID, testSecret, APIBaseSandBox)
|
|
c.GetAccessToken()
|
|
|
|
r1, e1 := c.PatchCreditCard(testCardID, nil)
|
|
if e1 == nil || r1 != nil {
|
|
t.Errorf("Error is expected for empty update info")
|
|
}
|
|
}
|