<?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; } }