mirror of
https://github.com/woocommerce/woocommerce-paypal-payments.git
synced 2025-09-01 07:02:48 +08:00
Add test coverage for payment tokens
This commit is contained in:
parent
eef459df58
commit
7842939ede
5 changed files with 373 additions and 1 deletions
|
@ -0,0 +1,88 @@
|
|||
<?php
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace WooCommerce\PayPalCommerce\Subscription\Repository;
|
||||
|
||||
use WooCommerce\PayPalCommerce\ApiClient\Endpoint\PaymentTokenEndpoint;
|
||||
use WooCommerce\PayPalCommerce\ApiClient\Entity\PaymentToken;
|
||||
use WooCommerce\PayPalCommerce\ApiClient\Exception\RuntimeException;
|
||||
use WooCommerce\PayPalCommerce\ApiClient\Factory\PaymentTokenFactory;
|
||||
use WooCommerce\PayPalCommerce\TestCase;
|
||||
use Mockery;
|
||||
use Mockery\Adapter\Phpunit\MockeryPHPUnitIntegration;
|
||||
use function Brain\Monkey\Functions\expect;
|
||||
use function Brain\Monkey\Functions\when;
|
||||
|
||||
class PaymentTokenRepositoryTest extends TestCase
|
||||
{
|
||||
use MockeryPHPUnitIntegration;
|
||||
|
||||
private $factory;
|
||||
private $endpoint;
|
||||
private $sut;
|
||||
|
||||
public function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
$this->factory = Mockery::mock(PaymentTokenFactory::class);
|
||||
$this->endpoint = Mockery::mock(PaymentTokenEndpoint::class);
|
||||
$this->sut = new PaymentTokenRepository($this->factory, $this->endpoint);
|
||||
}
|
||||
|
||||
public function testForUserIdFromArray()
|
||||
{
|
||||
$id = 1;
|
||||
$token = ['id' => 'foo'];
|
||||
$paymentToken = new PaymentToken('foo', 'PAYMENT_METHOD_TOKEN');
|
||||
|
||||
expect('get_user_meta')->with($id, $this->sut::USER_META, true)
|
||||
->andReturn($token);
|
||||
|
||||
$this->factory->shouldReceive('from_array')->with($token)
|
||||
->andReturn($paymentToken);
|
||||
|
||||
$result = $this->sut->for_user_id($id);
|
||||
$this->assertInstanceOf(PaymentToken::class, $result);
|
||||
}
|
||||
|
||||
public function testFetchForUserId()
|
||||
{
|
||||
$id = 1;
|
||||
$paymentToken = new PaymentToken('foo', 'PAYMENT_METHOD_TOKEN');
|
||||
|
||||
when('get_user_meta')->justReturn([]);
|
||||
$this->endpoint->shouldReceive('for_user')
|
||||
->with($id)
|
||||
->andReturn([$paymentToken]);
|
||||
expect('update_user_meta')->with($id, $this->sut::USER_META, $paymentToken->to_array());
|
||||
|
||||
$result = $this->sut->for_user_id($id);
|
||||
$this->assertInstanceOf(PaymentToken::class, $result);
|
||||
}
|
||||
|
||||
public function testForUserIdFails()
|
||||
{
|
||||
$id = 1;
|
||||
when('get_user_meta')->justReturn([]);
|
||||
|
||||
$this->endpoint
|
||||
->expects('for_user')
|
||||
->with($id)
|
||||
->andThrow(RuntimeException::class);
|
||||
|
||||
$result = $this->sut->for_user_id($id);
|
||||
$this->assertNull($result);
|
||||
}
|
||||
|
||||
public function testDeleteToken()
|
||||
{
|
||||
$id = 1;
|
||||
$paymentToken = new PaymentToken('foo', 'PAYMENT_METHOD_TOKEN');
|
||||
|
||||
expect('delete_user_meta')->with($id, $this->sut::USER_META);
|
||||
$this->endpoint->shouldReceive('delete_token')
|
||||
->with($paymentToken);
|
||||
|
||||
$this->sut->delete_token($id, $paymentToken);
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue