[PLUGIN][ActivityPub][Tests] Create a TestCase for the plugin
This commit is contained in:
parent
7d84323df4
commit
636cb681d6
61
plugins/ActivityPub/tests/ActivityPubTestCase.php
Normal file
61
plugins/ActivityPub/tests/ActivityPubTestCase.php
Normal file
@ -0,0 +1,61 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types = 1);
|
||||
|
||||
namespace Plugin\ActivityPub\tests;
|
||||
|
||||
use App\Core\DB\DB;
|
||||
use App\Util\GNUsocialTestCase;
|
||||
use Plugin\ActivityPub\Util\Model\Activity;
|
||||
use Plugin\ActivityPub\Util\Model\Actor;
|
||||
use Plugin\ActivityPub\Util\Model\Note;
|
||||
|
||||
class ActivityPubTestCase extends GNUsocialTestCase
|
||||
{
|
||||
private static bool $loaded_fixtures = false;
|
||||
private static string $fixtures_path = INSTALLDIR . '/plugins/ActivityPub/tests/fixtures';
|
||||
|
||||
public static function fixturesPath(string $path, string $ontology = 'gnusocial'): string
|
||||
{
|
||||
return self::$fixtures_path . \DIRECTORY_SEPARATOR . $ontology . \DIRECTORY_SEPARATOR . $path;
|
||||
}
|
||||
|
||||
public static function setUpBeforeClass(): void
|
||||
{
|
||||
static::bootKernel();
|
||||
if (!static::$loaded_fixtures) {
|
||||
static::loadFixtures();
|
||||
}
|
||||
static::$loaded_fixtures = true;
|
||||
}
|
||||
|
||||
public static function loadFixtures(string $ontology = 'gnusocial'): void
|
||||
{
|
||||
/*
|
||||
* Beware that it's important to Load Actors, Objects, Activities in this sequence
|
||||
* because we're running offline tests here.
|
||||
*/
|
||||
|
||||
// Load Actors
|
||||
$person = Actor::fromJson(file_get_contents(self::fixturesPath('objects/person.jsonld', $ontology)));
|
||||
DB::flush();
|
||||
$group = Actor::fromJson(file_get_contents(self::fixturesPath('objects/group.jsonld', $ontology)));
|
||||
DB::flush();
|
||||
|
||||
// Load Objects
|
||||
$note = Note::fromJson(file_get_contents(self::fixturesPath('objects/note.jsonld', $ontology)));
|
||||
DB::flush();
|
||||
$page = Note::fromJson(file_get_contents(self::fixturesPath('objects/page.jsonld', $ontology)));
|
||||
DB::flush();
|
||||
$reply = Note::fromJson(file_get_contents(self::fixturesPath('objects/reply.jsonld', $ontology)));
|
||||
DB::flush();
|
||||
|
||||
// Load Activities
|
||||
$create_note = Activity::fromJson(file_get_contents(self::fixturesPath('activities/create_note.jsonld', $ontology)));
|
||||
DB::flush();
|
||||
$create_page = Activity::fromJson(file_get_contents(self::fixturesPath('activities/create_page.jsonld', $ontology)));
|
||||
DB::flush();
|
||||
$create_reply = Activity::fromJson(file_get_contents(self::fixturesPath('activities/create_reply.jsonld', $ontology)));
|
||||
DB::flush();
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user