diff options
Diffstat (limited to 'tests')
-rw-r--r-- | tests/lib/api.php | 191 |
1 files changed, 80 insertions, 111 deletions
diff --git a/tests/lib/api.php b/tests/lib/api.php index a1f8d2459a0..95d75f15311 100644 --- a/tests/lib/api.php +++ b/tests/lib/api.php @@ -9,7 +9,7 @@ class Test_API extends PHPUnit_Framework_TestCase { // Helps build a response variable - public function buildResponse($shipped=true, $data=null, $code=100) { + function buildResponse($shipped, $data, $code) { return array( 'shipped' => $shipped, 'response' => new OC_OCS_Result($data, $code), @@ -18,142 +18,111 @@ class Test_API extends PHPUnit_Framework_TestCase { } // Validate details of the result - public function checkResult($result, $success=true) { + function checkResult($result, $success) { // Check response is of correct type - $this->assertEquals('OC_OCS_Result', get_class($result)); - // CHeck if it succeeded + $this->assertInstanceOf('OC_OCS_Result', $result); + // Check if it succeeded + /** @var $result OC_OCS_Result */ $this->assertEquals($success, $result->succeeded()); } - // Test the merging of multiple responses - public function testMergeResponses(){ + 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', - ), + ), )); - // Test merging one success result - $response = $this->buildResponse(true, $data1); - $result = OC_API::mergeResponses(array($response)); - $this->assertEquals($response['response'], $result); - $this->checkResult($result); - - $response = $this->buildResponse(true, $data1, 101); - $result = OC_API::mergeResponses(array($response)); - $this->assertEquals($response['response'], $result); - $this->checkResult($result); - - $response = $this->buildResponse(true, $data1, 997); - $result = OC_API::mergeResponses(array($response)); - $this->assertEquals($response['response'], $result); - $this->checkResult($result, false); // Two shipped success results $result = OC_API::mergeResponses(array( - $this->buildResponse(true, $data1), - $this->buildResponse(true, $data2), - )); - $this->checkResult($result); + $this->buildResponse($shipped1, $data1, $statusCode1), + $this->buildResponse($shipped2, $data2, $statusCode2), + )); + $this->checkResult($result, $succeeded); $resultData = $result->getData(); $this->assertArrayHasKey('jan', $resultData['users']); - - // Two shipped results, one success and one failure - $result = OC_API::mergeResponses(array( - $this->buildResponse(true, $data1), - $this->buildResponse(true, $data2, 997), - )); - $this->checkResult($result, false); - $resultData = $result->getData(); - $this->assertArrayHasKey('jan', $resultData['users']); - - // Two shipped results, both failure - $result = OC_API::mergeResponses(array( - $this->buildResponse(true, $data1, 997), - $this->buildResponse(true, $data2, 997), - )); - $this->checkResult($result, false); - $resultData = $result->getData(); - $this->assertArrayHasKey('jan', $resultData['users']); - - // Two third party success results - $result = OC_API::mergeResponses(array( - $this->buildResponse(false, $data1), - $this->buildResponse(false, $data2), - )); - $this->checkResult($result); - $resultData = $result->getData(); - $this->assertArrayHasKey('jan', $resultData['users']); - - // Two third party results, one success and one failure - $result = OC_API::mergeResponses(array( - $this->buildResponse(false, $data1), - $this->buildResponse(false, $data2, 997), - )); - $this->checkResult($result, false); - $resultData = $result->getData(); - $this->assertArrayHasKey('jan', $resultData['users']); - - // Two third party results, both failure - $result = OC_API::mergeResponses(array( - $this->buildResponse(false, $data1, 997), - $this->buildResponse(false, $data2, 997), - )); - $this->checkResult($result, false); - $resultData = $result->getData(); - $this->assertArrayHasKey('jan', $resultData['users']); - - // One of each, both success - $result = OC_API::mergeResponses(array( - $this->buildResponse(false, $data1), - $this->buildResponse(true, $data2), - )); - $this->checkResult($result); - $resultData = $result->getData(); - $this->assertArrayHasKey('jan', $resultData['users']); - - // One of each, both failure - $result = OC_API::mergeResponses(array( - $this->buildResponse(false, $data1, 997), - $this->buildResponse(true, $data2, 997), - )); - $this->checkResult($result, false); - $resultData = $result->getData(); - $this->assertArrayHasKey('jan', $resultData['users']); - - // One of each, shipped success - $result = OC_API::mergeResponses(array( - $this->buildResponse(false, $data1, 997), - $this->buildResponse(true, $data2), - )); - $this->checkResult($result); - $resultData = $result->getData(); - $this->assertArrayHasKey('jan', $resultData['users']); - - // One of each, third party success - $result = OC_API::mergeResponses(array( - $this->buildResponse(false, $data1), - $this->buildResponse(true, $data2, 997), - )); - $this->checkResult($result, false); - $resultData = $result->getData(); - $this->assertArrayHasKey('jan', $resultData['users']); - } } |