123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- <?php
- /**
- * Copyright (c) 2013 Tom Needham <tom@owncloud.com>
- * This file is licensed under the Affero General Public License version 3 or
- * later.
- * See the COPYING-README file.
- */
- class Test_API extends PHPUnit_Framework_TestCase {
-
- // Helps build a response variable
- function buildResponse($shipped, $data, $code) {
- return array(
- 'shipped' => $shipped,
- 'response' => new OC_OCS_Result($data, $code),
- 'app' => uniqid('testapp_', true),
- );
- }
- // Validate details of the result
- function checkResult($result, $success) {
- // Check response is of correct type
- $this->assertInstanceOf('OC_OCS_Result', $result);
- // Check if it succeeded
- /** @var $result OC_OCS_Result */
- $this->assertEquals($success, $result->succeeded());
- }
- function dataProviderTestOneResult() {
- return array(
- array(100, true),
- array(101, true),
- array(997, false),
- );
- }
- /**
- * @dataProvider dataProviderTestOneResult
- *
- * @param $statusCode
- * @param $succeeded
- */
- public function testOneResult($statusCode, $succeeded) {
- // Setup some data arrays
- $data1 = array(
- 'users' => array(
- 'tom' => array(
- 'key' => 'value',
- ),
- 'frank' => array(
- 'key' => 'value',
- ),
- ));
- // Test merging one success result
- $response = $this->buildResponse(true, $data1, $statusCode);
- $result = OC_API::mergeResponses(array($response));
- $this->assertEquals($response['response'], $result);
- $this->checkResult($result, $succeeded);
- }
- function dataProviderTestMergeResponses() {
- return array(
- // Two shipped success results
- array(true, 100, true, 100, true),
- // Two shipped results, one success and one failure
- array(true, 100, true, 997, false),
- // Two shipped results, both failure
- array(true, 997, true, 997, false),
- // Two third party success results
- array(false, 100, false, 100, true),
- // Two third party results, one success and one failure
- array(false, 100, false, 997, false),
- // Two third party results, both failure
- array(false, 997, false, 997, false),
- // One of each, both success
- array(false, 100, true, 100, true),
- array(true, 100, false, 100, true),
- // One of each, both failure
- array(false, 997, true, 997, false),
- // One of each, shipped success
- array(false, 997, true, 100, true),
- // One of each, third party success
- array(false, 100, true, 997, false),
- );
- }
- /**
- * @dataProvider dataProviderTestMergeResponses
- *
- * Test the merging of multiple responses
- * @param $statusCode1
- * @param $statusCode2
- * @param $succeeded
- */
- public function testMultipleMergeResponses($shipped1, $statusCode1, $shipped2, $statusCode2, $succeeded){
- // Tests that app responses are merged correctly
- // Setup some data arrays
- $data1 = array(
- 'users' => array(
- 'tom' => array(
- 'key' => 'value',
- ),
- 'frank' => array(
- 'key' => 'value',
- ),
- ));
- $data2 = array(
- 'users' => array(
- 'tom' => array(
- 'key' => 'newvalue',
- ),
- 'jan' => array(
- 'key' => 'value',
- ),
- ));
- // Two shipped success results
- $result = OC_API::mergeResponses(array(
- $this->buildResponse($shipped1, $data1, $statusCode1),
- $this->buildResponse($shipped2, $data2, $statusCode2),
- ));
- $this->checkResult($result, $succeeded);
- $resultData = $result->getData();
- $this->assertArrayHasKey('jan', $resultData['users']);
- }
- }
|