12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <?php
- /**
- * @copyright Copyright (c) 2016 Joas Schilling <coding@schilljs.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- */
- namespace Test\RichObjectStrings;
- use OCP\RichObjectStrings\Definitions;
- use Test\TestCase;
- class DefinitionsTest extends TestCase {
- public function dataGetDefinition() {
- $definitions = new Definitions();
- $testsuite = [];
- foreach ($definitions->definitions as $type => $definition) {
- $testsuite[] = [$type, $definition];
- }
- return $testsuite;
- }
- /**
- * @expectedException \OCP\RichObjectStrings\InvalidObjectExeption
- * @expectedExceptionMessage Object type is undefined
- */
- public function testGetDefinitionNotExisting() {
- $definitions = new Definitions();
- $definitions->getDefinition('NotExistingType');
- }
- /**
- * @dataProvider dataGetDefinition
- * @param string $type
- * @param array $expected
- */
- public function testGetDefinition($type, array $expected) {
- $definitions = new Definitions();
- $definition = $definitions->getDefinition($type);
- $this->assertEquals($expected, $definition);
- $this->assertArrayHasKey('author', $definition);
- $this->assertNotEquals('', $definition['author'], 'Author of definition must not be empty');
- $this->assertArrayHasKey('app', $definition);
- $this->assertNotEquals('', $definition['app'], 'App of definition must not be empty');
- $this->assertArrayHasKey('since', $definition);
- $this->assertNotEmpty($definition['since'], 'Since of definition must not be empty');
- $this->assertArrayHasKey('parameters', $definition);
- $this->assertTrue(is_array($definition['parameters']), 'Parameters of definition must be of type array');
- $this->assertNotEmpty($definition['parameters'], 'Parameters of definition must not be empty');
- $this->assertArrayHasKey('id', $definition['parameters'], 'Parameter ID must be defined');
- $this->assertArrayHasKey('name', $definition['parameters'], 'Parameter name must be defined');
- foreach ($definition['parameters'] as $parameter => $data) {
- $this->validateParameter($parameter, $data);
- }
- }
- public function validateParameter($parameter, $data) {
- $this->assertTrue(is_array($data), 'Parameter ' . $parameter . ' is invalid');
- $this->assertArrayHasKey('since', $data);
- $this->assertNotEmpty($data['since'], 'Since of parameter ' . $parameter . ' must not be empty');
- $this->assertArrayHasKey('required', $data);
- $this->assertTrue(is_bool($data['required']), 'Required of parameter ' . $parameter . ' must be a boolean');
- if ($parameter === 'id' || $parameter === 'name') {
- $this->assertTrue($data['required'], 'Parameter ' . $parameter . ' must be required');
- }
- $this->assertArrayHasKey('description', $data);
- $this->assertNotEquals('', $data['description'], 'Description of parameter ' . $parameter . ' must not be empty');
- $this->assertArrayHasKey('example', $data);
- $this->assertNotEquals('', $data['example'], 'Example of parameter ' . $parameter . ' must not be empty');
- }
- }
|