summaryrefslogtreecommitdiffstats
path: root/tests/Unit/Command/FeedItemListTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'tests/Unit/Command/FeedItemListTest.php')
-rw-r--r--tests/Unit/Command/FeedItemListTest.php158
1 files changed, 158 insertions, 0 deletions
diff --git a/tests/Unit/Command/FeedItemListTest.php b/tests/Unit/Command/FeedItemListTest.php
new file mode 100644
index 000000000..37f34e398
--- /dev/null
+++ b/tests/Unit/Command/FeedItemListTest.php
@@ -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);
+ }
+}