%PDF- %PDF-
Direktori : /home/eirtvhdf/logodowntown.com/root_stripe/stripe/tests/Stripe/ |
Current File : /home/eirtvhdf/logodowntown.com/root_stripe/stripe/tests/Stripe/StripeObjectTest.php |
<?php namespace Stripe; class StripeObjectTest extends TestCase { /** * @before */ public function setUpReflectors() { // Sets up reflectors needed by some tests to access protected or // private attributes. // This is used to invoke the `deepCopy` protected function $this->deepCopyReflector = new \ReflectionMethod('Stripe\\StripeObject', 'deepCopy'); $this->deepCopyReflector->setAccessible(true); // This is used to access the `_opts` protected variable $this->optsReflector = new \ReflectionProperty('Stripe\\StripeObject', '_opts'); $this->optsReflector->setAccessible(true); } public function testArrayAccessorsSemantics() { $s = new StripeObject(); $s['foo'] = 'a'; $this->assertSame($s['foo'], 'a'); $this->assertTrue(isset($s['foo'])); unset($s['foo']); $this->assertFalse(isset($s['foo'])); } public function testNormalAccessorsSemantics() { $s = new StripeObject(); $s->foo = 'a'; $this->assertSame($s->foo, 'a'); $this->assertTrue(isset($s->foo)); unset($s->foo); $this->assertFalse(isset($s->foo)); } public function testArrayAccessorsMatchNormalAccessors() { $s = new StripeObject(); $s->foo = 'a'; $this->assertSame($s['foo'], 'a'); $s['bar'] = 'b'; $this->assertSame($s->bar, 'b'); } public function testCount() { $s = new StripeObject(); $this->assertSame(0, count($s)); $s['key1'] = 'value1'; $this->assertSame(1, count($s)); $s['key2'] = 'value2'; $this->assertSame(2, count($s)); unset($s['key1']); $this->assertSame(1, count($s)); } public function testKeys() { $s = new StripeObject(); $s->foo = 'bar'; $this->assertSame($s->keys(), ['foo']); } public function testValues() { $s = new StripeObject(); $s->foo = 'bar'; $this->assertSame($s->values(), ['bar']); } public function testToArray() { $s = new StripeObject(); $s->foo = 'a'; $converted = $s->__toArray(); $this->assertInternalType('array', $converted); $this->assertArrayHasKey('foo', $converted); $this->assertEquals('a', $converted['foo']); } public function testRecursiveToArray() { $s = new StripeObject(); $z = new StripeObject(); $s->child = $z; $z->foo = 'a'; $converted = $s->__toArray(true); $this->assertInternalType('array', $converted); $this->assertArrayHasKey('child', $converted); $this->assertInternalType('array', $converted['child']); $this->assertArrayHasKey('foo', $converted['child']); $this->assertEquals('a', $converted['child']['foo']); } public function testNonexistentProperty() { $s = new StripeObject(); $this->assertNull($s->nonexistent); } public function testPropertyDoesNotExists() { $s = new StripeObject(); $this->assertNull($s['nonexistent']); } public function testJsonEncode() { $s = new StripeObject(); $s->foo = 'a'; $this->assertEquals('{"foo":"a"}', json_encode($s)); } public function testToString() { $s = new StripeObject(); $s->foo = 'a'; $string = $s->__toString(); $expected = <<<EOS Stripe\StripeObject JSON: { "foo": "a" } EOS; $this->assertEquals($expected, $string); } public function testReplaceNewNestedUpdatable() { $s = new StripeObject(); $s->metadata = ['bar']; $this->assertSame($s->metadata, ['bar']); $s->metadata = ['baz', 'qux']; $this->assertSame($s->metadata, ['baz', 'qux']); } /** * @expectedException \InvalidArgumentException */ public function testSetPermanentAttribute() { $s = new StripeObject(); $s->id = 'abc_123'; } /** * @expectedException \InvalidArgumentException */ public function testSetEmptyStringValue() { $s = new StripeObject(); $s->foo = ''; } public function testSerializeParametersOnEmptyObject() { $obj = StripeObject::constructFrom([]); $this->assertSame([], $obj->serializeParameters()); } public function testSerializeParametersOnNewObjectWithSubObject() { $obj = new StripeObject(); $obj->metadata = ['foo' => 'bar']; $this->assertSame(['metadata' => ['foo' => 'bar']], $obj->serializeParameters()); } public function testSerializeParametersOnBasicObject() { $obj = StripeObject::constructFrom(['foo' => null]); $obj->updateAttributes(['foo' => 'bar']); $this->assertSame(['foo' => 'bar'], $obj->serializeParameters()); } public function testSerializeParametersOnMoreComplexObject() { $obj = StripeObject::constructFrom([ 'foo' => StripeObject::constructFrom([ 'bar' => null, 'baz' => null, ]), ]); $obj->foo->bar = 'newbar'; $this->assertSame(['foo' => ['bar' => 'newbar']], $obj->serializeParameters()); } public function testSerializeParametersOnArray() { $obj = StripeObject::constructFrom([ 'foo' => null, ]); $obj->foo = ['new-value']; $this->assertSame(['foo' => ['new-value']], $obj->serializeParameters()); } public function testSerializeParametersOnArrayThatShortens() { $obj = StripeObject::constructFrom([ 'foo' => ['0-index', '1-index', '2-index'], ]); $obj->foo = ['new-value']; $this->assertSame(['foo' => ['new-value']], $obj->serializeParameters()); } public function testSerializeParametersOnArrayThatLengthens() { $obj = StripeObject::constructFrom([ 'foo' => ['0-index', '1-index', '2-index'], ]); $obj->foo = array_fill(0, 4, 'new-value'); $this->assertSame(['foo' => array_fill(0, 4, 'new-value')], $obj->serializeParameters()); } public function testSerializeParametersOnArrayOfHashes() { $obj = StripeObject::constructFrom(['foo' => null]); $obj->foo = [ StripeObject::constructFrom(['bar' => null]), ]; $obj->foo[0]->bar = 'baz'; $this->assertSame(['foo' => [['bar' => 'baz']]], $obj->serializeParameters()); } public function testSerializeParametersDoesNotIncludeUnchangedValues() { $obj = StripeObject::constructFrom([ 'foo' => null, ]); $this->assertSame([], $obj->serializeParameters()); } public function testSerializeParametersOnUnchangedArray() { $obj = StripeObject::constructFrom([ 'foo' => ['0-index', '1-index', '2-index'], ]); $obj->foo = ['0-index', '1-index', '2-index']; $this->assertSame([], $obj->serializeParameters()); } public function testSerializeParametersWithStripeObject() { $obj = StripeObject::constructFrom([]); $obj->metadata = StripeObject::constructFrom(['foo' => 'bar']); $serialized = $obj->serializeParameters(); $this->assertSame(['foo' => 'bar'], $serialized['metadata']); } public function testSerializeParametersOnReplacedStripeObject() { $obj = StripeObject::constructFrom([ 'source' => StripeObject::constructFrom(['bar' => 'foo']), ]); $obj->source = StripeObject::constructFrom(['baz' => 'foo']); $serialized = $obj->serializeParameters(); $this->assertSame(['baz' => 'foo'], $serialized['source']); } public function testSerializeParametersOnReplacedStripeObjectWhichIsMetadata() { $obj = StripeObject::constructFrom([ 'metadata' => StripeObject::constructFrom(['bar' => 'foo']), ]); $obj->metadata = StripeObject::constructFrom(['baz' => 'foo']); $serialized = $obj->serializeParameters(); $this->assertSame(['bar' => '', 'baz' => 'foo'], $serialized['metadata']); } public function testSerializeParametersOnArrayOfStripeObjects() { $obj = StripeObject::constructFrom([]); $obj->metadata = [ StripeObject::constructFrom(['foo' => 'bar']), ]; $serialized = $obj->serializeParameters(); $this->assertSame([['foo' => 'bar']], $serialized['metadata']); } public function testSerializeParametersOnSetApiResource() { $customer = Customer::constructFrom(['id' => 'cus_123']); $obj = StripeObject::constructFrom([]); // the key here is that the property is set explicitly (and therefore // marked as unsaved), which is why it gets included below $obj->customer = $customer; $serialized = $obj->serializeParameters(); $this->assertSame(['customer' => $customer], $serialized); } public function testSerializeParametersOnNotSetApiResource() { $customer = Customer::constructFrom(['id' => 'cus_123']); $obj = StripeObject::constructFrom(['customer' => $customer]); $serialized = $obj->serializeParameters(); $this->assertSame([], $serialized); } public function testSerializeParametersOnApiResourceFlaggedWithSaveWithParent() { $customer = Customer::constructFrom(['id' => 'cus_123']); $customer->saveWithParent = true; $obj = StripeObject::constructFrom(['customer' => $customer]); $serialized = $obj->serializeParameters(); $this->assertSame(['customer' => []], $serialized); } public function testSerializeParametersRaisesExceotionOnOtherEmbeddedApiResources() { // This customer doesn't have an ID and therefore the library doesn't know // what to do with it and throws an InvalidArgumentException because it's // probably not what the user expected to happen. $customer = Customer::constructFrom([]); $obj = StripeObject::constructFrom([]); $obj->customer = $customer; try { $serialized = $obj->serializeParameters(); $this->fail("Did not raise error"); } catch (\InvalidArgumentException $e) { $this->assertSame( "Cannot save property `customer` containing an API resource of type Stripe\Customer. " . "It doesn't appear to be persisted and is not marked as `saveWithParent`.", $e->getMessage() ); } catch (\Exception $e) { $this->fail("Unexpected exception: " . get_class($e)); } } public function testSerializeParametersForce() { $obj = StripeObject::constructFrom([ 'id' => 'id', 'metadata' => StripeObject::constructFrom([ 'bar' => 'foo', ]), ]); $serialized = $obj->serializeParameters(true); $this->assertSame(['id' => 'id', 'metadata' => ['bar' => 'foo']], $serialized); } public function testDirty() { $obj = StripeObject::constructFrom([ 'id' => 'id', 'metadata' => StripeObject::constructFrom([ 'bar' => 'foo', ]), ]); // note that `$force` and `dirty()` are for different things, but are // functionally equivalent $obj->dirty(); $serialized = $obj->serializeParameters(); $this->assertSame(['id' => 'id', 'metadata' => ['bar' => 'foo']], $serialized); } public function testDeepCopy() { $opts = [ "api_base" => Stripe::$apiBase, "api_key" => "apikey", ]; $values = [ "id" => 1, "name" => "Stripe", "arr" => [ StripeObject::constructFrom(["id" => "index0"], $opts), "index1", 2, ], "map" => [ "0" => StripeObject::constructFrom(["id" => "index0"], $opts), "1" => "index1", "2" => 2 ], ]; $copyValues = $this->deepCopyReflector->invoke(null, $values); // we can't compare the hashes directly because they have embedded // objects which are different from each other $this->assertEquals($values["id"], $copyValues["id"]); $this->assertEquals($values["name"], $copyValues["name"]); $this->assertEquals(count($values["arr"]), count($copyValues["arr"])); // internal values of the copied StripeObject should be the same, // but the object itself should be new (hence the assertNotSame) $this->assertEquals($values["arr"][0]["id"], $copyValues["arr"][0]["id"]); $this->assertNotSame($values["arr"][0], $copyValues["arr"][0]); // likewise, the Util\RequestOptions instance in _opts should have // copied values but be a new instance $this->assertEquals( $this->optsReflector->getValue($values["arr"][0]), $this->optsReflector->getValue($copyValues["arr"][0]) ); $this->assertNotSame( $this->optsReflector->getValue($values["arr"][0]), $this->optsReflector->getValue($copyValues["arr"][0]) ); // scalars however, can be compared $this->assertEquals($values["arr"][1], $copyValues["arr"][1]); $this->assertEquals($values["arr"][2], $copyValues["arr"][2]); // and a similar story with the hash $this->assertEquals($values["map"]["0"]["id"], $copyValues["map"]["0"]["id"]); $this->assertNotSame($values["map"]["0"], $copyValues["map"]["0"]); $this->assertNotSame( $this->optsReflector->getValue($values["arr"][0]), $this->optsReflector->getValue($copyValues["arr"][0]) ); $this->assertEquals( $this->optsReflector->getValue($values["map"]["0"]), $this->optsReflector->getValue($copyValues["map"]["0"]) ); $this->assertNotSame( $this->optsReflector->getValue($values["map"]["0"]), $this->optsReflector->getValue($copyValues["map"]["0"]) ); $this->assertEquals($values["map"]["1"], $copyValues["map"]["1"]); $this->assertEquals($values["map"]["2"], $copyValues["map"]["2"]); } public function testDeepCopyMaintainClass() { $charge = Charge::constructFrom(["id" => 1], null); $copyCharge = $this->deepCopyReflector->invoke(null, $charge); $this->assertEquals(get_class($charge), get_class($copyCharge)); } public function testIsDeleted() { $obj = StripeObject::constructFrom([]); $this->assertFalse($obj->isDeleted()); $obj = StripeObject::constructFrom(['deleted' => false]); $this->assertFalse($obj->isDeleted()); $obj = StripeObject::constructFrom(['deleted' => true]); $this->assertTrue($obj->isDeleted()); } }