mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-05 07:22:40 +00:00
More TT-RSS test conversions to Phony
This commit is contained in:
parent
2d951fb071
commit
a322d034f3
1 changed files with 164 additions and 220 deletions
|
@ -1110,42 +1110,30 @@ LONG_STRING;
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testAssignArticlesToALabel(): void {
|
public function provideLabelAssignments(): iterable {
|
||||||
$list = [
|
$ids = implode(",", range(1, 100));
|
||||||
range(1, 100),
|
return [
|
||||||
range(1, 50),
|
[['label_id' => -2112, 'article_ids' => $ids], 1088, Database::ASSOC_REMOVE, $this->respGood(['status' => "OK", 'updated' => 89])],
|
||||||
range(51, 100),
|
[['label_id' => -2112, 'article_ids' => $ids, 'assign' => true], 1088, Database::ASSOC_ADD, $this->respGood(['status' => "OK", 'updated' => 7])],
|
||||||
|
[['label_id' => -2112], null, null, $this->respGood(['status' => "OK", 'updated' => 0])],
|
||||||
|
[['label_id' => -42], null, null, $this->respErr("INCORRECT_USAGE")],
|
||||||
|
[['label_id' => 42], null, null, $this->respErr("INCORRECT_USAGE")],
|
||||||
|
[['label_id' => 0], null, null, $this->respErr("INCORRECT_USAGE")],
|
||||||
|
[[], null, null, $this->respErr("INCORRECT_USAGE")],
|
||||||
];
|
];
|
||||||
$in = [
|
}
|
||||||
['op' => "setArticleLabel", 'sid' => "PriestsOfSyrinx", 'label_id' => -2112, 'article_ids' => implode(",", $list[0])],
|
|
||||||
['op' => "setArticleLabel", 'sid' => "PriestsOfSyrinx", 'label_id' => -2112, 'article_ids' => implode(",", $list[0]), 'assign' => true],
|
/** @dataProvider provideLabelAssignments */
|
||||||
['op' => "setArticleLabel", 'sid' => "PriestsOfSyrinx", 'label_id' => -2112],
|
public function testAssignArticlesToALabel(array $in, ?int $label, ?int $operation, ResponseInterface $exp): void {
|
||||||
['op' => "setArticleLabel", 'sid' => "PriestsOfSyrinx", 'label_id' => -42],
|
$in = array_merge(['op' => "setArticleLabel", 'sid' => "PriestsOfSyrinx"], $in);
|
||||||
['op' => "setArticleLabel", 'sid' => "PriestsOfSyrinx", 'label_id' => 42],
|
$this->dbMock->labelArticlesSet->with($this->userId, "~", "~", Database::ASSOC_REMOVE)->returns(42)->returns(47);
|
||||||
['op' => "setArticleLabel", 'sid' => "PriestsOfSyrinx", 'label_id' => 0],
|
$this->dbMock->labelArticlesSet->with($this->userId, "~", "~", Database::ASSOC_ADD)->returns(5)->returns(2);
|
||||||
['op' => "setArticleLabel", 'sid' => "PriestsOfSyrinx"],
|
$this->dbMock->labelArticlesSet->with($this->userId, "~", $this->equalTo((new Context)->articles([])), "~")->throws(new ExceptionInput("tooShort"));
|
||||||
];
|
$this->assertMessage($exp, $this->req($in));
|
||||||
\Phake::when(Arsse::$db)->labelArticlesSet($this->userId, $this->anything(), (new Context)->articles([]), $this->anything())->thenThrow(new ExceptionInput("tooShort")); // data model function requires one valid integer for multiples
|
if ($label !== null) {
|
||||||
\Phake::when(Arsse::$db)->labelArticlesSet($this->userId, $this->anything(), (new Context)->articles($list[0]), $this->anything())->thenThrow(new ExceptionInput("tooLong")); // data model function limited to 50 items for multiples
|
$this->dbMock->labelArticlesSet->calledWith($this->userId, $label, $this->equalTo((new Context)->articles(range(1, 50))), $operation);
|
||||||
\Phake::when(Arsse::$db)->labelArticlesSet($this->userId, 1088, (new Context)->articles($list[1]), Database::ASSOC_REMOVE)->thenReturn(42);
|
$this->dbMock->labelArticlesSet->calledWith($this->userId, $label, $this->equalTo((new Context)->articles(range(51, 100))), $operation);
|
||||||
\Phake::when(Arsse::$db)->labelArticlesSet($this->userId, 1088, (new Context)->articles($list[2]), Database::ASSOC_REMOVE)->thenReturn(47);
|
}
|
||||||
\Phake::when(Arsse::$db)->labelArticlesSet($this->userId, 1088, (new Context)->articles($list[1]), Database::ASSOC_ADD)->thenReturn(5);
|
|
||||||
\Phake::when(Arsse::$db)->labelArticlesSet($this->userId, 1088, (new Context)->articles($list[2]), Database::ASSOC_ADD)->thenReturn(2);
|
|
||||||
$exp = $this->respGood(['status' => "OK", 'updated' => 89]);
|
|
||||||
$this->assertMessage($exp, $this->req($in[0]));
|
|
||||||
\Phake::verify(Arsse::$db)->labelArticlesSet($this->userId, 1088, (new Context)->articles($list[1]), Database::ASSOC_REMOVE);
|
|
||||||
\Phake::verify(Arsse::$db)->labelArticlesSet($this->userId, 1088, (new Context)->articles($list[2]), Database::ASSOC_REMOVE);
|
|
||||||
$exp = $this->respGood(['status' => "OK", 'updated' => 7]);
|
|
||||||
$this->assertMessage($exp, $this->req($in[1]));
|
|
||||||
\Phake::verify(Arsse::$db)->labelArticlesSet($this->userId, 1088, (new Context)->articles($list[1]), Database::ASSOC_ADD);
|
|
||||||
\Phake::verify(Arsse::$db)->labelArticlesSet($this->userId, 1088, (new Context)->articles($list[2]), Database::ASSOC_ADD);
|
|
||||||
$exp = $this->respGood(['status' => "OK", 'updated' => 0]);
|
|
||||||
$this->assertMessage($exp, $this->req($in[2]));
|
|
||||||
$exp = $this->respErr("INCORRECT_USAGE");
|
|
||||||
$this->assertMessage($exp, $this->req($in[3]));
|
|
||||||
$this->assertMessage($exp, $this->req($in[4]));
|
|
||||||
$this->assertMessage($exp, $this->req($in[5]));
|
|
||||||
$this->assertMessage($exp, $this->req($in[6]));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testRetrieveFeedTree(): void {
|
public function testRetrieveFeedTree(): void {
|
||||||
|
@ -1208,51 +1196,58 @@ LONG_STRING;
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testRetrieveFeedList(): void {
|
/** @dataProvider provideFeedListings */
|
||||||
$in1 = [
|
public function testRetrieveFeedList(array $in, ResponseInterface $exp): void {
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx"],
|
$in = array_merge(['op' => "getFeeds", 'sid' => "PriestsOfSyrinx"], $in);
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => -1],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => -1, 'unread_only' => true],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => -2],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => -2, 'unread_only' => true],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => -3],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => -3, 'unread_only' => true],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => -4],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => -4, 'unread_only' => true],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 6],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 6, 'limit' => 1],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 6, 'limit' => 1, 'offset' => 1],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 1],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 1, 'include_nested' => true],
|
|
||||||
];
|
|
||||||
$in2 = [
|
|
||||||
// these should all return an empty list
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 0, 'unread_only' => true],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 2112],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 2112, 'include_nested' => true],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 6, 'limit' => -42],
|
|
||||||
['op' => "getFeeds", 'sid' => "PriestsOfSyrinx", 'cat_id' => 6, 'offset' => 2],
|
|
||||||
];
|
|
||||||
// statistical mocks
|
// statistical mocks
|
||||||
\Phake::when(Arsse::$db)->articleStarred($this->anything())->thenReturn($this->v($this->starred));
|
$this->dbMock->articleStarred->returns($this->v($this->starred));
|
||||||
\Phake::when(Arsse::$db)->articleCount($this->anything(), $this->equalTo((new Context)->unread(true)->hidden(false)->modifiedSince(Date::sub("PT24H")), 2))->thenReturn(7);
|
$this->dbMock->articleCount->with("~", $this->equalTo((new Context)->unread(true)->hidden(false)->modifiedSince(Date::sub("PT24H", self::NOW))))->returns(7);
|
||||||
\Phake::when(Arsse::$db)->articleCount($this->anything(), (new Context)->unread(true)->hidden(false))->thenReturn(35);
|
$this->dbMock->articleCount->with("~", $this->equalTo((new Context)->unread(true)->hidden(false)))->returns(35);
|
||||||
// label mocks
|
// label mocks
|
||||||
\Phake::when(Arsse::$db)->labelList($this->anything())->thenReturn(new Result($this->v($this->labels)));
|
$this->dbMock->labelList->returns(new Result($this->v($this->labels)));
|
||||||
\Phake::when(Arsse::$db)->labelList($this->anything(), false)->thenReturn(new Result($this->v($this->usedLabels)));
|
$this->dbMock->labelList->with("~", false)->returns(new Result($this->v($this->usedLabels)));
|
||||||
// subscription and folder list and unread count mocks
|
// subscription and folder list and unread count mocks
|
||||||
\Phake::when(Arsse::$db)->folderList->thenThrow(new ExceptionInput("subjectMissing"));
|
$this->dbMock->folderList->throws(new ExceptionInput("subjectMissing"));
|
||||||
\Phake::when(Arsse::$db)->subscriptionList->thenThrow(new ExceptionInput("subjectMissing"));
|
$this->dbMock->subscriptionList->throws(new ExceptionInput("subjectMissing"));
|
||||||
\Phake::when(Arsse::$db)->folderList($this->anything())->thenReturn(new Result($this->v($this->folders)));
|
$this->dbMock->folderList->with("~")->returns(new Result($this->v($this->folders)));
|
||||||
\Phake::when(Arsse::$db)->subscriptionList($this->anything(), null, true)->thenReturn(new Result($this->v($this->subscriptions)));
|
$this->dbMock->subscriptionList->with("~", null, true)->returns(new Result($this->v($this->subscriptions)));
|
||||||
\Phake::when(Arsse::$db)->subscriptionList($this->anything(), null, false)->thenReturn(new Result($this->v($this->filterSubs(null))));
|
$this->dbMock->subscriptionList->with("~", null, false)->returns(new Result($this->v($this->filterSubs(null))));
|
||||||
\Phake::when(Arsse::$db)->folderList($this->anything(), null)->thenReturn(new Result($this->v($this->folders)));
|
$this->dbMock->folderList->with("~", null)->returns(new Result($this->v($this->folders)));
|
||||||
\Phake::when(Arsse::$db)->folderList($this->anything(), null, false)->thenReturn(new Result($this->v($this->filterFolders(null))));
|
$this->dbMock->folderList->with("~", null, false)->returns(new Result($this->v($this->filterFolders(null))));
|
||||||
foreach ($this->folders as $f) {
|
foreach ($this->folders as $f) {
|
||||||
\Phake::when(Arsse::$db)->folderList($this->anything(), $f['id'], false)->thenReturn(new Result($this->v($this->filterFolders($f['id']))));
|
$this->dbMock->folderList->with("~", $f['id'], false)->returns(new Result($this->v($this->filterFolders($f['id']))));
|
||||||
\Phake::when(Arsse::$db)->articleCount($this->anything(), (new Context)->unread(true)->hidden(false)->folder($f['id']))->thenReturn($this->reduceFolders($f['id']));
|
$this->dbMock->articleCount->with("~", $this->equalTo((new Context)->unread(true)->hidden(false)->folder($f['id'])))->returns($this->reduceFolders($f['id']));
|
||||||
\Phake::when(Arsse::$db)->subscriptionList($this->anything(), $f['id'], false)->thenReturn(new Result($this->v($this->filterSubs($f['id']))));
|
$this->dbMock->subscriptionList->with("~", $f['id'], false)->returns(new Result($this->v($this->filterSubs($f['id']))));
|
||||||
}
|
}
|
||||||
|
$this->assertMessage($exp, $this->req($in));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function filterFolders(int $id = null): array {
|
||||||
|
return array_filter($this->folders, function($value) use ($id) {
|
||||||
|
return $value['parent'] == $id;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function filterSubs(int $folder = null): array {
|
||||||
|
return array_filter($this->subscriptions, function($value) use ($folder) {
|
||||||
|
return $value['folder'] == $folder;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function reduceFolders(int $id = null): int {
|
||||||
|
$out = 0;
|
||||||
|
foreach ($this->filterFolders($id) as $f) {
|
||||||
|
$out += $this->reduceFolders($f['id']);
|
||||||
|
}
|
||||||
|
$out += array_reduce(array_filter($this->subscriptions, function($value) use ($id) {
|
||||||
|
return $value['folder'] == $id;
|
||||||
|
}), function($sum, $value) {
|
||||||
|
return $sum + $value['unread'];
|
||||||
|
}, 0);
|
||||||
|
return $out;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function provideFeedListings(): iterable {
|
||||||
$exp = [
|
$exp = [
|
||||||
[
|
[
|
||||||
['id' => 6, 'title' => 'Eurogamer', 'unread' => 0, 'cat_id' => 0, 'feed_url' => " http://example.com/6", 'has_icon' => true, 'last_updated' => 1266005327, 'order_id' => 1],
|
['id' => 6, 'title' => 'Eurogamer', 'unread' => 0, 'cat_id' => 0, 'feed_url' => " http://example.com/6", 'has_icon' => true, 'last_updated' => 1266005327, 'order_id' => 1],
|
||||||
|
@ -1337,148 +1332,95 @@ LONG_STRING;
|
||||||
['id' => 3, 'title' => 'Ars Technica', 'unread' => 2, 'cat_id' => 1, 'feed_url' => " http://example.com/3", 'has_icon' => true, 'last_updated' => 1463985602, 'order_id' => 1],
|
['id' => 3, 'title' => 'Ars Technica', 'unread' => 2, 'cat_id' => 1, 'feed_url' => " http://example.com/3", 'has_icon' => true, 'last_updated' => 1463985602, 'order_id' => 1],
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
for ($a = 0; $a < sizeof($in1); $a++) {
|
return [
|
||||||
$this->assertMessage($this->respGood($exp[$a]), $this->req($in1[$a]), "Test $a failed");
|
[[], $this->respGood($exp[0])],
|
||||||
}
|
[['cat_id' => -1], $this->respGood($exp[1])],
|
||||||
for ($a = 0; $a < sizeof($in2); $a++) {
|
[['cat_id' => -1, 'unread_only' => true], $this->respGood($exp[2])],
|
||||||
$this->assertMessage($this->respGood([]), $this->req($in2[$a]), "Test $a failed");
|
[['cat_id' => -2], $this->respGood($exp[3])],
|
||||||
}
|
[['cat_id' => -2, 'unread_only' => true], $this->respGood($exp[4])],
|
||||||
}
|
[['cat_id' => -3], $this->respGood($exp[5])],
|
||||||
|
[['cat_id' => -3, 'unread_only' => true], $this->respGood($exp[6])],
|
||||||
protected function filterFolders(int $id = null): array {
|
[['cat_id' => -4], $this->respGood($exp[7])],
|
||||||
return array_filter($this->folders, function($value) use ($id) {
|
[['cat_id' => -4, 'unread_only' => true], $this->respGood($exp[8])],
|
||||||
return $value['parent'] == $id;
|
[['cat_id' => 6], $this->respGood($exp[9])],
|
||||||
});
|
[['cat_id' => 6, 'limit' => 1], $this->respGood($exp[10])],
|
||||||
}
|
[['cat_id' => 6, 'limit' => 1, 'offset' => 1], $this->respGood($exp[11])],
|
||||||
|
[['cat_id' => 1], $this->respGood($exp[12])],
|
||||||
protected function filterSubs(int $folder = null): array {
|
[['cat_id' => 1, 'include_nested' => true], $this->respGood($exp[13])],
|
||||||
return array_filter($this->subscriptions, function($value) use ($folder) {
|
[['cat_id' => 0, 'unread_only' => true], $this->respGood([])],
|
||||||
return $value['folder'] == $folder;
|
[['cat_id' => 2112], $this->respGood([])],
|
||||||
});
|
[['cat_id' => 2112, 'include_nested' => true], $this->respGood([])],
|
||||||
}
|
[['cat_id' => 6, 'limit' => -42], $this->respGood([])],
|
||||||
|
[['cat_id' => 6, 'offset' => 2], $this->respGood([])],
|
||||||
protected function reduceFolders(int $id = null): int {
|
|
||||||
$out = 0;
|
|
||||||
foreach ($this->filterFolders($id) as $f) {
|
|
||||||
$out += $this->reduceFolders($f['id']);
|
|
||||||
}
|
|
||||||
$out += array_reduce(array_filter($this->subscriptions, function($value) use ($id) {
|
|
||||||
return $value['folder'] == $id;
|
|
||||||
}), function($sum, $value) {
|
|
||||||
return $sum + $value['unread'];
|
|
||||||
}, 0);
|
|
||||||
return $out;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testChangeArticles(): void {
|
|
||||||
$in = [
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx"],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1"],
|
|
||||||
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 0],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 0, 'mode' => 0],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 0, 'mode' => 1],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 0, 'mode' => 2],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 0, 'mode' => 3], // invalid mode
|
|
||||||
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 1], // Published feed' no-op
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 1, 'mode' => 0],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 1, 'mode' => 1],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 1, 'mode' => 2],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 1, 'mode' => 3], // invalid mode
|
|
||||||
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 2],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 2, 'mode' => 0],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 2, 'mode' => 1],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 2, 'mode' => 2],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 2, 'mode' => 3], // invalid mode
|
|
||||||
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 3],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 3, 'mode' => 0],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 3, 'mode' => 1],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 3, 'mode' => 2],
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 3, 'mode' => 3], // invalid mode
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 3, 'data' => "eh"],
|
|
||||||
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "42, 2112, -1", 'field' => 4], // invalid field
|
|
||||||
['op' => "updateArticle", 'sid' => "PriestsOfSyrinx", 'article_ids' => "0, -1", 'field' => 3], // no valid IDs
|
|
||||||
];
|
];
|
||||||
\Phake::when(Arsse::$db)->articleList($this->anything(), (new Context)->articles([42, 2112])->starred(true), $this->anything())->thenReturn(new Result($this->v([['id' => 42]])));
|
|
||||||
\Phake::when(Arsse::$db)->articleList($this->anything(), (new Context)->articles([42, 2112])->starred(false), $this->anything())->thenReturn(new Result($this->v([['id' => 2112]])));
|
|
||||||
\Phake::when(Arsse::$db)->articleList($this->anything(), (new Context)->articles([42, 2112])->unread(true), $this->anything())->thenReturn(new Result($this->v([['id' => 42]])));
|
|
||||||
\Phake::when(Arsse::$db)->articleList($this->anything(), (new Context)->articles([42, 2112])->unread(false), $this->anything())->thenReturn(new Result($this->v([['id' => 2112]])));
|
|
||||||
\Phake::when(Arsse::$db)->articleMark->thenReturn(1);
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['starred' => false], (new Context)->articles([42, 2112]))->thenReturn(2);
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['starred' => true], (new Context)->articles([42, 2112]))->thenReturn(4);
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['starred' => false], (new Context)->articles([42]))->thenReturn(8);
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['starred' => true], (new Context)->articles([2112]))->thenReturn(16);
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['read' => true], (new Context)->articles([42, 2112]))->thenReturn(32); // false is read for TT-RSS
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['read' => false], (new Context)->articles([42, 2112]))->thenReturn(64);
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['read' => true], (new Context)->articles([42]))->thenReturn(128);
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['read' => false], (new Context)->articles([2112]))->thenReturn(256);
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['note' => ""], (new Context)->articles([42, 2112]))->thenReturn(512);
|
|
||||||
\Phake::when(Arsse::$db)->articleMark($this->anything(), ['note' => "eh"], (new Context)->articles([42, 2112]))->thenReturn(1024);
|
|
||||||
$out = [
|
|
||||||
$this->respErr("INCORRECT_USAGE"),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 2]),
|
|
||||||
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 2]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 2]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 4]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 24]),
|
|
||||||
$this->respErr("INCORRECT_USAGE"),
|
|
||||||
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 0]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 0]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 0]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 0]),
|
|
||||||
$this->respErr("INCORRECT_USAGE"),
|
|
||||||
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 32]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 32]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 64]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 384]),
|
|
||||||
$this->respErr("INCORRECT_USAGE"),
|
|
||||||
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 512]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 512]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 512]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 512]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 512]),
|
|
||||||
$this->respGood(['status' => "OK", 'updated' => 1024]),
|
|
||||||
|
|
||||||
$this->respErr("INCORRECT_USAGE"),
|
|
||||||
$this->respErr("INCORRECT_USAGE"),
|
|
||||||
];
|
|
||||||
for ($a = 0; $a < sizeof($in); $a++) {
|
|
||||||
$this->assertMessage($out[$a], $this->req($in[$a]), "Test $a failed");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testListArticles(): void {
|
|
||||||
$in = [
|
/** @dataProvider provideArticleChanges */
|
||||||
// error conditions
|
public function testChangeArticles(array $in, ResponseInterface $exp): void {
|
||||||
['op' => "getArticle", 'sid' => "PriestsOfSyrinx"],
|
$in = array_merge(['op' => "updateArticle", 'sid' => "PriestsOfSyrinx"], $in);
|
||||||
['op' => "getArticle", 'sid' => "PriestsOfSyrinx", 'article_id' => 0],
|
$this->dbMock->articleMark->returns(1);
|
||||||
['op' => "getArticle", 'sid' => "PriestsOfSyrinx", 'article_id' => -1],
|
$this->dbMock->articleMark->with($this->userId, ['starred' => false], $this->equalTo((new Context)->articles([42, 2112])))->returns(2);
|
||||||
['op' => "getArticle", 'sid' => "PriestsOfSyrinx", 'article_id' => "0,-1"],
|
$this->dbMock->articleMark->with($this->userId, ['starred' => true], $this->equalTo((new Context)->articles([42, 2112])))->returns(4);
|
||||||
// acceptable input
|
$this->dbMock->articleMark->with($this->userId, ['starred' => false], $this->equalTo((new Context)->articles([42])))->returns(8);
|
||||||
['op' => "getArticle", 'sid' => "PriestsOfSyrinx", 'article_id' => "101,102"],
|
$this->dbMock->articleMark->with($this->userId, ['starred' => true], $this->equalTo((new Context)->articles([2112])))->returns(16);
|
||||||
['op' => "getArticle", 'sid' => "PriestsOfSyrinx", 'article_id' => "101"],
|
$this->dbMock->articleMark->with($this->userId, ['read' => true], $this->equalTo((new Context)->articles([42, 2112])))->returns(32); // false is read for TT-RSS
|
||||||
['op' => "getArticle", 'sid' => "PriestsOfSyrinx", 'article_id' => "102"],
|
$this->dbMock->articleMark->with($this->userId, ['read' => false], $this->equalTo((new Context)->articles([42, 2112])))->returns(64);
|
||||||
|
$this->dbMock->articleMark->with($this->userId, ['read' => true], $this->equalTo((new Context)->articles([42])))->returns(128);
|
||||||
|
$this->dbMock->articleMark->with($this->userId, ['read' => false], $this->equalTo((new Context)->articles([2112])))->returns(256);
|
||||||
|
$this->dbMock->articleMark->with($this->userId, ['note' => ""], $this->equalTo((new Context)->articles([42, 2112])))->returns(512);
|
||||||
|
$this->dbMock->articleMark->with($this->userId, ['note' => "eh"], $this->equalTo((new Context)->articles([42, 2112])))->returns(1024);
|
||||||
|
$this->dbMock->articleList->with($this->userId, $this->equalTo((new Context)->articles([42, 2112])->starred(true)), "~")->returns(new Result($this->v([['id' => 42]])));
|
||||||
|
$this->dbMock->articleList->with($this->userId, $this->equalTo((new Context)->articles([42, 2112])->starred(false)), "~")->returns(new Result($this->v([['id' => 2112]])));
|
||||||
|
$this->dbMock->articleList->with($this->userId, $this->equalTo((new Context)->articles([42, 2112])->unread(true)), "~")->returns(new Result($this->v([['id' => 42]])));
|
||||||
|
$this->dbMock->articleList->with($this->userId, $this->equalTo((new Context)->articles([42, 2112])->unread(false)), "~")->returns(new Result($this->v([['id' => 2112]])));
|
||||||
|
$this->assertMessage($exp, $this->req($in));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function provideArticleChanges(): iterable {
|
||||||
|
return [
|
||||||
|
[[], $this->respErr("INCORRECT_USAGE")],
|
||||||
|
[['article_ids' => "42, 2112, -1"], $this->respGood(['status' => "OK", 'updated' => 2])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 0], $this->respGood(['status' => "OK", 'updated' => 2])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 0, 'mode' => 0], $this->respGood(['status' => "OK", 'updated' => 2])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 0, 'mode' => 1], $this->respGood(['status' => "OK", 'updated' => 4])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 0, 'mode' => 2], $this->respGood(['status' => "OK", 'updated' => 24])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 0, 'mode' => 3], $this->respErr("INCORRECT_USAGE")],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 1], $this->respGood(['status' => "OK", 'updated' => 0])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 1, 'mode' => 0], $this->respGood(['status' => "OK", 'updated' => 0])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 1, 'mode' => 1], $this->respGood(['status' => "OK", 'updated' => 0])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 1, 'mode' => 2], $this->respGood(['status' => "OK", 'updated' => 0])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 1, 'mode' => 3], $this->respErr("INCORRECT_USAGE")],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 2], $this->respGood(['status' => "OK", 'updated' => 32])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 2, 'mode' => 0], $this->respGood(['status' => "OK", 'updated' => 32])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 2, 'mode' => 1], $this->respGood(['status' => "OK", 'updated' => 64])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 2, 'mode' => 2], $this->respGood(['status' => "OK", 'updated' => 384])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 2, 'mode' => 3], $this->respErr("INCORRECT_USAGE")],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 3], $this->respGood(['status' => "OK", 'updated' => 512])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 3, 'mode' => 0], $this->respGood(['status' => "OK", 'updated' => 512])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 3, 'mode' => 1], $this->respGood(['status' => "OK", 'updated' => 512])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 3, 'mode' => 2], $this->respGood(['status' => "OK", 'updated' => 512])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 3, 'mode' => 3], $this->respGood(['status' => "OK", 'updated' => 512])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 3, 'data' => "eh"], $this->respGood(['status' => "OK", 'updated' => 1024])],
|
||||||
|
[['article_ids' => "42, 2112, -1", 'field' => 4], $this->respErr("INCORRECT_USAGE")],
|
||||||
|
[['article_ids' => "0, -1", 'field' => 3], $this->respErr("INCORRECT_USAGE")],
|
||||||
];
|
];
|
||||||
\Phake::when(Arsse::$db)->labelList($this->anything())->thenReturn(new Result($this->v($this->labels)));
|
}
|
||||||
\Phake::when(Arsse::$db)->labelList($this->anything(), false)->thenReturn(new Result($this->v($this->usedLabels)));
|
|
||||||
\Phake::when(Arsse::$db)->articleLabelsGet($this->anything(), 101)->thenReturn([]);
|
/** @dataProvider provideArticleListings */
|
||||||
\Phake::when(Arsse::$db)->articleLabelsGet($this->anything(), 102)->thenReturn($this->v([1,3]));
|
public function testListArticles(array $in, ResponseInterface $exp): void {
|
||||||
\Phake::when(Arsse::$db)->articleList($this->anything(), (new Context)->articles([101, 102]), $this->anything())->thenReturn(new Result($this->v($this->articles)));
|
$in = array_merge(['op' => "getArticle", 'sid' => "PriestsOfSyrinx"], $in);
|
||||||
\Phake::when(Arsse::$db)->articleList($this->anything(), (new Context)->articles([101]), $this->anything())->thenReturn(new Result($this->v([$this->articles[0]])));
|
$this->dbMock->labelList->with("~")->returns(new Result($this->v($this->labels)));
|
||||||
\Phake::when(Arsse::$db)->articleList($this->anything(), (new Context)->articles([102]), $this->anything())->thenReturn(new Result($this->v([$this->articles[1]])));
|
$this->dbMock->labelList->with("~", false)->returns(new Result($this->v($this->usedLabels)));
|
||||||
$exp = $this->respErr("INCORRECT_USAGE");
|
$this->dbMock->articleLabelsGet->with("~", 101)->returns([]);
|
||||||
$this->assertMessage($exp, $this->req($in[0]));
|
$this->dbMock->articleLabelsGet->with("~", 102)->returns($this->v([1,3]));
|
||||||
$this->assertMessage($exp, $this->req($in[1]));
|
$this->dbMock->articleList->with("~", $this->equalTo((new Context)->articles([101, 102])), "~")->returns(new Result($this->v($this->articles)));
|
||||||
$this->assertMessage($exp, $this->req($in[2]));
|
$this->dbMock->articleList->with("~", $this->equalTo((new Context)->articles([101])), "~")->returns(new Result($this->v([$this->articles[0]])));
|
||||||
$this->assertMessage($exp, $this->req($in[3]));
|
$this->dbMock->articleList->with("~", $this->equalTo((new Context)->articles([102])), "~")->returns(new Result($this->v([$this->articles[1]])));
|
||||||
|
$this->assertMessage($exp, $this->req($in));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function provideArticleListings(): iterable {
|
||||||
$exp = [
|
$exp = [
|
||||||
[
|
[
|
||||||
'id' => "101",
|
'id' => "101",
|
||||||
|
@ -1535,13 +1477,15 @@ LONG_STRING;
|
||||||
'content' => '<p>Article content 2</p>',
|
'content' => '<p>Article content 2</p>',
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
$this->assertMessage($this->respGood($exp), $this->req($in[4]));
|
return [
|
||||||
$this->assertMessage($this->respGood([$exp[0]]), $this->req($in[5]));
|
[[], $this->respErr("INCORRECT_USAGE")],
|
||||||
$this->assertMessage($this->respGood([$exp[1]]), $this->req($in[6]));
|
[['article_id' => 0], $this->respErr("INCORRECT_USAGE")],
|
||||||
// test the special case when labels are not used
|
[['article_id' => -1], $this->respErr("INCORRECT_USAGE")],
|
||||||
\Phake::when(Arsse::$db)->labelList($this->anything())->thenReturn(new Result([]));
|
[['article_id' => "0,-1"], $this->respErr("INCORRECT_USAGE")],
|
||||||
\Phake::when(Arsse::$db)->labelList($this->anything(), false)->thenReturn(new Result([]));
|
[['article_id' => "101,102"], $this->respGood($exp)],
|
||||||
$this->assertMessage($this->respGood([$exp[0]]), $this->req($in[5]));
|
[['article_id' => "101"], $this->respGood([$exp[0]])],
|
||||||
|
[['article_id' => "102"], $this->respGood([$exp[1]])],
|
||||||
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @dataProvider provideHeadlines */
|
/** @dataProvider provideHeadlines */
|
||||||
|
|
Loading…
Reference in a new issue