mirror of
https://github.com/chylex/Nextcloud-News.git
synced 2024-11-21 22:42:48 +01:00
7a2b3ccfa8
Signed-off-by: Sean Molenaar <sean@seanmolenaar.eu>
192 lines
6.8 KiB
PHP
192 lines
6.8 KiB
PHP
<?php
|
|
/**
|
|
* @author Sean Molenaar <sean@seanmolenaar.eu>
|
|
*
|
|
* @license AGPL-3.0
|
|
*
|
|
* This code is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License, version 3,
|
|
* as published by the Free Software Foundation.
|
|
*
|
|
* 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, version 3,
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
*
|
|
*/
|
|
|
|
namespace OCA\News\Tests\Unit\Command;
|
|
|
|
use OCA\News\Command\Debug\FolderItemList;
|
|
use OCA\News\Command\Updater\UpdateFeed;
|
|
use OCA\News\Service\ItemServiceV2;
|
|
use PHPUnit\Framework\MockObject\MockObject;
|
|
use PHPUnit\Framework\TestCase;
|
|
use Symfony\Component\Console\Input\InputInterface;
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
|
|
|
class FolderItemListTest extends TestCase
|
|
{
|
|
/** @var MockObject|ItemServiceV2 */
|
|
protected $service;
|
|
/** @var MockObject|InputInterface */
|
|
protected $consoleInput;
|
|
/** @var MockObject|OutputInterface */
|
|
protected $consoleOutput;
|
|
|
|
/** @var FolderItemList */
|
|
protected $command;
|
|
|
|
protected function setUp(): void
|
|
{
|
|
$this->service = $this->getMockBuilder(ItemServiceV2::class)
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
|
|
$this->consoleInput = $this->getMockBuilder(InputInterface::class)->getMock();
|
|
$this->consoleOutput = $this->getMockBuilder(OutputInterface::class)->getMock();
|
|
|
|
$this->command = new FolderItemList($this->service);
|
|
}
|
|
|
|
/**
|
|
* Test a valid call will work
|
|
*/
|
|
public function testInvalidFolderId()
|
|
{
|
|
$this->consoleInput->expects($this->exactly(2))
|
|
->method('getArgument')
|
|
->will($this->returnValueMap([
|
|
['user-id', 'admin'],
|
|
['folder', 'a'],
|
|
]));
|
|
|
|
$this->consoleOutput->expects($this->exactly(1))
|
|
->method('writeln')
|
|
->with('Invalid folder ID!');
|
|
|
|
$result = $this->command->run($this->consoleInput, $this->consoleOutput);
|
|
$this->assertSame(255, $result);
|
|
}
|
|
|
|
/**
|
|
* Test a valid call will work
|
|
*/
|
|
public function testInvalidLimit()
|
|
{
|
|
$this->consoleInput->expects($this->exactly(2))
|
|
->method('getArgument')
|
|
->will($this->returnValueMap([
|
|
['user-id', 'admin'],
|
|
['folder', '1'],
|
|
]));
|
|
$this->consoleInput->expects($this->exactly(1))
|
|
->method('getOption')
|
|
->will($this->returnValueMap([
|
|
['limit', 'admin'],
|
|
]));
|
|
|
|
$this->consoleOutput->expects($this->exactly(1))
|
|
->method('writeln')
|
|
->with('Invalid limit!');
|
|
|
|
$result = $this->command->run($this->consoleInput, $this->consoleOutput);
|
|
$this->assertSame(255, $result);
|
|
}
|
|
|
|
/**
|
|
* Test a valid call will work
|
|
*/
|
|
public function testInvalidOffset()
|
|
{
|
|
$this->consoleInput->expects($this->exactly(2))
|
|
->method('getArgument')
|
|
->will($this->returnValueMap([
|
|
['user-id', 'admin'],
|
|
['folder', '1'],
|
|
]));
|
|
$this->consoleInput->expects($this->exactly(2))
|
|
->method('getOption')
|
|
->will($this->returnValueMap([
|
|
['limit', '1'],
|
|
['offset', 'admin'],
|
|
]));
|
|
|
|
$this->consoleOutput->expects($this->exactly(1))
|
|
->method('writeln')
|
|
->with('Invalid offset!');
|
|
|
|
$result = $this->command->run($this->consoleInput, $this->consoleOutput);
|
|
$this->assertSame(255, $result);
|
|
}
|
|
|
|
/**
|
|
* Test a valid call will work
|
|
*/
|
|
public function testValid()
|
|
{
|
|
$this->consoleInput->expects($this->exactly(2))
|
|
->method('getArgument')
|
|
->will($this->returnValueMap([
|
|
['user-id', 'admin'],
|
|
['folder', '1'],
|
|
]));
|
|
$this->consoleInput->expects($this->exactly(4))
|
|
->method('getOption')
|
|
->will($this->returnValueMap([
|
|
['limit', '1'],
|
|
['offset', '2'],
|
|
['reverse-sort', false],
|
|
['hide-read', false],
|
|
]));
|
|
|
|
$this->service->expects($this->exactly(1))
|
|
->method('findAllInFolderWithFilters')
|
|
->with('admin', 1, 1, 2, false, false)
|
|
->willReturn([]);
|
|
|
|
$this->consoleOutput->expects($this->exactly(1))
|
|
->method('writeln')
|
|
->with('[]');
|
|
|
|
$result = $this->command->run($this->consoleInput, $this->consoleOutput);
|
|
$this->assertSame(0, $result);
|
|
}
|
|
|
|
/**
|
|
* Test a valid call will work
|
|
*/
|
|
public function testValidNullFolder()
|
|
{
|
|
$this->consoleInput->expects($this->exactly(2))
|
|
->method('getArgument')
|
|
->will($this->returnValueMap([
|
|
['user-id', 'admin'],
|
|
['folder', null],
|
|
]));
|
|
$this->consoleInput->expects($this->exactly(4))
|
|
->method('getOption')
|
|
->will($this->returnValueMap([
|
|
['limit', '1'],
|
|
['offset', '2'],
|
|
['reverse-sort', false],
|
|
['hide-read', false],
|
|
]));
|
|
|
|
$this->service->expects($this->exactly(1))
|
|
->method('findAllInFolderWithFilters')
|
|
->with('admin', null, 1, 2, false, false)
|
|
->willReturn([]);
|
|
|
|
$this->consoleOutput->expects($this->exactly(1))
|
|
->method('writeln')
|
|
->with('[]');
|
|
|
|
$result = $this->command->run($this->consoleInput, $this->consoleOutput);
|
|
$this->assertSame(0, $result);
|
|
}
|
|
}
|