Blame view

sources/tests/lib/api.php 3.32 KB
31b7f2792   Kload   Upgrade to ownclo...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
  <?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']);
  	}
  
  }