PaymentMethodWithUsBankAccountTest.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. namespace Test\Integration;
  3. require_once dirname(__DIR__) . '/Setup.php';
  4. use Test;
  5. use Test\Setup;
  6. use Braintree;
  7. class PaymentMethodWithUsBankAccountTest extends Setup
  8. {
  9. public function testCreate_fromUsBankAccountNonce()
  10. {
  11. $customer = Braintree\Customer::createNoValidate();
  12. $result = Braintree\PaymentMethod::create([
  13. 'customerId' => $customer->id,
  14. 'paymentMethodNonce' => Test\Helper::generateValidUsBankAccountNonce(),
  15. 'options' => [
  16. 'verificationMerchantAccountId' => Test\Helper::usBankMerchantAccount()
  17. ]
  18. ]);
  19. $usBankAccount = $result->paymentMethod;
  20. $this->assertEquals('021000021', $usBankAccount->routingNumber);
  21. $this->assertEquals('1234', $usBankAccount->last4);
  22. $this->assertEquals('checking', $usBankAccount->accountType);
  23. $this->assertEquals('Dan Schulman', $usBankAccount->accountHolderName);
  24. $this->assertRegexp('/CHASE/', $usBankAccount->bankName);
  25. $this->assertEquals(true, $usBankAccount->verified);
  26. $this->assertEquals(1, count($usBankAccount->verifications));
  27. $verification = $usBankAccount->verifications[0];
  28. $this->assertEquals(Braintree\Result\UsBankAccountVerification::VERIFIED, $verification->status);
  29. $this->assertEquals(Braintree\Result\UsBankAccountVerification::INDEPENDENT_CHECK, $verification->verificationMethod);
  30. }
  31. public function testCreate_fromUsBankAccountNonceWithVerification()
  32. {
  33. $customer = Braintree\Customer::createNoValidate();
  34. $result = Braintree\PaymentMethod::create([
  35. 'customerId' => $customer->id,
  36. 'paymentMethodNonce' => Test\Helper::generateValidUsBankAccountNonce('1000000000'),
  37. 'options' => [
  38. 'verificationMerchantAccountId' => Test\Helper::usBankMerchantAccount(),
  39. 'usBankAccountVerificationMethod' => Braintree\Result\UsBankAccountVerification::NETWORK_CHECK,
  40. ]
  41. ]);
  42. $usBankAccount = $result->paymentMethod;
  43. $this->assertEquals('021000021', $usBankAccount->routingNumber);
  44. $this->assertEquals('0000', $usBankAccount->last4);
  45. $this->assertEquals('checking', $usBankAccount->accountType);
  46. $this->assertEquals('Dan Schulman', $usBankAccount->accountHolderName);
  47. $this->assertRegexp('/CHASE/', $usBankAccount->bankName);
  48. $this->assertEquals(true, $usBankAccount->verified);
  49. $this->assertEquals(1, count($usBankAccount->verifications));
  50. $verification = $usBankAccount->verifications[0];
  51. $this->assertEquals(Braintree\Result\UsBankAccountVerification::VERIFIED, $verification->status);
  52. $this->assertEquals(Braintree\Result\UsBankAccountVerification::NETWORK_CHECK, $verification->verificationMethod);
  53. }
  54. public function testCreate_fromPlaidUsBankAccountNonce()
  55. {
  56. $customer = Braintree\Customer::createNoValidate();
  57. $result = Braintree\PaymentMethod::create([
  58. 'customerId' => $customer->id,
  59. 'paymentMethodNonce' => Test\Helper::generatePlaidUsBankAccountNonce(),
  60. 'options' => [
  61. 'verificationMerchantAccountId' => Test\Helper::usBankMerchantAccount()
  62. ]
  63. ]);
  64. $usBankAccount = $result->paymentMethod;
  65. $this->assertEquals('011000015', $usBankAccount->routingNumber);
  66. $this->assertEquals('0000', $usBankAccount->last4);
  67. $this->assertEquals('checking', $usBankAccount->accountType);
  68. $this->assertEquals('Dan Schulman', $usBankAccount->accountHolderName);
  69. $this->assertRegexp('/FEDERAL/', $usBankAccount->bankName);
  70. $this->assertEquals(true, $usBankAccount->verified);
  71. $this->assertEquals(1, count($usBankAccount->verifications));
  72. $verification = $usBankAccount->verifications[0];
  73. $this->assertEquals(Braintree\Result\UsBankAccountVerification::VERIFIED, $verification->status);
  74. $this->assertEquals(Braintree\Result\UsBankAccountVerification::TOKENIZED_CHECK, $verification->verificationMethod);
  75. }
  76. public function testFind_returnsUsBankAccount()
  77. {
  78. $customer = Braintree\Customer::createNoValidate();
  79. $result = Braintree\PaymentMethod::create([
  80. 'customerId' => $customer->id,
  81. 'paymentMethodNonce' => Test\Helper::generateValidUsBankAccountNonce(),
  82. 'options' => [
  83. 'verificationMerchantAccountId' => Test\Helper::usBankMerchantAccount()
  84. ]
  85. ]);
  86. $foundUsBankAccount = Braintree\PaymentMethod::find($result->paymentMethod->token);
  87. $this->assertInstanceOf('Braintree\UsBankAccount', $foundUsBankAccount);
  88. $this->assertEquals('021000021', $foundUsBankAccount->routingNumber);
  89. $this->assertEquals('1234', $foundUsBankAccount->last4);
  90. $this->assertEquals('checking', $foundUsBankAccount->accountType);
  91. $this->assertEquals('Dan Schulman', $foundUsBankAccount->accountHolderName);
  92. $this->assertRegExp('/CHASE/', $foundUsBankAccount->bankName);
  93. }
  94. public function testCompliantCreate_fromUsBankAccountNonce()
  95. {
  96. $gateway = new Braintree\Gateway([
  97. 'environment' => 'development',
  98. 'merchantId' => 'integration2_merchant_id',
  99. 'publicKey' => 'integration2_public_key',
  100. 'privateKey' => 'integration2_private_key'
  101. ]);
  102. $customer = $gateway->customer()->create([
  103. 'firstName' => 'Joe',
  104. 'lastName' => 'Brown'
  105. ])->customer;
  106. $result = $gateway->paymentMethod()->create([
  107. 'customerId' => $customer->id,
  108. 'paymentMethodNonce' => Test\Helper::generateValidUsBankAccountNonce(),
  109. 'options' => [
  110. 'verificationMerchantAccountId' => Test\Helper::anotherUsBankMerchantAccount()
  111. ]
  112. ]);
  113. $usBankAccount = $result->paymentMethod;
  114. $this->assertEquals('021000021', $usBankAccount->routingNumber);
  115. $this->assertEquals('1234', $usBankAccount->last4);
  116. $this->assertEquals('checking', $usBankAccount->accountType);
  117. $this->assertEquals('Dan Schulman', $usBankAccount->accountHolderName);
  118. $this->assertRegexp('/CHASE/', $usBankAccount->bankName);
  119. $this->assertEquals(false, $usBankAccount->verified);
  120. $this->assertEquals(0, count($usBankAccount->verifications));
  121. }
  122. }