2017-11-10 12:02:59 -05:00
|
|
|
<?php
|
2017-11-16 20:51:03 -05:00
|
|
|
/** @license MIT
|
|
|
|
* Copyright 2017 J. King, Dustin Wilson et al.
|
|
|
|
* See LICENSE and AUTHORS files for details */
|
|
|
|
|
2017-11-10 12:02:59 -05:00
|
|
|
declare(strict_types=1);
|
2021-04-14 11:17:01 -04:00
|
|
|
|
2017-12-21 22:47:19 -05:00
|
|
|
namespace JKingWeb\Arsse\TestCase\REST\TinyTinyRSS;
|
2017-11-10 12:02:59 -05:00
|
|
|
|
2017-12-21 22:47:19 -05:00
|
|
|
use JKingWeb\Arsse\Arsse;
|
|
|
|
use JKingWeb\Arsse\User;
|
|
|
|
use JKingWeb\Arsse\Database;
|
2022-08-04 22:04:39 -04:00
|
|
|
use JKingWeb\Arsse\Misc\HTTP;
|
2020-11-18 10:01:20 -05:00
|
|
|
use JKingWeb\Arsse\Db\ExceptionInput;
|
2017-12-21 22:47:19 -05:00
|
|
|
use JKingWeb\Arsse\REST\TinyTinyRSS\Icon;
|
2018-01-04 23:08:53 -05:00
|
|
|
use Psr\Http\Message\ResponseInterface;
|
2017-11-10 12:02:59 -05:00
|
|
|
|
|
|
|
/** @covers \JKingWeb\Arsse\REST\TinyTinyRSS\Icon<extended> */
|
2017-12-21 22:47:19 -05:00
|
|
|
class TestIcon extends \JKingWeb\Arsse\Test\AbstractTest {
|
2017-11-10 12:02:59 -05:00
|
|
|
protected $h;
|
2018-10-26 14:40:20 -04:00
|
|
|
protected $user = "john.doe@example.com";
|
2017-11-10 12:02:59 -05:00
|
|
|
|
2019-10-16 14:42:43 -04:00
|
|
|
public function setUp(): void {
|
2021-02-27 15:24:02 -05:00
|
|
|
parent::setUp();
|
2018-11-22 19:55:54 -05:00
|
|
|
self::setConf();
|
2021-03-01 18:01:25 -05:00
|
|
|
Arsse::$user = $this->mock(User::class)->get();
|
2017-11-10 12:02:59 -05:00
|
|
|
// create a mock database interface
|
2021-03-01 18:01:25 -05:00
|
|
|
$this->dbMock = $this->mock(Database::class);
|
2017-12-21 22:47:19 -05:00
|
|
|
$this->h = new Icon();
|
2017-11-10 12:02:59 -05:00
|
|
|
}
|
|
|
|
|
2018-10-26 14:40:20 -04:00
|
|
|
protected function req(string $target, string $method = "GET", string $user = null): ResponseInterface {
|
2021-03-01 18:01:25 -05:00
|
|
|
Arsse::$db = $this->dbMock->get();
|
2019-09-25 18:30:53 -04:00
|
|
|
$prefix = "/tt-rss/feed-icons/";
|
|
|
|
$url = $prefix.$target;
|
|
|
|
$req = $this->serverRequest($method, $url, $prefix, [], [], null, "", [], $user);
|
2018-01-04 23:08:53 -05:00
|
|
|
return $this->h->dispatch($req);
|
|
|
|
}
|
|
|
|
|
2020-01-20 13:34:03 -05:00
|
|
|
protected function reqAuth(string $target, string $method = "GET"): ResponseInterface {
|
2018-10-26 14:40:20 -04:00
|
|
|
return $this->req($target, $method, $this->user);
|
|
|
|
}
|
|
|
|
|
2020-01-20 13:34:03 -05:00
|
|
|
protected function reqAuthFailed(string $target, string $method = "GET"): ResponseInterface {
|
2018-10-26 14:40:20 -04:00
|
|
|
return $this->req($target, $method, "");
|
|
|
|
}
|
|
|
|
|
2020-01-20 13:52:48 -05:00
|
|
|
public function testRetrieveFavion(): void {
|
2021-03-01 18:01:25 -05:00
|
|
|
$this->dbMock->subscriptionIcon->returns(['url' => null]);
|
|
|
|
$this->dbMock->subscriptionIcon->with($this->anything(), 1123, false)->throws(new ExceptionInput("subjectMissing"));
|
|
|
|
$this->dbMock->subscriptionIcon->with($this->anything(), 42, false)->returns(['url' => "http://example.com/favicon.ico"]);
|
|
|
|
$this->dbMock->subscriptionIcon->with($this->anything(), 2112, false)->returns(['url' => "http://example.net/logo.png"]);
|
|
|
|
$this->dbMock->subscriptionIcon->with($this->anything(), 1337, false)->returns(['url' => "http://example.org/icon.gif\r\nLocation: http://bad.example.com/"]);
|
2017-11-10 12:02:59 -05:00
|
|
|
// these requests should succeed
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(301, ['Location' => "http://example.com/favicon.ico"]);
|
2018-01-11 11:09:25 -05:00
|
|
|
$this->assertMessage($exp, $this->req("42.ico"));
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(301, ['Location' => "http://example.net/logo.png"]);
|
2018-01-11 11:09:25 -05:00
|
|
|
$this->assertMessage($exp, $this->req("2112.ico"));
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(301, ['Location' => "http://example.org/icon.gif"]);
|
2018-01-11 11:09:25 -05:00
|
|
|
$this->assertMessage($exp, $this->req("1337.ico"));
|
2017-11-10 12:02:59 -05:00
|
|
|
// these requests should fail
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(404);
|
2018-01-11 11:09:25 -05:00
|
|
|
$this->assertMessage($exp, $this->req("ook.ico"));
|
|
|
|
$this->assertMessage($exp, $this->req("ook"));
|
|
|
|
$this->assertMessage($exp, $this->req("47.ico"));
|
|
|
|
$this->assertMessage($exp, $this->req("2112.png"));
|
2020-11-18 10:01:20 -05:00
|
|
|
$this->assertMessage($exp, $this->req("1123.ico"));
|
2017-11-10 12:02:59 -05:00
|
|
|
// only GET is allowed
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(405, ['Allow' => "GET"]);
|
2018-01-11 11:09:25 -05:00
|
|
|
$this->assertMessage($exp, $this->req("2112.ico", "PUT"));
|
2017-11-10 12:02:59 -05:00
|
|
|
}
|
2018-10-26 14:40:20 -04:00
|
|
|
|
2020-01-20 13:52:48 -05:00
|
|
|
public function testRetrieveFavionWithHttpAuthentication(): void {
|
2020-11-06 10:27:30 -05:00
|
|
|
$url = ['url' => "http://example.org/icon.gif\r\nLocation: http://bad.example.com/"];
|
2021-03-01 18:01:25 -05:00
|
|
|
$this->dbMock->subscriptionIcon->returns(['url' => null]);
|
|
|
|
$this->dbMock->subscriptionIcon->with($this->user, 42, false)->returns($url);
|
|
|
|
$this->dbMock->subscriptionIcon->with("jane.doe", 2112, false)->returns($url);
|
|
|
|
$this->dbMock->subscriptionIcon->with($this->user, 1337, false)->returns($url);
|
|
|
|
$this->dbMock->subscriptionIcon->with(null, 42, false)->returns($url);
|
|
|
|
$this->dbMock->subscriptionIcon->with(null, 2112, false)->returns($url);
|
|
|
|
$this->dbMock->subscriptionIcon->with(null, 1337, false)->returns($url);
|
2018-10-26 14:40:20 -04:00
|
|
|
// these requests should succeed
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(301, ['Location' => "http://example.org/icon.gif"]);
|
2018-10-26 14:40:20 -04:00
|
|
|
$this->assertMessage($exp, $this->req("42.ico"));
|
|
|
|
$this->assertMessage($exp, $this->req("2112.ico"));
|
|
|
|
$this->assertMessage($exp, $this->req("1337.ico"));
|
|
|
|
$this->assertMessage($exp, $this->reqAuth("42.ico"));
|
|
|
|
$this->assertMessage($exp, $this->reqAuth("1337.ico"));
|
|
|
|
// these requests should fail
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(404);
|
2018-10-26 14:40:20 -04:00
|
|
|
$this->assertMessage($exp, $this->reqAuth("2112.ico"));
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(401);
|
2018-10-26 14:40:20 -04:00
|
|
|
$this->assertMessage($exp, $this->reqAuthFailed("42.ico"));
|
|
|
|
$this->assertMessage($exp, $this->reqAuthFailed("1337.ico"));
|
|
|
|
// with HTTP auth required, only authenticated requests should succeed
|
2018-11-22 19:55:54 -05:00
|
|
|
self::setConf(['userHTTPAuthRequired' => true]);
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(301, ['Location' => "http://example.org/icon.gif"]);
|
2018-10-26 14:40:20 -04:00
|
|
|
$this->assertMessage($exp, $this->reqAuth("42.ico"));
|
|
|
|
$this->assertMessage($exp, $this->reqAuth("1337.ico"));
|
|
|
|
// anything else should fail
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(401);
|
2018-10-26 14:40:20 -04:00
|
|
|
$this->assertMessage($exp, $this->req("42.ico"));
|
|
|
|
$this->assertMessage($exp, $this->req("2112.ico"));
|
|
|
|
$this->assertMessage($exp, $this->req("1337.ico"));
|
|
|
|
$this->assertMessage($exp, $this->reqAuthFailed("42.ico"));
|
|
|
|
$this->assertMessage($exp, $this->reqAuthFailed("1337.ico"));
|
|
|
|
// resources for the wrtong user should still fail, too
|
2022-08-04 22:04:39 -04:00
|
|
|
$exp = HTTP::respEmpty(404);
|
2018-10-26 14:40:20 -04:00
|
|
|
$this->assertMessage($exp, $this->reqAuth("2112.ico"));
|
|
|
|
}
|
2017-11-10 12:02:59 -05:00
|
|
|
}
|