From fff6082e3cd9382ceaba99d111bbd2faa65722d3 Mon Sep 17 00:00:00 2001 From: "J. King" Date: Tue, 31 Oct 2017 18:12:50 -0400 Subject: [PATCH] Adjust TTRSS catchupFeed to use shallow subscription listing --- lib/REST/TinyTinyRSS/API.php | 13 +++++++------ tests/REST/TinyTinyRSS/TestTinyTinyAPI.php | 3 ++- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/lib/REST/TinyTinyRSS/API.php b/lib/REST/TinyTinyRSS/API.php index b74e4424..51938480 100644 --- a/lib/REST/TinyTinyRSS/API.php +++ b/lib/REST/TinyTinyRSS/API.php @@ -19,8 +19,9 @@ use JKingWeb\Arsse\REST\Response; Protocol difference so far: - Handling of incorrect Content-Type and/or HTTP method is different - - TT-RSS accepts whitespace-only names; we do not + - TT-RSS accepts whitespace-only names for categories, labels, and feeds; we do not - TT-RSS allows two folders to share the same name under the same parent; we do not + - TT-RSS requires the user to choose in the face of multiple found feeds during discovery; we use the first one (picoFeed limitation) - Session lifetime is much shorter by default - Categories and feeds will always be sorted alphabetically (the protocol does not allow for clients to re-order) - The "Archived" virtual feed is non-functional (the protocol does not allow archiving) @@ -873,14 +874,14 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler { try { $tr = Arsse::$db->begin(); // filter the subscription list to return only uncategorized, and get their IDs - $list = array_column(array_filter(Arsse::$db->subscriptionList(Arsse::$user->id)->getAll(), function($value) {return is_null($value['folder']);}), "id"); + $list = array_column(Arsse::$db->subscriptionList(Arsse::$user->id, null, false)->getAll(), "id"); // perform marking for each applicable subscription foreach ($list as $id) { Arsse::$db->articleMark(Arsse::$user->id, ['read' => true], (new Context)->subscription($id)); } $tr->commit(); - } catch (ExceptionInput $e) { - // ignore errors + } catch (ExceptionInput $e) { // @codeCoverageIgnore + // ignore errors; none should occur } return $out; case self::CAT_LABELS: @@ -894,8 +895,8 @@ class API extends \JKingWeb\Arsse\REST\AbstractHandler { Arsse::$db->articleMark(Arsse::$user->id, ['read' => true], (new Context)->label($id)); } $tr->commit(); - } catch (ExceptionInput $e) { - // ignore errors + } catch (ExceptionInput $e) { // @codeCoverageIgnore + // ignore errors; none should occur } return $out; default: diff --git a/tests/REST/TinyTinyRSS/TestTinyTinyAPI.php b/tests/REST/TinyTinyRSS/TestTinyTinyAPI.php index 19555f05..f10912b3 100644 --- a/tests/REST/TinyTinyRSS/TestTinyTinyAPI.php +++ b/tests/REST/TinyTinyRSS/TestTinyTinyAPI.php @@ -927,7 +927,8 @@ class TestTinyTinyAPI extends Test\AbstractTest { // reset the database mock $this->setUp(); Phake::when(Arsse::$db)->articleMark->thenReturn(42); - Phake::when(Arsse::$db)->subscriptionList($this->anything())->thenReturn(new Result($this->subscriptions)); + Phake::when(Arsse::$db)->subscriptionList->thenReturn(new Result($this->subscriptions)); + Phake::when(Arsse::$db)->subscriptionList($this->anything(), null, false)->thenReturn(new Result(array_filter($this->subscriptions, function($value) {return is_null($value['folder']);}))); Phake::when(Arsse::$db)->labelList->thenReturn(new Result($this->labels)); Phake::when(Arsse::$db)->labelList($this->anything(), false)->thenReturn(new Result($this->usedLabels)); // verify the complex contexts