Add unit tests for new classes
Signed-off-by: Julius Härtl <jus@bitgrid.net>
This commit is contained in:
@@ -39,7 +39,7 @@ class AttachmentController extends Controller {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function getAll($cardId) {
|
public function getAll($cardId) {
|
||||||
return $this->attachmentService->getAll($cardId);
|
return $this->attachmentService->findAll($cardId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -55,6 +55,8 @@ class AttachmentService {
|
|||||||
* @param AttachmentMapper $attachmentMapper
|
* @param AttachmentMapper $attachmentMapper
|
||||||
* @param CardMapper $cardMapper
|
* @param CardMapper $cardMapper
|
||||||
* @param PermissionService $permissionService
|
* @param PermissionService $permissionService
|
||||||
|
* @param Application $application
|
||||||
|
* @param ICacheFactory $cacheFactory
|
||||||
* @param $userId
|
* @param $userId
|
||||||
* @throws \OCP\AppFramework\QueryException
|
* @throws \OCP\AppFramework\QueryException
|
||||||
*/
|
*/
|
||||||
@@ -257,6 +259,6 @@ class AttachmentService {
|
|||||||
}
|
}
|
||||||
} catch (InvalidAttachmentType $e) {
|
} catch (InvalidAttachmentType $e) {
|
||||||
}
|
}
|
||||||
throw new NoPermissionException();
|
throw new NoPermissionException('Restore is not allowed.');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -32,11 +32,11 @@ use OCA\Deck\Service\IAttachmentService;
|
|||||||
|
|
||||||
class DeleteCronTest extends \Test\TestCase {
|
class DeleteCronTest extends \Test\TestCase {
|
||||||
|
|
||||||
/** @var BoardMapper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var BoardMapper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
protected $boardMapper;
|
protected $boardMapper;
|
||||||
/** @var AttachmentService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var AttachmentService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $attachmentService;
|
private $attachmentService;
|
||||||
/** @var AttachmentMapper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var AttachmentMapper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $attachmentMapper;
|
private $attachmentMapper;
|
||||||
/** @var DeleteCron */
|
/** @var DeleteCron */
|
||||||
protected $deleteCron;
|
protected $deleteCron;
|
||||||
|
|||||||
@@ -31,9 +31,9 @@ use OCA\Deck\Notification\NotificationHelper;
|
|||||||
|
|
||||||
class ScheduledNoificationsTest extends \Test\TestCase {
|
class ScheduledNoificationsTest extends \Test\TestCase {
|
||||||
|
|
||||||
/** @var CardMapper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var CardMapper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
protected $cardMapper;
|
protected $cardMapper;
|
||||||
/** @var NotificationHelper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var NotificationHelper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
protected $notificationHelper;
|
protected $notificationHelper;
|
||||||
/** @var ScheduledNotifications */
|
/** @var ScheduledNotifications */
|
||||||
protected $scheduledNotifications;
|
protected $scheduledNotifications;
|
||||||
|
|||||||
51
tests/unit/Db/AttachmentTest.php
Normal file
51
tests/unit/Db/AttachmentTest.php
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2018 Julius Härtl <jus@bitgrid.net>
|
||||||
|
*
|
||||||
|
* @author Julius Härtl <jus@bitgrid.net>
|
||||||
|
*
|
||||||
|
* @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\Db;
|
||||||
|
|
||||||
|
class AttachmentTest extends \Test\TestCase {
|
||||||
|
private function createAttachment() {
|
||||||
|
$attachment = new Attachment();
|
||||||
|
$attachment->setId(1);
|
||||||
|
$attachment->setCardId(123);
|
||||||
|
$attachment->setData("blob");
|
||||||
|
$attachment->setCreatedBy('admin');
|
||||||
|
$attachment->setType('deck_file');
|
||||||
|
return $attachment;
|
||||||
|
}
|
||||||
|
public function testJsonSerialize() {
|
||||||
|
$board = $this->createAttachment();
|
||||||
|
$this->assertEquals([
|
||||||
|
'id' => 1,
|
||||||
|
'cardId' => 123,
|
||||||
|
'lastModified' => 0,
|
||||||
|
'data' => 'blob',
|
||||||
|
'type' => 'deck_file',
|
||||||
|
'createdAt' => 0,
|
||||||
|
'createdBy' => 'admin',
|
||||||
|
'deletedAt' => 0,
|
||||||
|
'extendedData' => []
|
||||||
|
|
||||||
|
], $board->jsonSerialize());
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -35,13 +35,13 @@ class BoardMapperTest extends MapperTestUtility {
|
|||||||
|
|
||||||
/** @var IDBConnection */
|
/** @var IDBConnection */
|
||||||
private $dbConnection;
|
private $dbConnection;
|
||||||
/** @var AclMapper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var AclMapper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $aclMapper;
|
private $aclMapper;
|
||||||
/** @var BoardMapper */
|
/** @var BoardMapper */
|
||||||
private $boardMapper;
|
private $boardMapper;
|
||||||
/** @var IUserManager|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var IUserManager|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $userManager;
|
private $userManager;
|
||||||
/** @var IGroupManager|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var IGroupManager|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $groupManager;
|
private $groupManager;
|
||||||
|
|
||||||
// Data
|
// Data
|
||||||
|
|||||||
@@ -25,8 +25,9 @@ namespace OCA\Deck\Db;
|
|||||||
|
|
||||||
use DateInterval;
|
use DateInterval;
|
||||||
use DateTime;
|
use DateTime;
|
||||||
|
use Test\TestCase;
|
||||||
|
|
||||||
class CardTest extends \PHPUnit_Framework_TestCase {
|
class CardTest extends TestCase {
|
||||||
private function createCard() {
|
private function createCard() {
|
||||||
$card = new Card();
|
$card = new Card();
|
||||||
$card->setId(1);
|
$card->setId(1);
|
||||||
|
|||||||
@@ -23,7 +23,9 @@
|
|||||||
|
|
||||||
namespace OCA\Deck\Db;
|
namespace OCA\Deck\Db;
|
||||||
|
|
||||||
class LabelTest extends \PHPUnit_Framework_TestCase {
|
use Test\TestCase;
|
||||||
|
|
||||||
|
class LabelTest extends TestCase {
|
||||||
private function createLabel() {
|
private function createLabel() {
|
||||||
$label = new Label();
|
$label = new Label();
|
||||||
$label->setId(1);
|
$label->setId(1);
|
||||||
|
|||||||
@@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
namespace OCA\Deck\Db;
|
namespace OCA\Deck\Db;
|
||||||
|
|
||||||
class StackTest extends \PHPUnit_Framework_TestCase {
|
class StackTest extends \Test\TestCase {
|
||||||
private function createStack() {
|
private function createStack() {
|
||||||
$board = new Stack();
|
$board = new Stack();
|
||||||
$board->setId(1);
|
$board->setId(1);
|
||||||
|
|||||||
@@ -25,11 +25,12 @@ namespace OCA\Deck\Db;
|
|||||||
|
|
||||||
use OCA\Deck\ArchivedItemException;
|
use OCA\Deck\ArchivedItemException;
|
||||||
use OCA\Deck\Controller\PageController;
|
use OCA\Deck\Controller\PageController;
|
||||||
|
use OCA\Deck\InvalidAttachmentType;
|
||||||
use OCA\Deck\NoPermissionException;
|
use OCA\Deck\NoPermissionException;
|
||||||
use OCA\Deck\NotFoundException;
|
use OCA\Deck\NotFoundException;
|
||||||
use OCA\Deck\StatusException;
|
use OCA\Deck\StatusException;
|
||||||
|
|
||||||
class ExceptionsTest extends \PHPUnit_Framework_TestCase {
|
class ExceptionsTest extends \Test\TestCase {
|
||||||
|
|
||||||
public function testNoPermissionException() {
|
public function testNoPermissionException() {
|
||||||
$c = new \stdClass();
|
$c = new \stdClass();
|
||||||
@@ -49,6 +50,11 @@ class ExceptionsTest extends \PHPUnit_Framework_TestCase {
|
|||||||
$this->assertEquals('foo', $e->getMessage());
|
$this->assertEquals('foo', $e->getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testInvalidAttachmentType() {
|
||||||
|
$e = new InvalidAttachmentType('foo');
|
||||||
|
$this->assertEquals('No matching IAttachmentService implementation found for type foo', $e->getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
public function testStatusException() {
|
public function testStatusException() {
|
||||||
$e = new StatusException('foo');
|
$e = new StatusException('foo');
|
||||||
$this->assertEquals('foo', $e->getMessage());
|
$this->assertEquals('foo', $e->getMessage());
|
||||||
|
|||||||
335
tests/unit/Service/AttachmentServiceTest.php
Normal file
335
tests/unit/Service/AttachmentServiceTest.php
Normal file
@@ -0,0 +1,335 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2018 Julius Härtl <jus@bitgrid.net>
|
||||||
|
*
|
||||||
|
* @author Julius Härtl <jus@bitgrid.net>
|
||||||
|
*
|
||||||
|
* @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 OCA\Deck\AppInfo\Application;
|
||||||
|
use OCA\Deck\Db\Acl;
|
||||||
|
use OCA\Deck\Db\Attachment;
|
||||||
|
use OCA\Deck\Db\AttachmentMapper;
|
||||||
|
use OCA\Deck\Db\CardMapper;
|
||||||
|
use OCA\Deck\InvalidAttachmentType;
|
||||||
|
use OCP\AppFramework\Http\Response;
|
||||||
|
use OCP\AppFramework\IAppContainer;
|
||||||
|
use OCP\ICache;
|
||||||
|
use OCP\ICacheFactory;
|
||||||
|
use PHPUnit\Framework\MockObject\MockObject;
|
||||||
|
use Test\TestCase;
|
||||||
|
|
||||||
|
/** @internal Just for testing the service registration */
|
||||||
|
class MyAttachmentService {
|
||||||
|
public function extendData(Attachment $attachment) {}
|
||||||
|
public function display(Attachment $attachment) {}
|
||||||
|
public function create(Attachment $attachment) {}
|
||||||
|
public function update(Attachment $attachment) {}
|
||||||
|
public function delete(Attachment $attachment) {}
|
||||||
|
public function allowUndo() {}
|
||||||
|
public function markAsDeleted(Attachment $attachment) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
class AttachmentServiceTest extends TestCase {
|
||||||
|
|
||||||
|
/** @var AttachmentMapper|MockObject */
|
||||||
|
private $attachmentMapper;
|
||||||
|
/** @var CardMapper|MockObject */
|
||||||
|
private $cardMapper;
|
||||||
|
/** @var PermissionService|MockObject */
|
||||||
|
private $permissionService;
|
||||||
|
private $userId = 'admin';
|
||||||
|
/** @var Application|MockObject */
|
||||||
|
private $application;
|
||||||
|
private $cacheFactory;
|
||||||
|
/** @var AttachmentService */
|
||||||
|
private $attachmentService;
|
||||||
|
/** @var MockObject */
|
||||||
|
private $attachmentServiceImpl;
|
||||||
|
private $appContainer;
|
||||||
|
/** ICache */
|
||||||
|
private $cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws \OCP\AppFramework\QueryException
|
||||||
|
*/
|
||||||
|
public function setUp() {
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
$this->attachmentServiceImpl = $this->createMock(IAttachmentService::class);
|
||||||
|
$this->appContainer = $this->createMock(IAppContainer::class);
|
||||||
|
|
||||||
|
$this->attachmentMapper = $this->createMock(AttachmentMapper::class);
|
||||||
|
$this->cardMapper = $this->createMock(CardMapper::class);
|
||||||
|
$this->permissionService = $this->createMock(PermissionService::class);
|
||||||
|
$this->application = $this->createMock(Application::class);
|
||||||
|
$this->cacheFactory = $this->createMock(ICacheFactory::class);
|
||||||
|
|
||||||
|
$this->cache = $this->createMock(ICache::class);
|
||||||
|
$this->cacheFactory->expects($this->any())->method('createDistributed')->willReturn($this->cache);
|
||||||
|
|
||||||
|
$this->appContainer->expects($this->at(0))->method('query')->with(FileService::class)->willReturn($this->attachmentServiceImpl);
|
||||||
|
$this->application->expects($this->any())
|
||||||
|
->method('getContainer')
|
||||||
|
->willReturn($this->appContainer);
|
||||||
|
|
||||||
|
$this->attachmentService = new AttachmentService($this->attachmentMapper, $this->cardMapper, $this->permissionService, $this->application, $this->cacheFactory, $this->userId);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testRegisterAttachmentService() {
|
||||||
|
$application = $this->createMock(Application::class);
|
||||||
|
$appContainer = $this->createMock(IAppContainer::class);
|
||||||
|
$fileServiceMock = $this->createMock(FileService::class);
|
||||||
|
$appContainer->expects($this->at(1))->method('query')->with(MyAttachmentService::class)->willReturn(new MyAttachmentService());
|
||||||
|
$appContainer->expects($this->at(0))->method('query')->with(FileService::class)->willReturn($fileServiceMock);
|
||||||
|
$application->expects($this->any())
|
||||||
|
->method('getContainer')
|
||||||
|
->willReturn($appContainer);
|
||||||
|
$attachmentService = new AttachmentService($this->attachmentMapper, $this->cardMapper, $this->permissionService, $application, $this->cacheFactory, $this->userId);
|
||||||
|
$attachmentService->registerAttachmentService('custom', MyAttachmentService::class);
|
||||||
|
$this->assertEquals($fileServiceMock, $attachmentService->getService('deck_file'));
|
||||||
|
$this->assertEquals(MyAttachmentService::class, get_class($attachmentService->getService('custom')));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @expectedException \OCA\Deck\InvalidAttachmentType
|
||||||
|
*/
|
||||||
|
public function testRegisterAttachmentServiceNotExisting() {
|
||||||
|
$application = $this->createMock(Application::class);
|
||||||
|
$appContainer = $this->createMock(IAppContainer::class);
|
||||||
|
$fileServiceMock = $this->createMock(FileService::class);
|
||||||
|
$appContainer->expects($this->at(0))->method('query')->with(FileService::class)->willReturn($fileServiceMock);
|
||||||
|
$appContainer->expects($this->at(1))->method('query')->with(MyAttachmentService::class)->willReturn(new MyAttachmentService());
|
||||||
|
$application->expects($this->any())
|
||||||
|
->method('getContainer')
|
||||||
|
->willReturn($appContainer);
|
||||||
|
$attachmentService = new AttachmentService($this->attachmentMapper, $this->cardMapper, $this->permissionService, $application, $this->cacheFactory, $this->userId);
|
||||||
|
$attachmentService->registerAttachmentService('custom', MyAttachmentService::class);
|
||||||
|
$attachmentService->getService('deck_file_invalid');
|
||||||
|
}
|
||||||
|
|
||||||
|
private function mockPermission($permission) {
|
||||||
|
$this->permissionService->expects($this->once())
|
||||||
|
->method('checkPermission')
|
||||||
|
->with($this->cardMapper, 123, $permission);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function createAttachment($type, $data) {
|
||||||
|
$attachment = new Attachment();
|
||||||
|
$attachment->setType($type);
|
||||||
|
$attachment->setData($data);
|
||||||
|
return $attachment;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testFindAll() {
|
||||||
|
$this->mockPermission(Acl::PERMISSION_READ);
|
||||||
|
$attachments = [
|
||||||
|
$this->createAttachment('deck_file','file1'),
|
||||||
|
$this->createAttachment('deck_file','file2'),
|
||||||
|
$this->createAttachment('deck_file_invalid','file3'),
|
||||||
|
];
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('findAll')
|
||||||
|
->with(123)
|
||||||
|
->willReturn($attachments);
|
||||||
|
|
||||||
|
$this->attachmentServiceImpl->expects($this->at(0))
|
||||||
|
->method('extendData')
|
||||||
|
->with($attachments[0]);
|
||||||
|
$this->attachmentServiceImpl->expects($this->at(1))
|
||||||
|
->method('extendData')
|
||||||
|
->with($attachments[1]);
|
||||||
|
$this->assertEquals($attachments, $this->attachmentService->findAll(123, false));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCount() {
|
||||||
|
$this->cache->expects($this->once())->method('get')->with('card-123')->willReturn(null);
|
||||||
|
$this->attachmentMapper->expects($this->once())->method('findAll')->willReturn([1,2,3,4]);
|
||||||
|
$this->cache->expects($this->once())->method('set')->with('card-123', 4)->willReturn(null);
|
||||||
|
$this->assertEquals(4, $this->attachmentService->count(123));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCountCacheHit() {
|
||||||
|
$this->cache->expects($this->once())->method('get')->with('card-123')->willReturn(4);
|
||||||
|
$this->assertEquals(4, $this->attachmentService->count(123));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreate() {
|
||||||
|
$attachment = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$expected = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$this->mockPermission(Acl::PERMISSION_EDIT);
|
||||||
|
$this->cache->expects($this->once())->method('clear')->with('card-123');
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('create');
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('insert')
|
||||||
|
->willReturn($attachment);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('extendData')
|
||||||
|
->willReturnCallback(function($a) { $a->setExtendedData(['mime' => 'image/jpeg']); });
|
||||||
|
|
||||||
|
$actual = $this->attachmentService->create(123, 'deck_file', 'file_name.jpg');
|
||||||
|
|
||||||
|
$expected->setExtendedData(['mime' => 'image/jpeg']);
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDisplay() {
|
||||||
|
$attachment = $this->createAttachment('deck_file', 'filename');
|
||||||
|
$response = new Response();
|
||||||
|
$this->mockPermission(Acl::PERMISSION_READ);
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('find')
|
||||||
|
->with(1)
|
||||||
|
->willReturn($attachment);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('display')
|
||||||
|
->with($attachment)
|
||||||
|
->willReturn($response);
|
||||||
|
$actual = $this->attachmentService->display(123, 1);
|
||||||
|
$this->assertEquals($response, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @expectedException \OCA\Deck\NotFoundException
|
||||||
|
*/
|
||||||
|
public function testDisplayInvalid() {
|
||||||
|
$attachment = $this->createAttachment('deck_file', 'filename');
|
||||||
|
$response = new Response();
|
||||||
|
$this->mockPermission(Acl::PERMISSION_READ);
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('find')
|
||||||
|
->with(1)
|
||||||
|
->willReturn($attachment);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('display')
|
||||||
|
->with($attachment)
|
||||||
|
->will($this->throwException(new InvalidAttachmentType('deck_file')));
|
||||||
|
$this->attachmentService->display(123, 1);
|
||||||
|
}
|
||||||
|
public function testUpdate() {
|
||||||
|
$attachment = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$expected = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$this->mockPermission(Acl::PERMISSION_EDIT);
|
||||||
|
$this->cache->expects($this->once())->method('clear')->with('card-123');
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('find')
|
||||||
|
->with(1)
|
||||||
|
->willReturn($attachment);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('update');
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('update')
|
||||||
|
->willReturn($attachment);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('extendData')
|
||||||
|
->willReturnCallback(function($a) { $a->setExtendedData(['mime' => 'image/jpeg']); });
|
||||||
|
|
||||||
|
$actual = $this->attachmentService->update(123, 1, 'file_name.jpg');
|
||||||
|
|
||||||
|
$expected->setExtendedData(['mime' => 'image/jpeg']);
|
||||||
|
$expected->setLastModified($attachment->getLastModified());
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDelete() {
|
||||||
|
$attachment = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$expected = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$this->mockPermission(Acl::PERMISSION_EDIT);
|
||||||
|
$this->cache->expects($this->once())->method('clear')->with('card-123');
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('find')
|
||||||
|
->with(1)
|
||||||
|
->willReturn($attachment);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('allowUndo')
|
||||||
|
->willReturn(false);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('delete');
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('delete')
|
||||||
|
->willReturn($attachment);
|
||||||
|
$actual = $this->attachmentService->delete(123, 1);
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDeleteWithUndo() {
|
||||||
|
$attachment = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$expected = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$this->mockPermission(Acl::PERMISSION_EDIT);
|
||||||
|
$this->cache->expects($this->once())->method('clear')->with('card-123');
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('find')
|
||||||
|
->with(1)
|
||||||
|
->willReturn($attachment);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('allowUndo')
|
||||||
|
->willReturn(true);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('markAsDeleted')
|
||||||
|
->willReturnCallback(function($a) { $a->setDeletedAt(23); });
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('update')
|
||||||
|
->willReturn($attachment);
|
||||||
|
$expected->setDeletedAt(23);
|
||||||
|
$actual = $this->attachmentService->delete(123, 1);
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testRestore() {
|
||||||
|
$attachment = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$expected = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$this->mockPermission(Acl::PERMISSION_EDIT);
|
||||||
|
$this->cache->expects($this->once())->method('clear')->with('card-123');
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('find')
|
||||||
|
->with(1)
|
||||||
|
->willReturn($attachment);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('allowUndo')
|
||||||
|
->willReturn(true);
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('update')
|
||||||
|
->willReturn($attachment);
|
||||||
|
$expected->setDeletedAt(0);
|
||||||
|
$actual = $this->attachmentService->restore(123, 1);
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @expectedException \OCA\Deck\NoPermissionException
|
||||||
|
*/
|
||||||
|
public function testRestoreNotAllowed() {
|
||||||
|
$attachment = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$expected = $this->createAttachment('deck_file', 'file_name.jpg');
|
||||||
|
$this->mockPermission(Acl::PERMISSION_EDIT);
|
||||||
|
$this->cache->expects($this->once())->method('clear')->with('card-123');
|
||||||
|
$this->attachmentMapper->expects($this->once())
|
||||||
|
->method('find')
|
||||||
|
->with(1)
|
||||||
|
->willReturn($attachment);
|
||||||
|
$this->attachmentServiceImpl->expects($this->once())
|
||||||
|
->method('allowUndo')
|
||||||
|
->willReturn(false);
|
||||||
|
$actual = $this->attachmentService->restore(123, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -35,17 +35,17 @@ use Test\TestCase;
|
|||||||
|
|
||||||
class CardServiceTest extends TestCase {
|
class CardServiceTest extends TestCase {
|
||||||
|
|
||||||
/** @var CardService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var CardService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $cardService;
|
private $cardService;
|
||||||
/** @var CardMapper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var CardMapper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $cardMapper;
|
private $cardMapper;
|
||||||
/** @var StackMapper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var StackMapper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $stackMapper;
|
private $stackMapper;
|
||||||
/** @var PermissionService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var PermissionService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $permissionService;
|
private $permissionService;
|
||||||
/** @var AssignedUsersMapper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var AssignedUsersMapper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $assignedUsersMapper;
|
private $assignedUsersMapper;
|
||||||
/** @var BoardService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var BoardService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $boardService;
|
private $boardService;
|
||||||
|
|
||||||
public function setUp() {
|
public function setUp() {
|
||||||
|
|||||||
229
tests/unit/Service/FileServiceTest.php
Normal file
229
tests/unit/Service/FileServiceTest.php
Normal file
@@ -0,0 +1,229 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2018 Julius Härtl <jus@bitgrid.net>
|
||||||
|
*
|
||||||
|
* @author Julius Härtl <jus@bitgrid.net>
|
||||||
|
*
|
||||||
|
* @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 OCA\Deck\AppInfo\Application;
|
||||||
|
use OCA\Deck\Db\AssignedUsers;
|
||||||
|
use OCA\Deck\Db\AssignedUsersMapper;
|
||||||
|
use OCA\Deck\Db\Attachment;
|
||||||
|
use OCA\Deck\Db\AttachmentMapper;
|
||||||
|
use OCA\Deck\Db\Card;
|
||||||
|
use OCA\Deck\Db\CardMapper;
|
||||||
|
use OCA\Deck\Db\StackMapper;
|
||||||
|
use OCA\Deck\InvalidAttachmentType;
|
||||||
|
use OCA\Deck\NotFoundException;
|
||||||
|
use OCA\Deck\StatusException;
|
||||||
|
use OCP\AppFramework\Http\ContentSecurityPolicy;
|
||||||
|
use OCP\AppFramework\Http\FileDisplayResponse;
|
||||||
|
use OCP\AppFramework\Http\Response;
|
||||||
|
use OCP\AppFramework\IAppContainer;
|
||||||
|
use OCP\Files\IAppData;
|
||||||
|
use OCP\Files\SimpleFS\ISimpleFile;
|
||||||
|
use OCP\Files\SimpleFS\ISimpleFolder;
|
||||||
|
use OCP\ICacheFactory;
|
||||||
|
use OCP\IL10N;
|
||||||
|
use OCP\IRequest;
|
||||||
|
use PHPUnit\Framework\MockObject\MockObject;
|
||||||
|
use Test\TestCase;
|
||||||
|
|
||||||
|
class FileServiceTest extends TestCase {
|
||||||
|
|
||||||
|
/** @var IL10N|MockObject */
|
||||||
|
private $l10n;
|
||||||
|
/** @var IAppData|MockObject */
|
||||||
|
private $appData;
|
||||||
|
/** @var IRequest|MockObject */
|
||||||
|
private $request;
|
||||||
|
/** @var FileService */
|
||||||
|
private $fileService;
|
||||||
|
|
||||||
|
public function setUp() {
|
||||||
|
parent::setUp();
|
||||||
|
$this->request = $this->createMock(IRequest::class);
|
||||||
|
$this->appData = $this->createMock(IAppData::class);
|
||||||
|
$this->l10n = $this->createMock(IL10N::class);
|
||||||
|
$this->fileService = new FileService($this->l10n, $this->appData, $this->request);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function mockGetFolder($cardId) {
|
||||||
|
$folder = $this->createMock(ISimpleFolder::class);
|
||||||
|
$this->appData->expects($this->once())
|
||||||
|
->method('getFolder')
|
||||||
|
->with('file-card-' . $cardId)
|
||||||
|
->willReturn($folder);
|
||||||
|
return $folder;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getAttachment() {
|
||||||
|
$attachment = new Attachment();
|
||||||
|
$attachment->setId(1);
|
||||||
|
$attachment->setCardId(123);
|
||||||
|
return $attachment;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function mockGetUploadedFileEmpty() {
|
||||||
|
$this->request->expects($this->once())
|
||||||
|
->method('getUploadedFile')
|
||||||
|
->willReturn(null);
|
||||||
|
}
|
||||||
|
private function mockGetUploadedFileError($error) {
|
||||||
|
$this->request->expects($this->once())
|
||||||
|
->method('getUploadedFile')
|
||||||
|
->willReturn(['error' => $error]);
|
||||||
|
}
|
||||||
|
private function mockGetUploadedFile() {
|
||||||
|
$this->request->expects($this->once())
|
||||||
|
->method('getUploadedFile')
|
||||||
|
->willReturn([
|
||||||
|
'name' => 'file.jpg',
|
||||||
|
'tmp_name' => __FILE__,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @expectedException \RuntimeException
|
||||||
|
*/
|
||||||
|
public function testCreateEmpty() {
|
||||||
|
$attachment = $this->getAttachment();
|
||||||
|
$this->mockGetUploadedFileEmpty();
|
||||||
|
$this->fileService->create($attachment);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @expectedException \RuntimeException
|
||||||
|
*/
|
||||||
|
public function testCreateError() {
|
||||||
|
$attachment = $this->getAttachment();
|
||||||
|
$this->mockGetUploadedFileError(UPLOAD_ERR_INI_SIZE);
|
||||||
|
$this->fileService->create($attachment);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreate() {
|
||||||
|
$attachment = $this->getAttachment();
|
||||||
|
$this->mockGetUploadedFile();
|
||||||
|
$folder = $this->mockGetFolder(123);
|
||||||
|
$folder->expects($this->once())
|
||||||
|
->method('fileExists')
|
||||||
|
->willReturn(false);
|
||||||
|
$file = $this->createMock(ISimpleFile::class);
|
||||||
|
$file->expects($this->once())
|
||||||
|
->method('putContent')
|
||||||
|
->with(file_get_contents(__FILE__, 'r'));
|
||||||
|
$folder->expects($this->once())
|
||||||
|
->method('newFile')
|
||||||
|
->willReturn($file);
|
||||||
|
|
||||||
|
$this->fileService->create($attachment);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @expectedException \Exception
|
||||||
|
* @expectedExceptionMessage File already exists.
|
||||||
|
*/
|
||||||
|
public function testCreateExists() {
|
||||||
|
$attachment = $this->getAttachment();
|
||||||
|
$this->mockGetUploadedFile();
|
||||||
|
$folder = $this->mockGetFolder(123);
|
||||||
|
$folder->expects($this->once())
|
||||||
|
->method('fileExists')
|
||||||
|
->willReturn(true);
|
||||||
|
$this->fileService->create($attachment);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testUpdate() {
|
||||||
|
$attachment = $this->getAttachment();
|
||||||
|
$this->mockGetUploadedFile();
|
||||||
|
$folder = $this->mockGetFolder(123);
|
||||||
|
$file = $this->createMock(ISimpleFile::class);
|
||||||
|
$file->expects($this->once())
|
||||||
|
->method('putContent')
|
||||||
|
->with(file_get_contents(__FILE__, 'r'));
|
||||||
|
$folder->expects($this->once())
|
||||||
|
->method('getFile')
|
||||||
|
->willReturn($file);
|
||||||
|
|
||||||
|
$this->fileService->update($attachment);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDelete() {
|
||||||
|
$attachment = $this->getAttachment();
|
||||||
|
$file = $this->createMock(ISimpleFile::class);
|
||||||
|
$folder = $this->mockGetFolder('123');
|
||||||
|
$folder->expects($this->once())
|
||||||
|
->method('getFile')
|
||||||
|
->willReturn($file);
|
||||||
|
$file->expects($this->once())
|
||||||
|
->method('delete');
|
||||||
|
$this->fileService->delete($attachment);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDisplay() {
|
||||||
|
$attachment = $this->getAttachment();
|
||||||
|
$file = $this->createMock(ISimpleFile::class);
|
||||||
|
$folder = $this->mockGetFolder('123');
|
||||||
|
$folder->expects($this->once())
|
||||||
|
->method('getFile')
|
||||||
|
->willReturn($file);
|
||||||
|
$file->expects($this->exactly(2))
|
||||||
|
->method('getMimeType')
|
||||||
|
->willReturn('image/jpeg');
|
||||||
|
$actual = $this->fileService->display($attachment);
|
||||||
|
$expected = new FileDisplayResponse($file);
|
||||||
|
$expected->addHeader('Content-Type', 'image/jpeg');
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDisplayPdf() {
|
||||||
|
$attachment = $this->getAttachment();
|
||||||
|
$file = $this->createMock(ISimpleFile::class);
|
||||||
|
$folder = $this->mockGetFolder('123');
|
||||||
|
$folder->expects($this->once())
|
||||||
|
->method('getFile')
|
||||||
|
->willReturn($file);
|
||||||
|
$file->expects($this->exactly(2))
|
||||||
|
->method('getMimeType')
|
||||||
|
->willReturn('application/pdf');
|
||||||
|
$actual = $this->fileService->display($attachment);
|
||||||
|
$expected = new FileDisplayResponse($file);
|
||||||
|
$expected->addHeader('Content-Type', 'application/pdf');
|
||||||
|
$policy = new ContentSecurityPolicy();
|
||||||
|
$policy->addAllowedObjectDomain('\'self\'');
|
||||||
|
$policy->addAllowedObjectDomain('blob:');
|
||||||
|
$expected->setContentSecurityPolicy($policy);
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAllowUndo() {
|
||||||
|
$this->assertTrue($this->fileService->allowUndo());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testMarkAsDeleted() {
|
||||||
|
// TODO: use proper ITimeFactory in the service so we can mock the call to time
|
||||||
|
$attachment = $this->getAttachment();
|
||||||
|
$this->assertEquals(0, $attachment->getDeletedAt());
|
||||||
|
$this->fileService->markAsDeleted($attachment);
|
||||||
|
$this->assertGreaterThan(0, $attachment->getDeletedAt());
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -30,13 +30,13 @@ use Test\TestCase;
|
|||||||
|
|
||||||
class LabelServiceTest extends TestCase {
|
class LabelServiceTest extends TestCase {
|
||||||
|
|
||||||
/** @var LabelMapper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var LabelMapper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $labelMapper;
|
private $labelMapper;
|
||||||
/** @var PermissionService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var PermissionService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $permissionService;
|
private $permissionService;
|
||||||
/** @var LabelService */
|
/** @var LabelService */
|
||||||
private $labelService;
|
private $labelService;
|
||||||
/** @var BoardService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var BoardService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $boardService;
|
private $boardService;
|
||||||
|
|
||||||
public function setUp() {
|
public function setUp() {
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ use OCP\ILogger;
|
|||||||
use OCP\IUser;
|
use OCP\IUser;
|
||||||
use OCP\IUserManager;
|
use OCP\IUserManager;
|
||||||
|
|
||||||
class PermissionServiceTest extends \PHPUnit_Framework_TestCase {
|
class PermissionServiceTest extends \Test\TestCase {
|
||||||
|
|
||||||
/** @var PermissionService*/
|
/** @var PermissionService*/
|
||||||
private $service;
|
private $service;
|
||||||
|
|||||||
@@ -44,19 +44,19 @@ class StackServiceTest extends TestCase {
|
|||||||
|
|
||||||
/** @var StackService */
|
/** @var StackService */
|
||||||
private $stackService;
|
private $stackService;
|
||||||
/** @var \PHPUnit_Framework_MockObject_MockObject|StackMapper */
|
/** @var \PHPUnit\Framework\MockObject\MockObject|StackMapper */
|
||||||
private $stackMapper;
|
private $stackMapper;
|
||||||
/** @var \PHPUnit_Framework_MockObject_MockObject|CardMapper */
|
/** @var \PHPUnit\Framework\MockObject\MockObject|CardMapper */
|
||||||
private $cardMapper;
|
private $cardMapper;
|
||||||
/** @var \PHPUnit_Framework_MockObject_MockObject|LabelMapper */
|
/** @var \PHPUnit\Framework\MockObject\MockObject|LabelMapper */
|
||||||
private $labelMapper;
|
private $labelMapper;
|
||||||
/** @var \PHPUnit_Framework_MockObject_MockObject|PermissionService */
|
/** @var \PHPUnit\Framework\MockObject\MockObject|PermissionService */
|
||||||
private $permissionService;
|
private $permissionService;
|
||||||
/** @var AssignedUsersMapper|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var AssignedUsersMapper|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $assignedUsersMapper;
|
private $assignedUsersMapper;
|
||||||
/** @var AttachmentService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var AttachmentService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $attachmentService;
|
private $attachmentService;
|
||||||
/** @var BoardService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var BoardService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $boardService;
|
private $boardService;
|
||||||
|
|
||||||
public function setUp() {
|
public function setUp() {
|
||||||
|
|||||||
105
tests/unit/controller/AttachmentControllerTest.php
Normal file
105
tests/unit/controller/AttachmentControllerTest.php
Normal file
@@ -0,0 +1,105 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2018 Julius Härtl <jus@bitgrid.net>
|
||||||
|
*
|
||||||
|
* @author Julius Härtl <jus@bitgrid.net>
|
||||||
|
*
|
||||||
|
* @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\Controller;
|
||||||
|
|
||||||
|
use OCA\Deck\Db\Acl;
|
||||||
|
use OCA\Deck\Service\AttachmentService;
|
||||||
|
use OCA\Deck\Service\CardService;
|
||||||
|
use OCA\Deck\Service\LabelService;
|
||||||
|
use OCA\Deck\Service\StackService;
|
||||||
|
use OCP\AppFramework\Controller;
|
||||||
|
use OCP\IRequest;
|
||||||
|
|
||||||
|
class AttachmentControllerTest extends \Test\TestCase {
|
||||||
|
|
||||||
|
/** @var Controller|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
|
private $controller;
|
||||||
|
/** @var IRequest|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
|
private $request;
|
||||||
|
/** @var AttachmentService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
|
private $attachmentService;
|
||||||
|
/** @var string */
|
||||||
|
private $userId = 'user';
|
||||||
|
|
||||||
|
public function setUp() {
|
||||||
|
$this->request = $this->createMock(IRequest::class);
|
||||||
|
$this->attachmentService = $this->createMock(AttachmentService::class);
|
||||||
|
$this->controller = new AttachmentController(
|
||||||
|
'deck',
|
||||||
|
$this->request,
|
||||||
|
$this->attachmentService,
|
||||||
|
$this->userId
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetAll() {
|
||||||
|
$this->attachmentService->expects($this->once())->method('findAll')->with(1);
|
||||||
|
$this->controller->getAll(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDisplay() {
|
||||||
|
$this->attachmentService->expects($this->once())->method('display')->with(1, 2);
|
||||||
|
$this->controller->display(1, 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreate() {
|
||||||
|
$this->request->expects($this->exactly(2))
|
||||||
|
->method('getParam')
|
||||||
|
->will($this->onConsecutiveCalls('type', 'data'));
|
||||||
|
$this->attachmentService->expects($this->once())
|
||||||
|
->method('create')
|
||||||
|
->with(1, 'type', 'data')
|
||||||
|
->willReturn(1);
|
||||||
|
$this->assertEquals(1, $this->controller->create(1));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testUpdate() {
|
||||||
|
$this->request->expects($this->exactly(1))
|
||||||
|
->method('getParam')
|
||||||
|
->will($this->onConsecutiveCalls('data'));
|
||||||
|
$this->attachmentService->expects($this->once())
|
||||||
|
->method('update')
|
||||||
|
->with(1, 2, 'data')
|
||||||
|
->willReturn(1);
|
||||||
|
$this->assertEquals(1, $this->controller->update(1, 2));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function testDelete() {
|
||||||
|
$this->attachmentService->expects($this->once())
|
||||||
|
->method('delete')
|
||||||
|
->with(123, 234)
|
||||||
|
->willReturn(1);
|
||||||
|
$this->assertEquals(1, $this->controller->delete(123, 234));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testRestore() {
|
||||||
|
$this->attachmentService->expects($this->once())
|
||||||
|
->method('restore')
|
||||||
|
->with(123, 234)
|
||||||
|
->willReturn(1);
|
||||||
|
$this->assertEquals(1, $this->controller->restore(123, 234));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -26,7 +26,7 @@ namespace OCA\Deck\Controller;
|
|||||||
use OCA\Deck\Db\Acl;
|
use OCA\Deck\Db\Acl;
|
||||||
use OCP\IUser;
|
use OCP\IUser;
|
||||||
|
|
||||||
class BoardControllerTest extends \PHPUnit_Framework_TestCase {
|
class BoardControllerTest extends \Test\TestCase {
|
||||||
|
|
||||||
private $controller;
|
private $controller;
|
||||||
private $request;
|
private $request;
|
||||||
|
|||||||
@@ -27,13 +27,13 @@ use OCA\Deck\Service\CardService;
|
|||||||
use OCP\AppFramework\Controller;
|
use OCP\AppFramework\Controller;
|
||||||
use OCP\IRequest;
|
use OCP\IRequest;
|
||||||
|
|
||||||
class CardControllerTest extends \PHPUnit_Framework_TestCase {
|
class CardControllerTest extends \Test\TestCase {
|
||||||
|
|
||||||
/** @var CardController|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var CardController|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $controller;
|
private $controller;
|
||||||
/** @var IRequest|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var IRequest|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $request;
|
private $request;
|
||||||
/** @var CardService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var CardService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $cardService;
|
private $cardService;
|
||||||
/** @var string */
|
/** @var string */
|
||||||
private $userId = 'user';
|
private $userId = 'user';
|
||||||
|
|||||||
@@ -29,13 +29,13 @@ use OCA\Deck\Service\LabelService;
|
|||||||
use OCP\AppFramework\Controller;
|
use OCP\AppFramework\Controller;
|
||||||
use OCP\IRequest;
|
use OCP\IRequest;
|
||||||
|
|
||||||
class LabelControllerTest extends \PHPUnit_Framework_TestCase {
|
class LabelControllerTest extends \Test\TestCase {
|
||||||
|
|
||||||
/** @var Controller|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var Controller|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $controller;
|
private $controller;
|
||||||
/** @var IRequest|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var IRequest|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $request;
|
private $request;
|
||||||
/** @var LabelService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var LabelService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $labelService;
|
private $labelService;
|
||||||
/** @var string */
|
/** @var string */
|
||||||
private $userId = 'user';
|
private $userId = 'user';
|
||||||
|
|||||||
@@ -25,7 +25,7 @@ namespace OCA\Deck\Controller;
|
|||||||
|
|
||||||
use PHPUnit_Framework_TestCase;
|
use PHPUnit_Framework_TestCase;
|
||||||
|
|
||||||
class PageControllerTest extends \PHPUnit_Framework_TestCase {
|
class PageControllerTest extends \Test\TestCase {
|
||||||
|
|
||||||
private $controller;
|
private $controller;
|
||||||
private $request;
|
private $request;
|
||||||
|
|||||||
@@ -30,13 +30,13 @@ use OCA\Deck\Service\StackService;
|
|||||||
use OCP\AppFramework\Controller;
|
use OCP\AppFramework\Controller;
|
||||||
use OCP\IRequest;
|
use OCP\IRequest;
|
||||||
|
|
||||||
class StackControllerTest extends \PHPUnit_Framework_TestCase {
|
class StackControllerTest extends \Test\TestCase {
|
||||||
|
|
||||||
/** @var Controller|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var Controller|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $controller;
|
private $controller;
|
||||||
/** @var IRequest|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var IRequest|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $request;
|
private $request;
|
||||||
/** @var StackService|\PHPUnit_Framework_MockObject_MockObject */
|
/** @var StackService|\PHPUnit\Framework\MockObject\MockObject */
|
||||||
private $stackService;
|
private $stackService;
|
||||||
/** @var string */
|
/** @var string */
|
||||||
private $userId = 'user';
|
private $userId = 'user';
|
||||||
|
|||||||
Reference in New Issue
Block a user