mirror of
https://github.com/chylex/Nextcloud-News.git
synced 2025-05-13 19:34:05 +02:00
chore: Improve test coverage
Signed-off-by: Sean Molenaar <sean@seanmolenaar.eu>
This commit is contained in:
parent
a6c9b30d58
commit
7a2b3ccfa8
@ -10,6 +10,7 @@ The format is almost based on [Keep a Changelog](https://keepachangelog.com/en/1
|
||||
- Update serialization of item to include categories (#1248)
|
||||
- Make PHPStan stricter
|
||||
- Restore search in news
|
||||
- Improve test coverage
|
||||
|
||||
### Fixed
|
||||
- Do not show deleted feeds in item list
|
||||
|
@ -63,7 +63,7 @@ class FeedItemList extends Command
|
||||
|
||||
$feed = $input->getArgument('feed');
|
||||
if (!is_numeric($feed)) {
|
||||
$output->writeln('Invalid Type!');
|
||||
$output->writeln('Invalid feed ID!');
|
||||
return 255;
|
||||
}
|
||||
|
||||
|
@ -63,7 +63,7 @@ class ItemList extends Command
|
||||
|
||||
$type = $input->getOption('type');
|
||||
if (!is_numeric($type)) {
|
||||
$output->writeln('Invalid Type!');
|
||||
$output->writeln('Invalid type!');
|
||||
return 255;
|
||||
}
|
||||
$limit = $input->getOption('limit');
|
||||
|
158
tests/Unit/Command/FeedItemListTest.php
Normal file
158
tests/Unit/Command/FeedItemListTest.php
Normal file
@ -0,0 +1,158 @@
|
||||
<?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\FeedItemList;
|
||||
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 FeedItemListTest extends TestCase
|
||||
{
|
||||
/** @var MockObject|ItemServiceV2 */
|
||||
protected $service;
|
||||
/** @var MockObject|InputInterface */
|
||||
protected $consoleInput;
|
||||
/** @var MockObject|OutputInterface */
|
||||
protected $consoleOutput;
|
||||
|
||||
/** @var FeedItemList */
|
||||
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 FeedItemList($this->service);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test a valid call will work
|
||||
*/
|
||||
public function testInvalidFeedId()
|
||||
{
|
||||
$this->consoleInput->expects($this->exactly(2))
|
||||
->method('getArgument')
|
||||
->will($this->returnValueMap([
|
||||
['user-id', 'admin'],
|
||||
['feed', 'a'],
|
||||
]));
|
||||
|
||||
$this->consoleOutput->expects($this->exactly(1))
|
||||
->method('writeln')
|
||||
->with('Invalid feed 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'],
|
||||
['feed', '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'],
|
||||
['feed', '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'],
|
||||
['feed', '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('findAllInFeedWithFilters')
|
||||
->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);
|
||||
}
|
||||
}
|
191
tests/Unit/Command/FolderItemListTest.php
Normal file
191
tests/Unit/Command/FolderItemListTest.php
Normal file
@ -0,0 +1,191 @@
|
||||
<?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);
|
||||
}
|
||||
}
|
156
tests/Unit/Command/ItemListTest.php
Normal file
156
tests/Unit/Command/ItemListTest.php
Normal file
@ -0,0 +1,156 @@
|
||||
<?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\ItemList;
|
||||
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 ItemListTest extends TestCase
|
||||
{
|
||||
/** @var MockObject|ItemServiceV2 */
|
||||
protected $service;
|
||||
/** @var MockObject|InputInterface */
|
||||
protected $consoleInput;
|
||||
/** @var MockObject|OutputInterface */
|
||||
protected $consoleOutput;
|
||||
|
||||
/** @var ItemList */
|
||||
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 ItemList($this->service);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test a valid call will work
|
||||
*/
|
||||
public function testInvalidType()
|
||||
{
|
||||
$this->consoleInput->expects($this->exactly(1))
|
||||
->method('getArgument')
|
||||
->will($this->returnValueMap([
|
||||
['user-id', 'admin'],
|
||||
]));
|
||||
|
||||
$this->consoleOutput->expects($this->exactly(1))
|
||||
->method('writeln')
|
||||
->with('Invalid type!');
|
||||
|
||||
$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(1))
|
||||
->method('getArgument')
|
||||
->will($this->returnValueMap([
|
||||
['user-id', 'admin'],
|
||||
]));
|
||||
$this->consoleInput->expects($this->exactly(2))
|
||||
->method('getOption')
|
||||
->will($this->returnValueMap([
|
||||
['type', '1'],
|
||||
['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(1))
|
||||
->method('getArgument')
|
||||
->will($this->returnValueMap([
|
||||
['user-id', 'admin'],
|
||||
]));
|
||||
$this->consoleInput->expects($this->exactly(3))
|
||||
->method('getOption')
|
||||
->will($this->returnValueMap([
|
||||
['type', '1'],
|
||||
['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(1))
|
||||
->method('getArgument')
|
||||
->will($this->returnValueMap([
|
||||
['user-id', 'admin'],
|
||||
]));
|
||||
$this->consoleInput->expects($this->exactly(4))
|
||||
->method('getOption')
|
||||
->will($this->returnValueMap([
|
||||
['type', '1'],
|
||||
['limit', '1'],
|
||||
['offset', '2'],
|
||||
['reverse-sort', false],
|
||||
]));
|
||||
|
||||
$this->service->expects($this->exactly(1))
|
||||
->method('findAllWithFilters')
|
||||
->with('admin', 1, 1, 2, false, [])
|
||||
->willReturn([]);
|
||||
|
||||
$this->consoleOutput->expects($this->exactly(1))
|
||||
->method('writeln')
|
||||
->with('[]');
|
||||
|
||||
$result = $this->command->run($this->consoleInput, $this->consoleOutput);
|
||||
$this->assertSame(0, $result);
|
||||
}
|
||||
}
|
65
tests/Unit/Config/FetcherConfigTest.php
Normal file
65
tests/Unit/Config/FetcherConfigTest.php
Normal file
@ -0,0 +1,65 @@
|
||||
<?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\Config;
|
||||
|
||||
use OCA\News\Command\Debug\ItemList;
|
||||
use OCA\News\Command\Updater\UpdateFeed;
|
||||
use OCA\News\Config\FetcherConfig;
|
||||
use OCA\News\Fetcher\Client\FeedIoClient;
|
||||
use OCA\News\Service\ItemServiceV2;
|
||||
use OCP\IConfig;
|
||||
use PHPUnit\Framework\MockObject\MockObject;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Component\Console\Input\InputInterface;
|
||||
use Symfony\Component\Console\Output\OutputInterface;
|
||||
|
||||
/**
|
||||
* Class FetcherConfigTest
|
||||
*
|
||||
* TODO: Improve this
|
||||
*
|
||||
* @package OCA\News\Tests\Config
|
||||
*/
|
||||
class FetcherConfigTest extends TestCase
|
||||
{
|
||||
/** @var MockObject|IConfig */
|
||||
protected $config;
|
||||
|
||||
/** @var FetcherConfig */
|
||||
protected $class;
|
||||
|
||||
protected function setUp(): void
|
||||
{
|
||||
$this->config = $this->getMockBuilder(IConfig::class)
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
}
|
||||
|
||||
/**
|
||||
* Test a valid call will work
|
||||
*/
|
||||
public function testGetClient()
|
||||
{
|
||||
$this->class = new FetcherConfig($this->config);
|
||||
|
||||
$this->assertInstanceOf(FeedIoClient::class, $this->class->getClient());
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user