Merge pull request #2052 from nextcloud/ros-definitions-as-php-class
Use a php class for the definitions to avoid loading problemspull/2064/head
commit
eadccc239a
@ -0,0 +1,296 @@ |
||||
<?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 OCP\RichObjectStrings; |
||||
|
||||
|
||||
/** |
||||
* Class Definitions |
||||
* |
||||
* @package OCP\RichObjectStrings |
||||
* @since 9.2.0 |
||||
*/ |
||||
class Definitions { |
||||
/** |
||||
* @var array |
||||
* @since 9.2.0 |
||||
*/ |
||||
public $definitions = [ |
||||
'addressbook' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'dav', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The id used to identify the addressbook on the instance', |
||||
'example' => '42', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The display name of the addressbook which should be used in the visual representation', |
||||
'example' => 'Contacts', |
||||
], |
||||
], |
||||
], |
||||
'addressbook-contact' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'dav', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The id used to identify the contact on the instance', |
||||
'example' => '42', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The display name of the contact which should be used in the visual representation', |
||||
'example' => 'John Doe', |
||||
], |
||||
], |
||||
], |
||||
'announcement' => [ |
||||
'author' => 'Joas Schilling', |
||||
'app' => 'announcementcenter', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, 'description' => 'The id used to identify the announcement on the instance', |
||||
'example' => '42', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The announcement subject which should be used in the visual representation', |
||||
'example' => 'file.txt', |
||||
], |
||||
'link' => [ |
||||
'since' => '9.2.0', |
||||
'required' => false, |
||||
'description' => 'The full URL to the file', |
||||
'example' => 'http://localhost/index.php/apps/announcements/#23', |
||||
], |
||||
], |
||||
], |
||||
'calendar' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'dav', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The id used to identify the calendar on the instance', |
||||
'example' => '42', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The display name of the calendar which should be used in the visual representation', |
||||
'example' => 'Personal', |
||||
], |
||||
], |
||||
], |
||||
'calendar-event' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'dav', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The id used to identify the event on the instance', |
||||
'example' => '42', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The display name of the event which should be used in the visual representation', |
||||
'example' => 'Workout', |
||||
], |
||||
], |
||||
], |
||||
'email' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'sharebymail', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The mail-address used to identify the event on the instance', |
||||
'example' => 'test@localhost', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The display name of a matching contact or the email (fallback) which should be used in the visual representation', |
||||
'example' => 'Foo Bar', |
||||
], |
||||
], |
||||
], |
||||
'file' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'dav', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The id used to identify the file on the instance', |
||||
'example' => '42', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The file name which should be used in the visual representation', |
||||
'example' => 'file.txt', |
||||
], |
||||
'path' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The full path of the file for the user', |
||||
'example' => 'path/to/file.txt', |
||||
], |
||||
'link' => [ |
||||
'since' => '9.2.0', |
||||
'required' => false, |
||||
'description' => 'The full URL to the file', |
||||
'example' => 'http://localhost/index.php/f/42', |
||||
], |
||||
], |
||||
], |
||||
'pending-federated-share' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'dav', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The id used to identify the federated share on the instance', |
||||
'example' => '42', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The name of the shared item which should be used in the visual representation', |
||||
'example' => 'file.txt', |
||||
], |
||||
], |
||||
], |
||||
'systemtag' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'core', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The id used to identify the systemtag on the instance', |
||||
'example' => '23', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The display name of the systemtag which should be used in the visual representation', |
||||
'example' => 'Project 1', |
||||
], |
||||
'visibility' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'If the user can see the systemtag', |
||||
'example' => '1', |
||||
], |
||||
'assignable' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'If the user can assign the systemtag', |
||||
'example' => '0', |
||||
], |
||||
], |
||||
], |
||||
'user' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'core', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The id used to identify the user on the instance', |
||||
'example' => 'johndoe', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The display name of the user which should be used in the visual representation', |
||||
'example' => 'John Doe', |
||||
], |
||||
'server' => [ |
||||
'since' => '9.2.0', |
||||
'required' => false, |
||||
'description' => 'The URL of the instance the user lives on', |
||||
'example' => 'localhost', |
||||
], |
||||
], |
||||
], |
||||
'user-group' => [ |
||||
'author' => 'Nextcloud', |
||||
'app' => 'core', |
||||
'since' => '9.2.0', |
||||
'parameters' => [ |
||||
'id' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The id used to identify the group on the instance', |
||||
'example' => 'supportteam', |
||||
], |
||||
'name' => [ |
||||
'since' => '9.2.0', |
||||
'required' => true, |
||||
'description' => 'The display name of the group which should be used in the visual representation', |
||||
'example' => 'Support Team', |
||||
], |
||||
], |
||||
], |
||||
]; |
||||
|
||||
/** |
||||
* @param string $type |
||||
* @return array |
||||
* @throws InvalidObjectExeption |
||||
* @since 9.2.0 |
||||
*/ |
||||
public function getDefinition($type) { |
||||
if (isset($this->definitions[$type])) { |
||||
return $this->definitions[$type]; |
||||
} |
||||
|
||||
throw new InvalidObjectExeption('Object type is undefined'); |
||||
} |
||||
} |
@ -1,247 +0,0 @@ |
||||
{ |
||||
"addressbook": { |
||||
"author": "Nextcloud", |
||||
"app": "dav", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the addressbook on the instance", |
||||
"example": "42" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The display name of the addressbook which should be used in the visual representation", |
||||
"example": "Contacts" |
||||
} |
||||
} |
||||
}, |
||||
"addressbook-contact": { |
||||
"author": "Nextcloud", |
||||
"app": "dav", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the contact on the instance", |
||||
"example": "42" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The display name of the contact which should be used in the visual representation", |
||||
"example": "John Doe" |
||||
} |
||||
} |
||||
}, |
||||
"announcement": { |
||||
"author": "Joas Schilling", |
||||
"app": "announcementcenter", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the announcement on the instance", |
||||
"example": "42" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The announcement subject which should be used in the visual representation", |
||||
"example": "file.txt" |
||||
}, |
||||
"link": { |
||||
"since": "9.2.0", |
||||
"required": false, |
||||
"description": "The full URL to the file", |
||||
"example": "http://localhost/index.php/apps/announcements/#23" |
||||
} |
||||
} |
||||
}, |
||||
"calendar": { |
||||
"author": "Nextcloud", |
||||
"app": "dav", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the calendar on the instance", |
||||
"example": "42" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The display name of the calendar which should be used in the visual representation", |
||||
"example": "Personal" |
||||
} |
||||
} |
||||
}, |
||||
"calendar-event": { |
||||
"author": "Nextcloud", |
||||
"app": "dav", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the event on the instance", |
||||
"example": "42" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The display name of the event which should be used in the visual representation", |
||||
"example": "Workout" |
||||
} |
||||
} |
||||
}, |
||||
"file": { |
||||
"author": "Nextcloud", |
||||
"app": "dav", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the file on the instance", |
||||
"example": "42" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The file name which should be used in the visual representation", |
||||
"example": "file.txt" |
||||
}, |
||||
"path": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The full path of the file for the user", |
||||
"example": "path/to/file.txt" |
||||
}, |
||||
"link": { |
||||
"since": "9.2.0", |
||||
"required": false, |
||||
"description": "The full URL to the file", |
||||
"example": "http://localhost/index.php/f/42" |
||||
} |
||||
} |
||||
}, |
||||
"pending-federated-share": { |
||||
"author": "Nextcloud", |
||||
"app": "dav", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the federated share on the instance", |
||||
"example": "42" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The name of the shared item which should be used in the visual representation", |
||||
"example": "file.txt" |
||||
} |
||||
} |
||||
}, |
||||
"systemtag": { |
||||
"author": "Nextcloud", |
||||
"app": "core", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the systemtag on the instance", |
||||
"example": "23" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The display name of the systemtag which should be used in the visual representation", |
||||
"example": "Project 1" |
||||
}, |
||||
"visibility": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "If the user can see the systemtag", |
||||
"example": "1" |
||||
}, |
||||
"assignable": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "If the user can assign the systemtag", |
||||
"example": "0" |
||||
} |
||||
} |
||||
}, |
||||
"user": { |
||||
"author": "Nextcloud", |
||||
"app": "core", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the user on the instance", |
||||
"example": "johndoe" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The display name of the user which should be used in the visual representation", |
||||
"example": "John Doe" |
||||
}, |
||||
"server": { |
||||
"since": "9.2.0", |
||||
"required": false, |
||||
"description": "The URL of the instance the user lives on", |
||||
"example": "localhost" |
||||
} |
||||
} |
||||
}, |
||||
"user-group": { |
||||
"author": "Nextcloud", |
||||
"app": "core", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The id used to identify the group on the instance", |
||||
"example": "supportteam" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The display name of the group which should be used in the visual representation", |
||||
"example": "Support Team" |
||||
} |
||||
} |
||||
}, |
||||
"email": { |
||||
"author": "Nextcloud", |
||||
"app": "sharebymail", |
||||
"since": "9.2.0", |
||||
"parameters": { |
||||
"id": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The mail-address used to identify the event on the instance", |
||||
"example": "test@localhost" |
||||
}, |
||||
"name": { |
||||
"since": "9.2.0", |
||||
"required": true, |
||||
"description": "The display name of a matching contact or the email (fallback) which should be used in the visual representation", |
||||
"example": "Foo Bar" |
||||
} |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,93 @@ |
||||
<?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'); |
||||
|
||||
} |
||||
} |
Loading…
Reference in new issue