mirror of
https://github.com/nothingworksinc/ticketbeast.git
synced 2026-02-10 12:51:28 +00:00
65 - Extracting a Contract Test
This commit is contained in:
@@ -35,7 +35,7 @@ class FakePaymentGateway implements PaymentGateway
|
||||
{
|
||||
$chargesFrom = $this->charges->count();
|
||||
$callback($this);
|
||||
return $this->charges->slice($chargesFrom)->values();
|
||||
return $this->charges->slice($chargesFrom)->reverse()->values();
|
||||
}
|
||||
|
||||
public function totalCharges()
|
||||
|
||||
@@ -28,7 +28,7 @@
|
||||
},
|
||||
"autoload-dev": {
|
||||
"classmap": [
|
||||
"tests/TestCase.php"
|
||||
"tests"
|
||||
]
|
||||
},
|
||||
"scripts": {
|
||||
|
||||
@@ -8,40 +8,13 @@ use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||
|
||||
class FakePaymentGatewayTest extends TestCase
|
||||
{
|
||||
use PaymentGatewayContractTests;
|
||||
|
||||
protected function getPaymentGateway()
|
||||
{
|
||||
return new FakePaymentGateway;
|
||||
}
|
||||
|
||||
/** @test */
|
||||
function can_fetch_charges_created_during_a_callback()
|
||||
{
|
||||
$paymentGateway = $this->getPaymentGateway();
|
||||
$paymentGateway->charge(2000, $paymentGateway->getValidTestToken());
|
||||
$paymentGateway->charge(3000, $paymentGateway->getValidTestToken());
|
||||
|
||||
$newCharges = $paymentGateway->newChargesDuring(function ($paymentGateway) {
|
||||
$paymentGateway->charge(4000, $paymentGateway->getValidTestToken());
|
||||
$paymentGateway->charge(5000, $paymentGateway->getValidTestToken());
|
||||
});
|
||||
|
||||
$this->assertCount(2, $newCharges);
|
||||
$this->assertEquals([4000, 5000], $newCharges->all());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
function charges_with_a_valid_payment_token_are_successful()
|
||||
{
|
||||
$paymentGateway = $this->getPaymentGateway();
|
||||
|
||||
$newCharges = $paymentGateway->newChargesDuring(function ($paymentGateway) {
|
||||
$paymentGateway->charge(2500, $paymentGateway->getValidTestToken());
|
||||
});
|
||||
|
||||
$this->assertCount(1, $newCharges);
|
||||
$this->assertEquals(2500, $newCharges->sum());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
function charges_with_an_invalid_payment_token_fail()
|
||||
{
|
||||
|
||||
35
tests/unit/Billing/PaymentGatewayContractTests.php
Normal file
35
tests/unit/Billing/PaymentGatewayContractTests.php
Normal file
@@ -0,0 +1,35 @@
|
||||
<?php
|
||||
|
||||
trait PaymentGatewayContractTests
|
||||
{
|
||||
abstract protected function getPaymentGateway();
|
||||
|
||||
/** @test */
|
||||
function charges_with_a_valid_payment_token_are_successful()
|
||||
{
|
||||
$paymentGateway = $this->getPaymentGateway();
|
||||
|
||||
$newCharges = $paymentGateway->newChargesDuring(function ($paymentGateway) {
|
||||
$paymentGateway->charge(2500, $paymentGateway->getValidTestToken());
|
||||
});
|
||||
|
||||
$this->assertCount(1, $newCharges);
|
||||
$this->assertEquals(2500, $newCharges->sum());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
function can_fetch_charges_created_during_a_callback()
|
||||
{
|
||||
$paymentGateway = $this->getPaymentGateway();
|
||||
$paymentGateway->charge(2000, $paymentGateway->getValidTestToken());
|
||||
$paymentGateway->charge(3000, $paymentGateway->getValidTestToken());
|
||||
|
||||
$newCharges = $paymentGateway->newChargesDuring(function ($paymentGateway) {
|
||||
$paymentGateway->charge(4000, $paymentGateway->getValidTestToken());
|
||||
$paymentGateway->charge(5000, $paymentGateway->getValidTestToken());
|
||||
});
|
||||
|
||||
$this->assertCount(2, $newCharges);
|
||||
$this->assertEquals([5000, 4000], $newCharges->all());
|
||||
}
|
||||
}
|
||||
@@ -8,6 +8,8 @@ use App\Billing\PaymentFailedException;
|
||||
*/
|
||||
class StripePaymentGatewayTest extends TestCase
|
||||
{
|
||||
use PaymentGatewayContractTests;
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
parent::setUp();
|
||||
@@ -19,19 +21,6 @@ class StripePaymentGatewayTest extends TestCase
|
||||
return new StripePaymentGateway(config('services.stripe.secret'));
|
||||
}
|
||||
|
||||
/** @test */
|
||||
function charges_with_a_valid_payment_token_are_successful()
|
||||
{
|
||||
$paymentGateway = $this->getPaymentGateway();
|
||||
|
||||
$newCharges = $paymentGateway->newChargesDuring(function ($paymentGateway) {
|
||||
$paymentGateway->charge(2500, $paymentGateway->getValidTestToken());
|
||||
});
|
||||
|
||||
$this->assertCount(1, $newCharges);
|
||||
$this->assertEquals(2500, $newCharges->sum());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
function charges_with_an_invalid_payment_token_fail()
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user