Created index tests for StackApiTestController

Signed-off-by: Ryan Fletcher <ryan.fletcher@codepassion.ca>
This commit is contained in:
Ryan Fletcher
2018-07-15 15:35:48 -04:00
committed by Julius Härtl
parent 54f110f7c6
commit 891fa7b7d5
5 changed files with 125 additions and 42 deletions

View File

@@ -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;
} }

View File

@@ -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']);

View File

@@ -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();
} }
/** /**

View File

@@ -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']);

View 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);
}
}