mirror of
https://github.com/woocommerce/woocommerce-paypal-payments.git
synced 2025-08-30 05:00:51 +08:00
fix tests and cs
This commit is contained in:
parent
b82fc6128b
commit
f826c25f64
3 changed files with 138 additions and 34 deletions
|
@ -215,9 +215,9 @@ class CreateOrderEndpoint implements EndpointInterface {
|
|||
$number = preg_replace( '/[^0-9]/', '', $number );
|
||||
$number = substr( $number, 0, 14 );
|
||||
$data['payer']['phone']['phone_number']['national_number'] = $number;
|
||||
if( empty($data['payer']['phone']['phone_number']['national_number'] ) ) {
|
||||
unset($data['payer']['phone']);
|
||||
}
|
||||
if ( empty( $data['payer']['phone']['phone_number']['national_number'] ) ) {
|
||||
unset( $data['payer']['phone'] );
|
||||
}
|
||||
}
|
||||
|
||||
$payer = $this->payer_factory->from_paypal_response( json_decode( wp_json_encode( $data['payer'] ) ) );
|
||||
|
|
5
patchwork.json
Normal file
5
patchwork.json
Normal file
|
@ -0,0 +1,5 @@
|
|||
{
|
||||
"redefinable-internals": [
|
||||
"json_decode"
|
||||
]
|
||||
}
|
|
@ -4,23 +4,23 @@ declare(strict_types=1);
|
|||
namespace WooCommerce\PayPalCommerce\Button\Endpoint;
|
||||
|
||||
|
||||
use Mockery;
|
||||
use Mockery\Adapter\Phpunit\MockeryPHPUnitIntegration;
|
||||
use ReflectionClass;
|
||||
use WooCommerce\PayPalCommerce\ApiClient\Endpoint\OrderEndpoint;
|
||||
use WooCommerce\PayPalCommerce\ApiClient\Entity\PurchaseUnit;
|
||||
use WooCommerce\PayPalCommerce\ApiClient\Factory\PayerFactory;
|
||||
use WooCommerce\PayPalCommerce\ApiClient\Factory\PurchaseUnitFactory;
|
||||
use WooCommerce\PayPalCommerce\ApiClient\Repository\CartRepository;
|
||||
use WooCommerce\PayPalCommerce\Button\Helper\EarlyOrderHandler;
|
||||
use WooCommerce\PayPalCommerce\Session\SessionHandler;
|
||||
use WooCommerce\PayPalCommerce\TestCase;
|
||||
use Mockery;
|
||||
use WooCommerce\PayPalCommerce\WcGateway\Settings\Settings;
|
||||
|
||||
use function Brain\Monkey\Functions\expect;
|
||||
|
||||
class CreateOrderEndpointTest extends TestCase
|
||||
{
|
||||
|
||||
use MockeryPHPUnitIntegration;
|
||||
/**
|
||||
* @dataProvider dataForTestPhoneNumber
|
||||
* @test
|
||||
|
@ -28,34 +28,22 @@ class CreateOrderEndpointTest extends TestCase
|
|||
* @param $data
|
||||
* @param $expectedResult
|
||||
*/
|
||||
public function payerVerifiesPhoneNumber($data, $expectedResult) {
|
||||
$request_data = Mockery::mock(RequestData::class);
|
||||
$cart_repository = Mockery::mock(CartRepository::class);
|
||||
$purchase_unit_factory = Mockery::mock(PurchaseUnitFactory::class);
|
||||
$order_endpoint = Mockery::mock(OrderEndpoint::class);
|
||||
$payer_factory = Mockery::mock(PayerFactory::class);
|
||||
$session_handler = Mockery::mock(SessionHandler::class);
|
||||
$settings = Mockery::mock(Settings::class);
|
||||
$early_order_handler = Mockery::mock(EarlyOrderHandler::class);
|
||||
public function payerVerifiesPhoneNumber($data, $expectedResult)
|
||||
{
|
||||
list($payer_factory, $testee) = $this->mockTestee();
|
||||
|
||||
$testee = new CreateOrderEndpoint(
|
||||
$request_data,
|
||||
$cart_repository,
|
||||
$purchase_unit_factory,
|
||||
$order_endpoint,
|
||||
$payer_factory,
|
||||
$session_handler,
|
||||
$settings,
|
||||
$early_order_handler
|
||||
);
|
||||
$reflector = new ReflectionClass( CreateOrderEndpoint::class );
|
||||
$method = $reflector->getMethod( 'payer' );
|
||||
$method->setAccessible( true );
|
||||
$method = $this->testPrivateMethod(CreateOrderEndpoint::class, 'payer');
|
||||
$dataString = wp_json_encode($expectedResult['payer']);
|
||||
$dataObj = json_decode(wp_json_encode($expectedResult['payer']));
|
||||
|
||||
expect('wp_json_encode')->once()->with($expectedResult['payer'])
|
||||
->andReturn($dataString);
|
||||
expect('json_decode')->once()->with($dataString)->andReturn($dataObj);
|
||||
|
||||
|
||||
$payer = $method->invokeArgs( $testee, array( $data ) );
|
||||
$this->assertEquals($expectedResult, $payer);
|
||||
$payer_factory->expects('from_paypal_response')->with($dataObj);
|
||||
|
||||
$method->invokeArgs($testee, array($data));
|
||||
}
|
||||
|
||||
public function dataForTestPhoneNumber() : array {
|
||||
|
@ -65,20 +53,131 @@ class CreateOrderEndpointTest extends TestCase
|
|||
[
|
||||
'context' => 'none',
|
||||
'payer'=>[
|
||||
'name'=>['given_name'=>'testName'],
|
||||
'phone'=>[
|
||||
'phone_number'=>[
|
||||
'national_number'=>'123456789876'
|
||||
'national_number'=>''
|
||||
]
|
||||
]
|
||||
]
|
||||
],
|
||||
[
|
||||
[
|
||||
'context' => 'none',
|
||||
'payer'=>[]
|
||||
'context' => 'none',
|
||||
'payer' => [
|
||||
'name' => ['given_name' => 'testName']
|
||||
]
|
||||
]
|
||||
],
|
||||
'tooLongStringPhone' => [
|
||||
[
|
||||
'context' => 'none',
|
||||
'payer'=>[
|
||||
'name'=>['given_name'=>'testName'],
|
||||
'phone'=>[
|
||||
'phone_number'=>[
|
||||
'national_number'=>'43241341234123412341234123123412341'
|
||||
]
|
||||
]
|
||||
]
|
||||
],
|
||||
[
|
||||
'context' => 'none',
|
||||
'payer'=>[
|
||||
'name'=>['given_name'=>'testName'],
|
||||
'phone'=>[
|
||||
'phone_number'=>[
|
||||
'national_number'=>'43241341234123'
|
||||
]
|
||||
]
|
||||
]
|
||||
]
|
||||
],
|
||||
'removeNonISOStringPhone' => [
|
||||
[
|
||||
'context' => 'none',
|
||||
'payer'=>[
|
||||
'name'=>['given_name'=>'testName'],
|
||||
'phone'=>[
|
||||
'phone_number'=>[
|
||||
'national_number'=>'432a34as73737373'
|
||||
]
|
||||
]
|
||||
]
|
||||
],
|
||||
[
|
||||
'context' => 'none',
|
||||
'payer'=>[
|
||||
'name'=>['given_name'=>'testName'],
|
||||
'phone'=>[
|
||||
'phone_number'=>[
|
||||
'national_number'=>'4323473737373'
|
||||
]
|
||||
]
|
||||
]
|
||||
]
|
||||
],
|
||||
'notNumbersStringPhone' => [
|
||||
[
|
||||
'context' => 'none',
|
||||
'payer'=>[
|
||||
'name'=>['given_name'=>'testName'],
|
||||
'phone'=>[
|
||||
'phone_number'=>[
|
||||
'national_number'=>'this is_notaPhone'
|
||||
]
|
||||
]
|
||||
]
|
||||
],
|
||||
[
|
||||
'context' => 'none',
|
||||
'payer'=>[
|
||||
'name'=>['given_name'=>'testName']
|
||||
]
|
||||
]
|
||||
]
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array
|
||||
*/
|
||||
protected function mockTestee()
|
||||
{
|
||||
$request_data = Mockery::mock(RequestData::class);
|
||||
$cart_repository = Mockery::mock(CartRepository::class);
|
||||
$purchase_unit_factory = Mockery::mock(PurchaseUnitFactory::class);
|
||||
$order_endpoint = Mockery::mock(OrderEndpoint::class);
|
||||
$payer_factory = Mockery::mock(PayerFactory::class);
|
||||
$session_handler = Mockery::mock(SessionHandler::class);
|
||||
$settings = Mockery::mock(Settings::class);
|
||||
$early_order_handler = Mockery::mock(EarlyOrderHandler::class);
|
||||
|
||||
$testee = new CreateOrderEndpoint(
|
||||
$request_data,
|
||||
$cart_repository,
|
||||
$purchase_unit_factory,
|
||||
$order_endpoint,
|
||||
$payer_factory,
|
||||
$session_handler,
|
||||
$settings,
|
||||
$early_order_handler
|
||||
);
|
||||
return array($payer_factory, $testee);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param $class
|
||||
*
|
||||
* @param $method
|
||||
*
|
||||
* @return \ReflectionMethod
|
||||
* @throws \ReflectionException
|
||||
*/
|
||||
protected function testPrivateMethod($class, $method)
|
||||
{
|
||||
$reflector = new ReflectionClass($class);
|
||||
$method = $reflector->getMethod($method);
|
||||
$method->setAccessible(true);
|
||||
return $method;
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue