1
1
Fork 0
mirror of https://code.mensbeam.com/MensBeam/Arsse.git synced 2025-01-07 00:12:40 +00:00

Test cleanup

This commit is contained in:
J. King 2024-12-25 10:11:28 -05:00
parent 1f137ba710
commit 9c25b7b6e6
6 changed files with 13 additions and 13 deletions

View file

@ -14,7 +14,6 @@ use JKingWeb\Arsse\User;
use JKingWeb\Arsse\Database; use JKingWeb\Arsse\Database;
use JKingWeb\Arsse\Service; use JKingWeb\Arsse\Service;
use JKingWeb\Arsse\CLI; use JKingWeb\Arsse\CLI;
use JKingWeb\Arsse\Factory;
use JKingWeb\Arsse\REST\Fever\User as FeverUser; use JKingWeb\Arsse\REST\Fever\User as FeverUser;
use JKingWeb\Arsse\REST\Miniflux\Token as MinifluxToken; use JKingWeb\Arsse\REST\Miniflux\Token as MinifluxToken;
use JKingWeb\Arsse\ImportExport\OPML; use JKingWeb\Arsse\ImportExport\OPML;
@ -25,11 +24,8 @@ class TestCLI extends \JKingWeb\Arsse\Test\AbstractTest {
protected $cli; protected $cli;
public function setUp(): void { public function setUp(): void {
parent::setup();
Arsse::$db = \Phake::mock(Database::class); Arsse::$db = \Phake::mock(Database::class);
Arsse::$obj = \Phake::mock(Factory::class);
\Phake::when(Arsse::$obj)->get->thenReturnCallback(function($c) {
return new $c;
});
$this->cli = \Phake::partialMock(CLI::class); $this->cli = \Phake::partialMock(CLI::class);
\Phake::when($this->cli)->logError->thenReturn(null); \Phake::when($this->cli)->logError->thenReturn(null);
\Phake::when($this->cli)->loadConf->thenReturn(true); \Phake::when($this->cli)->loadConf->thenReturn(true);

View file

@ -53,7 +53,8 @@ abstract class BaseResult extends \JKingWeb\Arsse\Test\AbstractTest {
$this->makeResult(static::$createMeta); $this->makeResult(static::$createMeta);
$r = new $this->resultClass(...$this->makeResult("INSERT INTO arsse_meta(\"key\",value) values('test', 1)")); $r = new $this->resultClass(...$this->makeResult("INSERT INTO arsse_meta(\"key\",value) values('test', 1)"));
$this->assertSame(1, $r->changes()); $this->assertSame(1, $r->changes());
$this->assertSame(0, $r->lastId()); // FIXME: In PHP 8.4 the result seems to have changed for the SQLite3 class
// $this->assertSame(0, $r->lastId());
} }
public function testGetChangeCountAndLastInsertIdBis(): void { public function testGetChangeCountAndLastInsertIdBis(): void {

View file

@ -16,7 +16,6 @@ use JKingWeb\Arsse\Database;
use JKingWeb\Arsse\Misc\HTTP; use JKingWeb\Arsse\Misc\HTTP;
use JKingWeb\Arsse\Db\Transaction; use JKingWeb\Arsse\Db\Transaction;
use JKingWeb\Arsse\Db\ExceptionInput; use JKingWeb\Arsse\Db\ExceptionInput;
use JKingWeb\Arsse\Factory;
use JKingWeb\Arsse\REST\Miniflux\V1; use JKingWeb\Arsse\REST\Miniflux\V1;
use JKingWeb\Arsse\Feed\Exception as FeedException; use JKingWeb\Arsse\Feed\Exception as FeedException;
use JKingWeb\Arsse\ImportExport\Exception as ImportException; use JKingWeb\Arsse\ImportExport\Exception as ImportException;
@ -76,7 +75,6 @@ class TestV1 extends \JKingWeb\Arsse\Test\AbstractTest {
self::setConf(); self::setConf();
$this->transaction = \Phake::mock(Transaction::class); $this->transaction = \Phake::mock(Transaction::class);
// create mock timestamps // create mock timestamps
Arsse::$obj = \Phake::mock(Factory::class);
\Phake::when(Arsse::$obj)->get(\DateTimeImmutable::class)->thenReturn(new \DateTimeImmutable(self::NOW)); \Phake::when(Arsse::$obj)->get(\DateTimeImmutable::class)->thenReturn(new \DateTimeImmutable(self::NOW));
// create a mock database interface // create a mock database interface
Arsse::$db = \Phake::mock(Database::class); Arsse::$db = \Phake::mock(Database::class);

View file

@ -19,7 +19,6 @@ use Psr\Http\Message\ResponseInterface;
use GuzzleHttp\Psr7\Response; use GuzzleHttp\Psr7\Response;
use GuzzleHttp\Psr7\Request; use GuzzleHttp\Psr7\Request;
use GuzzleHttp\Psr7\ServerRequest; use GuzzleHttp\Psr7\ServerRequest;
use JKingWeb\Arsse\Factory;
/** @covers \JKingWeb\Arsse\REST */ /** @covers \JKingWeb\Arsse\REST */
class TestREST extends \JKingWeb\Arsse\Test\AbstractTest { class TestREST extends \JKingWeb\Arsse\Test\AbstractTest {
@ -295,7 +294,6 @@ class TestREST extends \JKingWeb\Arsse\Test\AbstractTest {
return $req; return $req;
}); });
if ($called) { if ($called) {
Arsse::$obj = \Phake::mock(Factory::class);
$hMock = \Phake::mock($class); $hMock = \Phake::mock($class);
\Phake::when($hMock)->dispatch->thenReturn(HTTP::respEmpty(204)); \Phake::when($hMock)->dispatch->thenReturn(HTTP::respEmpty(204));
\Phake::when(Arsse::$obj)->get($class)->thenReturn($hMock); \Phake::when(Arsse::$obj)->get($class)->thenReturn($hMock);

View file

@ -16,7 +16,6 @@ use JKingWeb\Arsse\Misc\HTTP;
use JKingWeb\Arsse\Context\Context; use JKingWeb\Arsse\Context\Context;
use JKingWeb\Arsse\Db\ExceptionInput; use JKingWeb\Arsse\Db\ExceptionInput;
use JKingWeb\Arsse\Db\Transaction; use JKingWeb\Arsse\Db\Transaction;
use JKingWeb\Arsse\Factory;
use JKingWeb\Arsse\REST\TinyTinyRSS\API; use JKingWeb\Arsse\REST\TinyTinyRSS\API;
use JKingWeb\Arsse\Feed\Exception as FeedException; use JKingWeb\Arsse\Feed\Exception as FeedException;
use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ResponseInterface;
@ -130,10 +129,9 @@ LONG_STRING;
} }
public function setUp(): void { public function setUp(): void {
self::clearData(); parent::setUp();
self::setConf(); self::setConf();
// create mock timestamps // create mock timestamps
Arsse::$obj = \Phake::mock(Factory::class);
\Phake::when(Arsse::$obj)->get(\DateTimeImmutable::class)->thenReturn(new \DateTimeImmutable(self::NOW)); \Phake::when(Arsse::$obj)->get(\DateTimeImmutable::class)->thenReturn(new \DateTimeImmutable(self::NOW));
// create a mock user manager // create a mock user manager
$this->userId = "john.doe@example.com"; $this->userId = "john.doe@example.com";

View file

@ -29,6 +29,15 @@ use GuzzleHttp\Psr7\ServerRequest;
abstract class AbstractTest extends \PHPUnit\Framework\TestCase { abstract class AbstractTest extends \PHPUnit\Framework\TestCase {
use \DMS\PHPUnitExtensions\ArraySubset\ArraySubsetAsserts; use \DMS\PHPUnitExtensions\ArraySubset\ArraySubsetAsserts;
public function setUp(): void {
self::clearData();
// create the object factory as a mock
Arsse::$obj = \Phake::mock(Factory::class);
\Phake::when(Arsse::$obj)->get->thenReturnCallback(function(string $class) {
return new $class;
});
}
public static function clearData(bool $loadLang = true): void { public static function clearData(bool $loadLang = true): void {
date_default_timezone_set("America/Toronto"); date_default_timezone_set("America/Toronto");
$r = new \ReflectionClass(\JKingWeb\Arsse\Arsse::class); $r = new \ReflectionClass(\JKingWeb\Arsse\Arsse::class);