Start implementing Trello API service
Implement name of system to import Implement need validate data Fix allowed system list Start implementing Trello API service Signed-off-by: Vitor Mattos <vitor@php.rio>
This commit is contained in:
committed by
Julius Härtl
parent
c7a37ea425
commit
202ea30090
@@ -45,6 +45,7 @@ class BoardImport extends Command {
|
|||||||
*/
|
*/
|
||||||
protected function configure() {
|
protected function configure() {
|
||||||
$allowedSystems = $this->boardImportCommandService->getAllowedImportSystems();
|
$allowedSystems = $this->boardImportCommandService->getAllowedImportSystems();
|
||||||
|
$names = array_column($allowedSystems, 'name');
|
||||||
$this
|
$this
|
||||||
->setName('deck:import')
|
->setName('deck:import')
|
||||||
->setDescription('Import data')
|
->setDescription('Import data')
|
||||||
@@ -52,8 +53,8 @@ class BoardImport extends Command {
|
|||||||
'system',
|
'system',
|
||||||
null,
|
null,
|
||||||
InputOption::VALUE_REQUIRED,
|
InputOption::VALUE_REQUIRED,
|
||||||
'Source system for import. Available options: ' . implode(', ', $allowedSystems) . '.',
|
'Source system for import. Available options: ' . implode(', ', $names) . '.',
|
||||||
'trello'
|
null
|
||||||
)
|
)
|
||||||
->addOption(
|
->addOption(
|
||||||
'config',
|
'config',
|
||||||
@@ -65,7 +66,7 @@ class BoardImport extends Command {
|
|||||||
->addOption(
|
->addOption(
|
||||||
'data',
|
'data',
|
||||||
null,
|
null,
|
||||||
InputOption::VALUE_REQUIRED,
|
InputOption::VALUE_OPTIONAL,
|
||||||
'Data file to import.',
|
'Data file to import.',
|
||||||
'data.json'
|
'data.json'
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -33,8 +33,11 @@ use OCP\AppFramework\Db\Entity;
|
|||||||
use OCP\Comments\IComment;
|
use OCP\Comments\IComment;
|
||||||
|
|
||||||
abstract class ABoardImportService {
|
abstract class ABoardImportService {
|
||||||
|
/** @var string */
|
||||||
|
public static $name = '';
|
||||||
/** @var BoardImportService */
|
/** @var BoardImportService */
|
||||||
private $boardImportService;
|
private $boardImportService;
|
||||||
|
protected $needValidateData = true;
|
||||||
/** @var Stack[] */
|
/** @var Stack[] */
|
||||||
protected $stacks = [];
|
protected $stacks = [];
|
||||||
/** @var Label[] */
|
/** @var Label[] */
|
||||||
@@ -123,4 +126,8 @@ abstract class ABoardImportService {
|
|||||||
public function getImportService(): BoardImportService {
|
public function getImportService(): BoardImportService {
|
||||||
return $this->boardImportService;
|
return $this->boardImportService;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function needValidateData(): bool {
|
||||||
|
return $this->needValidateData;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -126,19 +126,24 @@ class BoardImportCommandService extends BoardImportService {
|
|||||||
} catch (\Throwable $th) {
|
} catch (\Throwable $th) {
|
||||||
}
|
}
|
||||||
$helper = $this->getCommand()->getHelper('question');
|
$helper = $this->getCommand()->getHelper('question');
|
||||||
|
$allowedSystems = $this->getAllowedImportSystems();
|
||||||
|
$names = array_column($allowedSystems, 'name');
|
||||||
$question = new ChoiceQuestion(
|
$question = new ChoiceQuestion(
|
||||||
'Please inform a source system',
|
'Please inform a source system',
|
||||||
$this->getAllowedImportSystems(),
|
$names,
|
||||||
0
|
0
|
||||||
);
|
);
|
||||||
$question->setErrorMessage('System %s is invalid.');
|
$question->setErrorMessage('System %s is invalid.');
|
||||||
$system = $helper->ask($this->getInput(), $this->getOutput(), $question);
|
$selectedName = $helper->ask($this->getInput(), $this->getOutput(), $question);
|
||||||
$this->getInput()->setOption('system', $system);
|
$className = $allowedSystems[array_flip($names)[$selectedName]]['internalName'];
|
||||||
$this->setSystem($system);
|
$this->setSystem($className);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function validateData(): void {
|
protected function validateData(): void {
|
||||||
|
if (!$this->getImportSystem()->needValidateData()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
$data = $this->getInput()->getOption('data');
|
$data = $this->getInput()->getOption('data');
|
||||||
if (is_string($data)) {
|
if (is_string($data)) {
|
||||||
$data = json_decode(file_get_contents($data));
|
$data = json_decode(file_get_contents($data));
|
||||||
|
|||||||
@@ -67,7 +67,7 @@ class BoardImportService {
|
|||||||
private $system = '';
|
private $system = '';
|
||||||
/** @var null|ABoardImportService */
|
/** @var null|ABoardImportService */
|
||||||
private $systemInstance;
|
private $systemInstance;
|
||||||
/** @var string[] */
|
/** @var array */
|
||||||
private $allowedSystems = [];
|
private $allowedSystems = [];
|
||||||
/**
|
/**
|
||||||
* Data object created from config JSON
|
* Data object created from config JSON
|
||||||
@@ -142,7 +142,9 @@ class BoardImportService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function validateSystem(): void {
|
public function validateSystem(): void {
|
||||||
if (!in_array($this->getSystem(), $this->getAllowedImportSystems())) {
|
$allowedSystems = $this->getAllowedImportSystems();
|
||||||
|
$allowedSystems = array_column($allowedSystems, 'internalName');
|
||||||
|
if (!in_array($this->getSystem(), $allowedSystems)) {
|
||||||
throw new NotFoundException('Invalid system');
|
throw new NotFoundException('Invalid system');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -173,9 +175,23 @@ class BoardImportService {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
});
|
});
|
||||||
$allowedSystems = array_map(function ($name) {
|
$allowedSystems = array_map(function ($filename) {
|
||||||
preg_match('/\/BoardImport(?<system>\w+)Service\.php$/', $name, $matches);
|
preg_match('/\/(?<class>BoardImport(?<system>\w+)Service)\.php$/', $filename, $matches);
|
||||||
return lcfirst($matches['system']);
|
$className = 'OCA\Deck\Service\\'.$matches['class'];
|
||||||
|
if (!class_exists($className)) {
|
||||||
|
/** @psalm-suppress UnresolvableInclude */
|
||||||
|
require_once $name;
|
||||||
|
}
|
||||||
|
/** @psalm-suppress InvalidPropertyFetch */
|
||||||
|
$name = $className::$name;
|
||||||
|
if (empty($name)) {
|
||||||
|
$name = lcfirst($matches['system']);
|
||||||
|
}
|
||||||
|
return [
|
||||||
|
'name' => $name,
|
||||||
|
'class' => $className,
|
||||||
|
'internalName' => lcfirst($matches['system'])
|
||||||
|
];
|
||||||
}, $allowedSystems);
|
}, $allowedSystems);
|
||||||
$this->allowedSystems = array_values($allowedSystems);
|
$this->allowedSystems = array_values($allowedSystems);
|
||||||
}
|
}
|
||||||
|
|||||||
99
lib/Service/BoardImportTrelloApiService.php
Normal file
99
lib/Service/BoardImportTrelloApiService.php
Normal file
@@ -0,0 +1,99 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2021 Vitor Mattos <vitor@php.rio>
|
||||||
|
*
|
||||||
|
* @author Vitor Mattos <vitor@php.rio>
|
||||||
|
*
|
||||||
|
* @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 OCA\Deck\Service;
|
||||||
|
|
||||||
|
use GuzzleHttp\Exception\ClientException;
|
||||||
|
use GuzzleHttp\Exception\RequestException;
|
||||||
|
use OCP\AppFramework\Http;
|
||||||
|
use OCP\Http\Client\IClient;
|
||||||
|
use OCP\Http\Client\IClientService;
|
||||||
|
use OCP\IL10N;
|
||||||
|
use OCP\ILogger;
|
||||||
|
use OCP\IUserManager;
|
||||||
|
|
||||||
|
class BoardImportTrelloApiService extends BoardImportTrelloJsonService {
|
||||||
|
/** @var string */
|
||||||
|
public static $name = 'Trello API';
|
||||||
|
protected $needValidateData = false;
|
||||||
|
/** @var IClient */
|
||||||
|
private $httpClient;
|
||||||
|
/** @var ILogger */
|
||||||
|
protected $logger;
|
||||||
|
/** @var string */
|
||||||
|
private $baseApiUrl = 'https://api.trello.com/1';
|
||||||
|
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
IUserManager $userManager,
|
||||||
|
IL10N $l10n,
|
||||||
|
ILogger $logger,
|
||||||
|
IClientService $httpClientService
|
||||||
|
) {
|
||||||
|
parent::__construct($userManager, $l10n);
|
||||||
|
$this->logger = $logger;
|
||||||
|
$this->httpClient = $httpClientService->newClient();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function bootstrap(): void {
|
||||||
|
$this->getBoards();
|
||||||
|
parent::bootstrap();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getBoards() {
|
||||||
|
$boards = $this->doRequest('/members/me/boards');
|
||||||
|
}
|
||||||
|
|
||||||
|
private function doRequest($path, $queryString = []) {
|
||||||
|
try {
|
||||||
|
$target = $this->baseApiUrl . $path;
|
||||||
|
$result = $this->httpClient
|
||||||
|
->get($target, $this->getQueryString($queryString))
|
||||||
|
->getBody();
|
||||||
|
$data = json_decode($result);
|
||||||
|
} catch (ClientException $e) {
|
||||||
|
$status = $e->getCode();
|
||||||
|
if ($status === Http::STATUS_FORBIDDEN) {
|
||||||
|
$this->logger->info($target . ' refused.', ['app' => 'deck']);
|
||||||
|
} else {
|
||||||
|
$this->logger->info($target . ' responded with a ' . $status . ' containing: ' . $e->getMessage(), ['app' => 'deck']);
|
||||||
|
}
|
||||||
|
} catch (RequestException $e) {
|
||||||
|
$this->logger->logException($e, [
|
||||||
|
'message' => 'Could not connect to ' . $target,
|
||||||
|
'level' => ILogger::INFO,
|
||||||
|
'app' => 'deck',
|
||||||
|
]);
|
||||||
|
} catch (\Throwable $e) {
|
||||||
|
$this->logger->logException($e, ['app' => 'deck']);
|
||||||
|
}
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getQueryString($params = []): array {
|
||||||
|
$apiSettings = $this->getImportService()->getConfig('api');
|
||||||
|
$params['key'] = $apiSettings->key;
|
||||||
|
$params['value'] = $apiSettings->token;
|
||||||
|
return $params;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -35,7 +35,9 @@ use OCP\IL10N;
|
|||||||
use OCP\IUser;
|
use OCP\IUser;
|
||||||
use OCP\IUserManager;
|
use OCP\IUserManager;
|
||||||
|
|
||||||
class BoardImportTrelloService extends ABoardImportService {
|
class BoardImportTrelloJsonService extends ABoardImportService {
|
||||||
|
/** @var string */
|
||||||
|
public static $name = 'Trello JSON';
|
||||||
/** @var IUserManager */
|
/** @var IUserManager */
|
||||||
private $userManager;
|
private $userManager;
|
||||||
/** @var IL10N */
|
/** @var IL10N */
|
||||||
44
lib/Service/fixtures/config-trelloApi-schema.json
Normal file
44
lib/Service/fixtures/config-trelloApi-schema.json
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
{
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"api": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"key": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\w{32}$"
|
||||||
|
},
|
||||||
|
"token": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\w{1,}$"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"boards": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\w{1,}$"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"uidRelation": {
|
||||||
|
"type": "object",
|
||||||
|
"comment": "Relationship between Trello and Nextcloud usernames",
|
||||||
|
"example": {
|
||||||
|
"johndoe": "admin"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"owner": {
|
||||||
|
"type": "string",
|
||||||
|
"required": true,
|
||||||
|
"comment": "Nextcloud owner username"
|
||||||
|
},
|
||||||
|
"color": {
|
||||||
|
"type": "string",
|
||||||
|
"required": true,
|
||||||
|
"pattern": "^[0-9a-fA-F]{6}$",
|
||||||
|
"comment": "Default color for the board. If you don't inform, the default color will be used.",
|
||||||
|
"default": "0800fd"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -58,7 +58,7 @@ class BoardImportTest extends \Test\TestCase {
|
|||||||
['config']
|
['config']
|
||||||
)
|
)
|
||||||
->will($this->returnValueMap([
|
->will($this->returnValueMap([
|
||||||
['system', 'trello'],
|
['system', 'trelloJson'],
|
||||||
['config', null]
|
['config', null]
|
||||||
]));
|
]));
|
||||||
|
|
||||||
|
|||||||
@@ -59,8 +59,8 @@ class BoardImportServiceTest extends \Test\TestCase {
|
|||||||
private $assignmentMapper;
|
private $assignmentMapper;
|
||||||
/** @var ICommentsManager|MockObject */
|
/** @var ICommentsManager|MockObject */
|
||||||
private $commentsManager;
|
private $commentsManager;
|
||||||
/** @var BoardImportTrelloService|MockObject */
|
/** @var BoardImportTrelloJsonService|MockObject */
|
||||||
private $importTrelloService;
|
private $importTrelloJsonService;
|
||||||
/** @var BoardImportService|MockObject */
|
/** @var BoardImportService|MockObject */
|
||||||
private $boardImportService;
|
private $boardImportService;
|
||||||
public function setUp(): void {
|
public function setUp(): void {
|
||||||
@@ -85,16 +85,16 @@ class BoardImportServiceTest extends \Test\TestCase {
|
|||||||
$this->commentsManager
|
$this->commentsManager
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->boardImportService->setSystem('trello');
|
$this->boardImportService->setSystem('trelloJson');
|
||||||
|
|
||||||
$data = json_decode(file_get_contents(__DIR__ . '/../../data/data-trello.json'));
|
$data = json_decode(file_get_contents(__DIR__ . '/../../data/data-trelloJson.json'));
|
||||||
$this->boardImportService->setData($data);
|
$this->boardImportService->setData($data);
|
||||||
|
|
||||||
$configInstance = json_decode(file_get_contents(__DIR__ . '/../../data/config-trello.json'));
|
$configInstance = json_decode(file_get_contents(__DIR__ . '/../../data/config-trelloJson.json'));
|
||||||
$this->boardImportService->setConfigInstance($configInstance);
|
$this->boardImportService->setConfigInstance($configInstance);
|
||||||
|
|
||||||
$this->importTrelloService = $this->createMock(BoardImportTrelloService::class);
|
$this->importTrelloJsonService = $this->createMock(BoardImportTrelloJsonService::class);
|
||||||
$this->boardImportService->setImportSystem($this->importTrelloService);
|
$this->boardImportService->setImportSystem($this->importTrelloJsonService);
|
||||||
|
|
||||||
$owner = $this->createMock(IUser::class);
|
$owner = $this->createMock(IUser::class);
|
||||||
$owner
|
$owner
|
||||||
@@ -122,35 +122,35 @@ class BoardImportServiceTest extends \Test\TestCase {
|
|||||||
->expects($this->once())
|
->expects($this->once())
|
||||||
->method('insert');
|
->method('insert');
|
||||||
|
|
||||||
$this->importTrelloService
|
$this->importTrelloJsonService
|
||||||
->method('getAclList')
|
->method('getAclList')
|
||||||
->willReturn([new Acl()]);
|
->willReturn([new Acl()]);
|
||||||
$this->aclMapper
|
$this->aclMapper
|
||||||
->expects($this->once())
|
->expects($this->once())
|
||||||
->method('insert');
|
->method('insert');
|
||||||
|
|
||||||
$this->importTrelloService
|
$this->importTrelloJsonService
|
||||||
->method('getLabels')
|
->method('getLabels')
|
||||||
->willReturn([new Label()]);
|
->willReturn([new Label()]);
|
||||||
$this->labelMapper
|
$this->labelMapper
|
||||||
->expects($this->once())
|
->expects($this->once())
|
||||||
->method('insert');
|
->method('insert');
|
||||||
|
|
||||||
$this->importTrelloService
|
$this->importTrelloJsonService
|
||||||
->method('getStacks')
|
->method('getStacks')
|
||||||
->willReturn([new Stack()]);
|
->willReturn([new Stack()]);
|
||||||
$this->stackMapper
|
$this->stackMapper
|
||||||
->expects($this->once())
|
->expects($this->once())
|
||||||
->method('insert');
|
->method('insert');
|
||||||
|
|
||||||
$this->importTrelloService
|
$this->importTrelloJsonService
|
||||||
->method('getCards')
|
->method('getCards')
|
||||||
->willReturn([new Card()]);
|
->willReturn([new Card()]);
|
||||||
$this->cardMapper
|
$this->cardMapper
|
||||||
->expects($this->any())
|
->expects($this->any())
|
||||||
->method('insert');
|
->method('insert');
|
||||||
|
|
||||||
$this->importTrelloService
|
$this->importTrelloJsonService
|
||||||
->method('getComments')
|
->method('getComments')
|
||||||
->willReturn([
|
->willReturn([
|
||||||
'fakecardid' => [new Comment()]
|
'fakecardid' => [new Comment()]
|
||||||
@@ -159,7 +159,7 @@ class BoardImportServiceTest extends \Test\TestCase {
|
|||||||
->expects($this->once())
|
->expects($this->once())
|
||||||
->method('save');
|
->method('save');
|
||||||
|
|
||||||
$this->importTrelloService
|
$this->importTrelloJsonService
|
||||||
->method('getCardAssignments')
|
->method('getCardAssignments')
|
||||||
->willReturn([
|
->willReturn([
|
||||||
'fakecardid' => [new Assignment()]
|
'fakecardid' => [new Assignment()]
|
||||||
|
|||||||
@@ -26,8 +26,8 @@ use OCP\IL10N;
|
|||||||
use OCP\IUser;
|
use OCP\IUser;
|
||||||
use OCP\IUserManager;
|
use OCP\IUserManager;
|
||||||
|
|
||||||
class BoardImportTrelloServiceTest extends \Test\TestCase {
|
class BoardImportTrelloJsonServiceTest extends \Test\TestCase {
|
||||||
/** @var BoardImportTrelloService */
|
/** @var BoardImportTrelloJsonService */
|
||||||
private $service;
|
private $service;
|
||||||
/** @var IUserManager */
|
/** @var IUserManager */
|
||||||
private $userManager;
|
private $userManager;
|
||||||
@@ -36,7 +36,7 @@ class BoardImportTrelloServiceTest extends \Test\TestCase {
|
|||||||
public function setUp(): void {
|
public function setUp(): void {
|
||||||
$this->userManager = $this->createMock(IUserManager::class);
|
$this->userManager = $this->createMock(IUserManager::class);
|
||||||
$this->l10n = $this->createMock(IL10N::class);
|
$this->l10n = $this->createMock(IL10N::class);
|
||||||
$this->service = new BoardImportTrelloService(
|
$this->service = new BoardImportTrelloJsonService(
|
||||||
$this->userManager,
|
$this->userManager,
|
||||||
$this->l10n
|
$this->l10n
|
||||||
);
|
);
|
||||||
@@ -62,7 +62,7 @@ class BoardImportTrelloServiceTest extends \Test\TestCase {
|
|||||||
->willReturn(json_decode('{"members": [{"username": "othre_trello_user"}]}'));
|
->willReturn(json_decode('{"members": [{"username": "othre_trello_user"}]}'));
|
||||||
$this->service->setImportService($importService);
|
$this->service->setImportService($importService);
|
||||||
$actual = $this->service->validateUsers();
|
$actual = $this->service->validateUsers();
|
||||||
$this->assertInstanceOf(BoardImportTrelloService::class, $actual);
|
$this->assertInstanceOf(BoardImportTrelloJsonService::class, $actual);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testValidateUsersWithNotStringNextcloud() {
|
public function testValidateUsersWithNotStringNextcloud() {
|
||||||
@@ -78,7 +78,7 @@ class BoardImportTrelloServiceTest extends \Test\TestCase {
|
|||||||
->willReturn(json_decode('{"members": [{"username": "trello_user"}]}'));
|
->willReturn(json_decode('{"members": [{"username": "trello_user"}]}'));
|
||||||
$this->service->setImportService($importService);
|
$this->service->setImportService($importService);
|
||||||
$actual = $this->service->validateUsers();
|
$actual = $this->service->validateUsers();
|
||||||
$this->assertInstanceOf(BoardImportTrelloService::class, $actual);
|
$this->assertInstanceOf(BoardImportTrelloJsonService::class, $actual);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testValidateUsersWithNotFoundUser() {
|
public function testValidateUsersWithNotFoundUser() {
|
||||||
@@ -92,7 +92,7 @@ class BoardImportTrelloServiceTest extends \Test\TestCase {
|
|||||||
->willReturn(json_decode('{"members": [{"username": "trello_user"}]}'));
|
->willReturn(json_decode('{"members": [{"username": "trello_user"}]}'));
|
||||||
$this->service->setImportService($importService);
|
$this->service->setImportService($importService);
|
||||||
$actual = $this->service->validateUsers();
|
$actual = $this->service->validateUsers();
|
||||||
$this->assertInstanceOf(BoardImportTrelloService::class, $actual);
|
$this->assertInstanceOf(BoardImportTrelloJsonService::class, $actual);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testValidateUsersWithValidUsers() {
|
public function testValidateUsersWithValidUsers() {
|
||||||
@@ -123,10 +123,10 @@ class BoardImportTrelloServiceTest extends \Test\TestCase {
|
|||||||
public function testGetBoardWithSuccess() {
|
public function testGetBoardWithSuccess() {
|
||||||
$importService = \OC::$server->get(BoardImportService::class);
|
$importService = \OC::$server->get(BoardImportService::class);
|
||||||
|
|
||||||
$data = json_decode(file_get_contents(__DIR__ . '/../../data/data-trello.json'));
|
$data = json_decode(file_get_contents(__DIR__ . '/../../data/data-trelloJson.json'));
|
||||||
$importService->setData($data);
|
$importService->setData($data);
|
||||||
|
|
||||||
$configInstance = json_decode(file_get_contents(__DIR__ . '/../../data/config-trello.json'));
|
$configInstance = json_decode(file_get_contents(__DIR__ . '/../../data/config-trelloJson.json'));
|
||||||
$importService->setConfigInstance($configInstance);
|
$importService->setConfigInstance($configInstance);
|
||||||
|
|
||||||
$owner = $this->createMock(IUser::class);
|
$owner = $this->createMock(IUser::class);
|
||||||
|
|||||||
@@ -50,16 +50,23 @@ class BoardImportApiControllerTest extends \Test\TestCase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function testGetAllowedSystems() {
|
public function testGetAllowedSystems() {
|
||||||
|
$allowedSystems = [
|
||||||
|
[
|
||||||
|
'name' => '',
|
||||||
|
'class' => '',
|
||||||
|
'internalName' => 'trelloJson'
|
||||||
|
]
|
||||||
|
];
|
||||||
$this->boardImportService
|
$this->boardImportService
|
||||||
->method('getAllowedImportSystems')
|
->method('getAllowedImportSystems')
|
||||||
->willReturn(['trello']);
|
->willReturn($allowedSystems);
|
||||||
$actual = $this->controller->getAllowedSystems();
|
$actual = $this->controller->getAllowedSystems();
|
||||||
$expected = new DataResponse(['trello'], HTTP::STATUS_OK);
|
$expected = new DataResponse($allowedSystems, HTTP::STATUS_OK);
|
||||||
$this->assertEquals($expected, $actual);
|
$this->assertEquals($expected, $actual);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testImport() {
|
public function testImport() {
|
||||||
$system = 'trello';
|
$system = 'trelloJson';
|
||||||
$config = [
|
$config = [
|
||||||
'owner' => 'test'
|
'owner' => 'test'
|
||||||
];
|
];
|
||||||
|
|||||||
Reference in New Issue
Block a user