website/files/stripe/tests/TestCase.php

264 lines
7.4 KiB
PHP

<?php
namespace Stripe;
/**
* Base class for Stripe test cases, provides some utility methods for creating
* objects.
*/
class TestCase extends \PHPUnit_Framework_TestCase
{
const API_KEY = 'tGN0bIwXnHdwOa85VABjPdSn8nWY7G7I';
private $mock;
protected static function authorizeFromEnv()
{
$apiKey = getenv('STRIPE_API_KEY');
if (!$apiKey) {
$apiKey = self::API_KEY;
}
Stripe::setApiKey($apiKey);
}
protected function setUp()
{
ApiRequestor::setHttpClient(HttpClient\CurlClient::instance());
// Peg the API version so that it can be varied independently of the
// one set on the test account.
Stripe::setApiVersion('2017-04-06');
$this->mock = null;
$this->call = 0;
}
protected function mockRequest($method, $path, $params = array(), $return = array('id' => 'myId'), $rcode = 200)
{
$mock = $this->setUpMockRequest();
$mock->expects($this->at($this->call++))
->method('request')
->with(strtolower($method), 'https://api.stripe.com' . $path, $this->anything(), $params, false)
->willReturn(array(json_encode($return), $rcode, array()));
}
private function setUpMockRequest()
{
if (!$this->mock) {
self::authorizeFromEnv();
$this->mock = $this->getMock('\Stripe\HttpClient\ClientInterface');
ApiRequestor::setHttpClient($this->mock);
}
return $this->mock;
}
/**
* Create a valid test charge.
*/
protected static function createTestCharge(array $attributes = array())
{
self::authorizeFromEnv();
return Charge::create(
$attributes + array(
'amount' => 2000,
'currency' => 'usd',
'description' => 'Charge for test@example.com',
'card' => 'tok_visa',
)
);
}
/**
* Create a valid test transfer.
*/
protected static function createTestTransfer(array $attributes = array(), $opts = null)
{
self::authorizeFromEnv();
$recipient = self::createTestRecipient();
return Transfer::create(
$attributes + array(
'amount' => 2000,
'currency' => 'usd',
'description' => 'Transfer to test@example.com',
'recipient' => $recipient->id
),
$opts
);
}
/**
* Create a valid test customer.
*/
protected static function createTestCustomer(array $attributes = array())
{
self::authorizeFromEnv();
return Customer::create(
$attributes + array(
'card' => 'tok_visa',
)
);
}
/**
* Create a valid test recipient
*/
protected static function createTestRecipient(array $attributes = array())
{
self::authorizeFromEnv();
return Recipient::create(
$attributes + array(
'name' => 'PHP Test',
'type' => 'individual',
'tax_id' => '000000000',
'bank_account' => array(
'country' => 'US',
'routing_number' => '110000000',
'account_number' => '000123456789'
),
)
);
}
/**
* Create a test account
*/
protected static function createTestAccount(array $attributes = array())
{
self::authorizeFromEnv();
return Account::create(
$attributes + array(
'managed' => false,
'country' => 'US',
'email' => self::generateRandomEmail(),
)
);
}
/**
* Create a test account
*/
protected static function createTestManagedAccount(array $attributes = array())
{
self::authorizeFromEnv();
return Account::create(
$attributes + array(
'managed' => true,
'country' => 'US',
'external_account' => array(
'object' => 'bank_account',
'country' => 'US',
'currency' => 'usd',
'routing_number' => '110000000',
'account_number' => '000123456789'
),
'legal_entity' => array(
'type' => 'individual',
'personal_id_number' => '000000000',
'type' => 'individual',
'dob' => array('year' => '1980', 'month' => '01', 'day' => '01'),
'first_name' => 'John',
'last_name' => 'Doe',
'address' => array(
'line1' => '1234 Main Street',
'postal_code' => '94110',
'city' => 'San Francisco'
),
'personal_address' => array(
'line1' => '1234 Main Street',
'postal_code' => '94110',
'city' => 'San Francisco'
)
),
'tos_acceptance' => array('date' => time(), 'ip' => '127.0.0.1')
)
);
}
/**
* Verify that a plan with a given ID exists, or create a new one if it does
* not.
*/
protected static function retrieveOrCreatePlan($id)
{
self::authorizeFromEnv();
try {
$plan = Plan::retrieve($id);
} catch (Error\InvalidRequest $exception) {
$plan = Plan::create(
array(
'id' => $id,
'amount' => 0,
'currency' => 'usd',
'interval' => 'month',
'name' => 'Gold Test Plan',
)
);
}
}
/**
* Verify that a coupon with a given ID exists, or create a new one if it
* does not.
*/
protected static function retrieveOrCreateCoupon($id)
{
self::authorizeFromEnv();
try {
$coupon = Coupon::retrieve($id);
} catch (Error\InvalidRequest $exception) {
$coupon = Coupon::create(
array(
'id' => $id,
'duration' => 'forever',
'percent_off' => 25,
)
);
}
}
/**
* Generate a semi-random string
*/
protected static function generateRandomString($length = 24)
{
$characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTU';
$charactersLength = strlen($characters);
$randomString = '';
for ($i = 0; $i < $length; $i++) {
$randomString .= $characters[rand(0, $charactersLength - 1)];
}
return $randomString;
}
/**
* Generate a semi-random email.
*/
protected static function generateRandomEmail()
{
return 'dev-platform-bots+php-'.self::generateRandomString(12).'@stripe.com';
}
protected static function createTestBitcoinReceiver($email)
{
$receiver = BitcoinReceiver::create(
array(
'amount' => 100,
'currency' => 'usd',
'description' => 'some details',
'email' => $email
)
);
return $receiver;
}
}