Created index tests for StackApiTestController
Signed-off-by: Ryan Fletcher <ryan.fletcher@codepassion.ca>
This commit is contained in:
committed by
Julius Härtl
parent
54f110f7c6
commit
891fa7b7d5
@@ -38,7 +38,7 @@ class ApiHelper {
|
|||||||
$entity = $service->find($entityId);
|
$entity = $service->find($entityId);
|
||||||
|
|
||||||
if ($entity === false || $entity === null) {
|
if ($entity === false || $entity === null) {
|
||||||
$error['message'] = $entityName . ' does not exist';
|
$error['message'] = $entityName . ' not found';
|
||||||
$error['status'] = HTTP::STATUS_NOT_FOUND;
|
$error['status'] = HTTP::STATUS_NOT_FOUND;
|
||||||
return $error;
|
return $error;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -66,17 +66,13 @@ class StackApiController extends ApiController {
|
|||||||
* Return all of the stacks in the specified board.
|
* Return all of the stacks in the specified board.
|
||||||
*/
|
*/
|
||||||
public function index() {
|
public function index() {
|
||||||
$boardError = $this->apiHelper->entityHasError($this->request->params['boardId'], 'board', $this->boardService);
|
$boardError = $this->apiHelper->entityHasError($this->request->getParam('boardId'), 'board', $this->boardService);
|
||||||
|
|
||||||
if ($boardError) {
|
if ($boardError) {
|
||||||
return new DataResponse($boardError['message'], $boardError['status']);
|
return new DataResponse($boardError['message'], $boardError['status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$stacks = $this->service->findAll($this->request->params['boardId']);
|
$stacks = $this->service->findAll($this->request->getParam('boardId'));
|
||||||
|
|
||||||
if ($stacks === false || $stacks === null) {
|
|
||||||
return new DataResponse('No Stacks Found', HTTP::STATUS_NOT_FOUND);
|
|
||||||
}
|
|
||||||
|
|
||||||
return new DataResponse($stacks, HTTP::STATUS_OK);
|
return new DataResponse($stacks, HTTP::STATUS_OK);
|
||||||
}
|
}
|
||||||
@@ -89,7 +85,7 @@ class StackApiController extends ApiController {
|
|||||||
* Return all of the stacks in the specified board.
|
* Return all of the stacks in the specified board.
|
||||||
*/
|
*/
|
||||||
public function get() {
|
public function get() {
|
||||||
$boardError = $this->apiHelper->entityHasError($this->request->params['boardId'], 'board', $this->boardService);
|
$boardError = $this->apiHelper->entityHasError($this->request->getParam('boardId'), 'board', $this->boardService);
|
||||||
|
|
||||||
if ($boardError) {
|
if ($boardError) {
|
||||||
return new DataResponse($boardError['message'], $boardError['status']);
|
return new DataResponse($boardError['message'], $boardError['status']);
|
||||||
@@ -116,7 +112,7 @@ class StackApiController extends ApiController {
|
|||||||
*/
|
*/
|
||||||
public function create($title, $order) {
|
public function create($title, $order) {
|
||||||
|
|
||||||
$boardError = $this->apiHelper->entityHasError( $this->request->params['boardId'], 'board', $this->boardService );
|
$boardError = $this->apiHelper->entityHasError( $this->request->getParam('boardId'), 'board', $this->boardService );
|
||||||
|
|
||||||
if ($boardError) {
|
if ($boardError) {
|
||||||
return new DataResponse($boardError['message'], $boardError['status']);
|
return new DataResponse($boardError['message'], $boardError['status']);
|
||||||
@@ -127,7 +123,7 @@ class StackApiController extends ApiController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$stack = $this->service->create($title, $this->request->params['boardId'], $order);
|
$stack = $this->service->create($title, $this->request->getParam('boardId'), $order);
|
||||||
} catch (StatusException $e) {
|
} catch (StatusException $e) {
|
||||||
$errorMessage['error'] = $e->getMessage();
|
$errorMessage['error'] = $e->getMessage();
|
||||||
return new DataResponse($errorMessage, HTTP::STATUS_INTERNAL_SERVER_ERROR);
|
return new DataResponse($errorMessage, HTTP::STATUS_INTERNAL_SERVER_ERROR);
|
||||||
@@ -148,7 +144,7 @@ class StackApiController extends ApiController {
|
|||||||
*/
|
*/
|
||||||
public function update($title, $order) {
|
public function update($title, $order) {
|
||||||
|
|
||||||
$boardError = $this->apiHelper->entityHasError( $this->request->params['boardId'], 'board', $this->boardService );
|
$boardError = $this->apiHelper->entityHasError( $this->request->getParam('boardId'), 'board', $this->boardService );
|
||||||
|
|
||||||
if ($boardError) {
|
if ($boardError) {
|
||||||
return new DataResponse($boardError['message'], $boardError['status']);
|
return new DataResponse($boardError['message'], $boardError['status']);
|
||||||
@@ -163,7 +159,7 @@ class StackApiController extends ApiController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$stack = $this->service->update($this->request->params['stackId'], $title, $this->request->params['boardId'], $order);
|
$stack = $this->service->update($this->request->params['stackId'], $title, $this->request->getParam('boardId'), $order);
|
||||||
|
|
||||||
if ($stack === false || $stack === null) {
|
if ($stack === false || $stack === null) {
|
||||||
return new DataResponse('Stack not found', HTTP::STATUS_NOT_FOUND);
|
return new DataResponse('Stack not found', HTTP::STATUS_NOT_FOUND);
|
||||||
@@ -184,7 +180,7 @@ class StackApiController extends ApiController {
|
|||||||
*/
|
*/
|
||||||
public function delete() {
|
public function delete() {
|
||||||
|
|
||||||
$boardError = $this->apiHelper->entityHasError( $this->request->params['boardId'], 'board', $this->boardService );
|
$boardError = $this->apiHelper->entityHasError( $this->request->getParam('boardId'), 'board', $this->boardService );
|
||||||
|
|
||||||
if ($boardError) {
|
if ($boardError) {
|
||||||
return new DataResponse($boardError['message'], $boardError['status']);
|
return new DataResponse($boardError['message'], $boardError['status']);
|
||||||
|
|||||||
@@ -146,11 +146,11 @@ class PermissionService {
|
|||||||
public function userIsBoardOwner($boardId) {
|
public function userIsBoardOwner($boardId) {
|
||||||
try {
|
try {
|
||||||
$board = $this->boardMapper->find($boardId);
|
$board = $this->boardMapper->find($boardId);
|
||||||
|
return $board && $this->userId === $board->getOwner();
|
||||||
} catch (DoesNotExistException $e) {
|
} catch (DoesNotExistException $e) {
|
||||||
} catch (MultipleObjectsReturnedException $e) {
|
} catch (MultipleObjectsReturnedException $e) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return $board && $this->userId === $board->getOwner();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -120,32 +120,6 @@ class BoardApiControllerTest extends \Test\TestCase {
|
|||||||
$this->assertEquals($expected, $actual);
|
$this->assertEquals($expected, $actual);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testGetNoPermission() {
|
|
||||||
|
|
||||||
$board = new Board();
|
|
||||||
$board->setId($this->deniedBoard['id']);
|
|
||||||
$board->setOwner($this->deniedBoard['owner']);
|
|
||||||
$this->boardService->expects($this->once())
|
|
||||||
->method('find')
|
|
||||||
->willReturn($board);
|
|
||||||
|
|
||||||
// permission service check.
|
|
||||||
// ------ there be dragons here -----
|
|
||||||
// $this->permissionsService->expect($this->once())
|
|
||||||
// ->method('matchPermissions')
|
|
||||||
// ->with($board)
|
|
||||||
// ->will($this->)
|
|
||||||
|
|
||||||
$this->request->expects($this->any())
|
|
||||||
->method('getParam')
|
|
||||||
->with('boardId')
|
|
||||||
->will($this->returnValue('999'));
|
|
||||||
|
|
||||||
$expected = new DataResponse("Access Denied: User has no access rights to board", HTTP::STATUS_FORBIDDEN);
|
|
||||||
$actual = $this->controller->get();
|
|
||||||
$this->assertEquals($expected, $actual);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testCreate() {
|
public function testCreate() {
|
||||||
$board = new Board();
|
$board = new Board();
|
||||||
$board->setId($this->exampleBoard['id']);
|
$board->setId($this->exampleBoard['id']);
|
||||||
|
|||||||
113
tests/unit/controller/StackApiControllerTest.php
Normal file
113
tests/unit/controller/StackApiControllerTest.php
Normal file
@@ -0,0 +1,113 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2018 Ryan Fletcher <ryan.fletcher@codepassion.ca>
|
||||||
|
*
|
||||||
|
* @author Ryan Fletcher <ryan.fletcher@codepassion.ca>
|
||||||
|
*
|
||||||
|
* @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 OCP\AppFramework\Http;
|
||||||
|
use OCP\AppFramework\Http\DataResponse;
|
||||||
|
use OCP\IRequest;
|
||||||
|
|
||||||
|
use OCA\Deck\Service\BoardService;
|
||||||
|
use OCA\Deck\Service\StackService;
|
||||||
|
use OCA\Deck\Db\Board;
|
||||||
|
use OCA\Deck\Db\Stack;
|
||||||
|
|
||||||
|
class StackApiControllerTest extends \Test\TestCase {
|
||||||
|
|
||||||
|
private $appName = 'deck';
|
||||||
|
private $userId = 'admin';
|
||||||
|
private $controller;
|
||||||
|
private $boardService;
|
||||||
|
private $stackService;
|
||||||
|
private $exampleStack;
|
||||||
|
private $exampleBoard;
|
||||||
|
|
||||||
|
public function setUp() {
|
||||||
|
parent::setUp();
|
||||||
|
$this->request = $this->createMock(IRequest::class);
|
||||||
|
$this->boardService = $this->createMock(BoardService::class);
|
||||||
|
$this->stackService = $this->createMock(StackService::class);
|
||||||
|
|
||||||
|
$this->exampleStack['id'] = 345;
|
||||||
|
$this->exampleStack['boardId'] = 245;
|
||||||
|
$this->exampleStack['order'] = 0;
|
||||||
|
|
||||||
|
$this->exampleBoard['boardId'] = '89';
|
||||||
|
|
||||||
|
$this->controller = new StackApiController(
|
||||||
|
$this->appName,
|
||||||
|
$this->request,
|
||||||
|
$this->stackService,
|
||||||
|
$this->boardService
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testIndex() {
|
||||||
|
$stack = new Stack();
|
||||||
|
$stack->setId($this->exampleStack['id']);
|
||||||
|
$stack->setBoardId($this->exampleStack['boardId']);
|
||||||
|
$stack->setOrder($this->exampleStack['order']);
|
||||||
|
$stacks = [$stack];
|
||||||
|
|
||||||
|
$board = new Board();
|
||||||
|
$board->setId($this->exampleBoard['boardId']);
|
||||||
|
$this->boardService->expects($this->once())
|
||||||
|
->method('find')
|
||||||
|
->willReturn($board);
|
||||||
|
|
||||||
|
$this->stackService->expects($this->once())
|
||||||
|
->method('findAll')
|
||||||
|
->willReturn($stacks);
|
||||||
|
|
||||||
|
$this->request->expects($this->any())
|
||||||
|
->method('getParam')
|
||||||
|
->with('boardId')
|
||||||
|
->will($this->returnValue($this->exampleBoard['boardId']));
|
||||||
|
|
||||||
|
$expected = new DataResponse($stacks, HTTP::STATUS_OK);
|
||||||
|
$actual = $this->controller->index();
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testIndexBadBoardId() {
|
||||||
|
$this->request->expects($this->any())
|
||||||
|
->method('getParam')
|
||||||
|
->with('boardId')
|
||||||
|
->will($this->returnValue('bad board id'));
|
||||||
|
|
||||||
|
$expected = new DataResponse('board id must be a number', HTTP::STATUS_BAD_REQUEST);
|
||||||
|
$actual = $this->controller->index();
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testIndexBoardNotFound() {
|
||||||
|
$this->request->expects($this->any())
|
||||||
|
->method('getParam')
|
||||||
|
->with('boardId')
|
||||||
|
->will($this->returnValue(689));
|
||||||
|
|
||||||
|
$expected = new DataResponse('board not found', HTTP::STATUS_NOT_FOUND);
|
||||||
|
$actual = $this->controller->index();
|
||||||
|
$this->assertEquals($expected, $actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user