/** * Test #13. SYNCH request write new object. */ public function testSynchPut() { global $testTripId1, $testReferenceId1, $testUserId1; global $synchAuthToken; $this->assertEquals(0, $this->countTestRows()); $data = array('tripId' => $testTripId1, 'referenceId' => $testReferenceId1, 'userId' => $testUserId1, 'created' => '2015-10-01', 'updated' => '2015-10-02', 'type' => '-type-1', 'deleted' => 'Y', 'hash' => 'forced hash'); $result = putApi('synchFeedback.php', $data, $synchAuthToken); $this->assertEquals(RESPONSE_SUCCESS, $result['resultCode']); $this->assertEquals(1, $this->countTestRows()); $object = new Feedback($testTripId1, $testReferenceId1, $testUserId1); $this->assertEquals('2015-10-01 00:00:00.000000', $object->getCreated()); $this->assertEquals('2015-10-02 00:00:00.000000', $object->getUpdated()); $this->assertEquals('-type-1', $object->getType()); $this->assertEquals("Y", $object->getDeleted()); $this->assertEquals('forced hash', $object->getHash()); }
/** * test #14. * Overriding automatic attributes using a future date. Because * a future date is used, the record can no longer be changed after * it was saved. * @depends testSaveEmptyObject * @depends testSetAttributes * @depends testUpdate * @depends testOverrideAutomaticAttributesNewRecord */ public function testOverrideAutomaticAttributesFutureDate() { global $testTripId1, $testReferenceId1, $testUserId1; // Create the object, which automatically gets the current date $object = new Feedback($testTripId1, $testReferenceId1, $testUserId1); $object->setType('like'); $object->setDeleted('Y'); $this->assertTrue($object->save()); $this->assertEquals(1, $this->countTestRows()); $originalCreated = $object->getCreated(); $originalUpdated = $object->getUpdated(); $originalHash = $object->getHash(); // Change the object with different values, using a guaranteed // future date for the Created and Updated fields. Note that // the mySQL timestamp values allow for dates up to January 19, // 2038. Select as the future date for this test January 18, 2038 // values after first save are unchanged $object->setCreated('2038-01-18 10:10:10.000000'); $object->setUpdated('2038-01-18 10:10:11.000000'); $object->setType('plus'); $object->setDeleted('N'); $object->setHash('future date hash'); // Check the values before saving $this->assertEquals($testTripId1, $object->getTripId()); $this->assertEquals($testReferenceId1, $object->getReferenceId()); $this->assertEquals($testUserId1, $object->getUserId()); $this->assertEquals('2038-01-18 10:10:10.000000', $object->getCreated()); $this->assertEquals('2038-01-18 10:10:11.000000', $object->getUpdated()); $this->assertEquals('plus', $object->getType()); $this->assertEquals('N', $object->getDeleted()); $this->assertEquals('future date hash', $object->getHash()); // update the record, this adds a row in the database $this->assertTrue($object->save()); $this->assertEquals(2, $this->countTestRows()); // after the update, the information has been saved $this->assertEquals($testTripId1, $object->getTripId()); $this->assertEquals($testReferenceId1, $object->getReferenceId()); $this->assertEquals($testUserId1, $object->getUserId()); $this->assertEquals('2038-01-18 10:10:10.000000', $object->getCreated()); $this->assertEquals('2038-01-18 10:10:11.000000', $object->getUpdated()); $this->assertEquals('plus', $object->getType()); $this->assertEquals('N', $object->getDeleted()); $this->assertEquals('future date hash', $object->getHash()); // Try to update the record. This will add a row in the database $object->setType('hugs'); $object->setDeleted('Y'); $this->assertTrue($object->save()); $this->assertEquals(3, $this->countTestRows()); // but the new information is not saved. The previously saved // information cannot be overwritten without manually setting the // updated field. $this->assertEquals($testTripId1, $object->getTripId()); $this->assertEquals($testReferenceId1, $object->getReferenceId()); $this->assertEquals($testUserId1, $object->getUserId()); $this->assertEquals('2038-01-18 10:10:10.000000', $object->getCreated()); $this->assertEquals('2038-01-18 10:10:11.000000', $object->getUpdated()); $this->assertEquals('plus', $object->getType()); $this->assertEquals('N', $object->getDeleted()); // Note: this will FAIL in the current implementation! //$this->assertEquals('future date hash', $object->getHash()); }
if (!$auth->canGetFeedback($tripId, $referenceId)) { $response = errorResponse(RESPONSE_UNAUTHORIZED); } else { if ($userId === '') { // Request for a list $list = Feedback::getList($tripId, $referenceId); $response = successResponse(); $response['tripId'] = $tripId; $response['referenceId'] = $referenceId; $response['list'] = $list; } else { $object = new Feedback($tripId, $referenceId, $userId); if ($object->getCreated() === null) { $response = errorResponse(RESPONSE_NOT_FOUND); } else { $response = successResponse(); $response['tripId'] = $object->getTripId(); $response['referenceId'] = $object->getReferenceId(); $response['userId'] = $object->getUserId(); $response['created'] = $object->getCreated(); $response['updated'] = $object->getUpdated(); $response['type'] = $object->getType(); $response['deleted'] = $object->getDeleted(); } } } } } else { $response = errorResponse(RESPONSE_METHOD_NOT_ALLOWED, 'Must use GET method'); } echo json_encode($response);